

# EFR32xG24 Wireless SoC Reference Manual



The EFR32xG24 Wireless SoC includes the EFR32BG24 and EFR32MG24 Wireless families. The EFR32xG24 improves processing capability with an ARM Cortex®-M33 core, while providing for lower active current for both the MCU and radio. This low power and application-optimized device supports Bluetooth 5.3 (including Direction Finding), Proprietary 2.4 GHz & Zigbee PRO/Green Power protocols.

The EFR32xG24 solution provides industry-leading energy efficiency, processing capability, and RF performance in a small form factor for IoT connected applications.

## KEY FEATURES

- 32-bit ARM Cortex®-M33 core with up to 78.0 MHz maximum operating frequency
- Scalable Memory and Radio configuration options available in QFN packaging
- Integrated PA with up to 19.5 dBm transmit power
- Energy-efficient radio core with low active and sleep currents
- Secure Vault™
- AI/ML Hardware Accelerator



# Table of Contents

|                                           |    |
|-------------------------------------------|----|
| <b>1. About This Document</b>             | 27 |
| 1.1 Introduction                          | 27 |
| 1.2 Conventions                           | 28 |
| 1.3 Related Documentation                 | 29 |
| <b>2. System Overview</b>                 | 30 |
| 2.1 Introduction                          | 31 |
| 2.2 Block Diagrams                        | 32 |
| 2.3 MCU Features overview                 | 33 |
| <b>3. System Processor</b>                | 35 |
| 3.1 Introduction                          | 35 |
| 3.2 Features                              | 36 |
| 3.3 Functional Description                | 36 |
| 3.3.1 Interrupt Operation                 | 37 |
| 3.3.2 TrustZone                           | 37 |
| 3.3.3 Interrupt Request Lines (IRQ)       | 38 |
| <b>4. Memory and Bus System</b>           | 41 |
| 4.1 Introduction                          | 41 |
| 4.2 Functional Description                | 42 |
| 4.2.1 Bus Matrix                          | 43 |
| 4.2.2 Flash                               | 44 |
| 4.2.3 SRAM                                | 44 |
| 4.2.4 Peripherals                         | 44 |
| <b>5. Radio Transceiver</b>               | 50 |
| 5.1 Introduction                          | 51 |
| 5.1.1 RF Frequency Synthesizer            | 51 |
| 5.1.2 Modulation Modes                    | 52 |
| 5.1.3 Transmit Mode                       | 52 |
| 5.1.4 Receive Mode                        | 52 |
| 5.1.5 Data Buffering                      | 52 |
| 5.1.6 Unbuffered Data Transfer            | 52 |
| 5.1.7 Frame Format Support                | 53 |
| 5.1.8 Hardware CRC Support                | 53 |
| 5.1.9 Convolutional Encoding / Decoding   | 53 |
| 5.1.10 Binary Block Encoding / Decoding   | 53 |
| 5.1.11 Data Encryption and Authentication | 54 |
| 5.1.12 RF Test Modes                      | 54 |
| <b>6. MSC - Memory System Controller</b>  | 55 |
| 6.1 Introduction                          | 55 |
| 6.2 Features                              | 56 |

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| 6.3 Functional Description . . . . .                                        | .56  |
| 6.3.1 RAM Configuration . . . . .                                           | .56  |
| 6.3.2 Instruction Cache. . . . .                                            | .57  |
| 6.3.3 Device Information (DI) Page . . . . .                                | .57  |
| 6.3.4 User Data (UD) Page Description . . . . .                             | .57  |
| 6.3.5 Bootloader . . . . .                                                  | .57  |
| 6.3.6 Post-reset Behavior . . . . .                                         | .57  |
| 6.3.7 Flash Startup . . . . .                                               | .57  |
| 6.3.8 Flash EM0 / EM1 Power Down . . . . .                                  | .57  |
| 6.3.9 Wait-states . . . . .                                                 | .57  |
| 6.3.10 Cortex®-M33 If-Then Block Folding . . . . .                          | .58  |
| 6.3.11 Line Buffering (Prefetch). . . . .                                   | .58  |
| 6.3.12 Erase and Write Operations. . . . .                                  | .59  |
| 6.4 DEVINFO - Device Info Page . . . . .                                    | .60  |
| 6.4.1 DEVINFO Register Map . . . . .                                        | .61  |
| 6.4.2 DEVINFO Register Description . . . . .                                | .62  |
| 6.5 ICACHE - Instruction Cache . . . . .                                    | .90  |
| 6.5.1 Cache Operation . . . . .                                             | .90  |
| 6.5.2 Performance Measurement . . . . .                                     | .91  |
| 6.5.3 ICACHE Register Map . . . . .                                         | .92  |
| 6.5.4 ICACHE Register Description . . . . .                                 | .93  |
| 6.6 SYSCFG - System Configuration . . . . .                                 | .99  |
| 6.6.1 RAM Retention . . . . .                                               | .99  |
| 6.6.2 ECC . . . . .                                                         | .100 |
| 6.6.3 Software Interrupts . . . . .                                         | .100 |
| 6.6.4 Bus faults . . . . .                                                  | .100 |
| 6.6.5 SYSCFG Register Map. . . . .                                          | .101 |
| 6.6.6 SYSCFG Register Description . . . . .                                 | .104 |
| 6.6.7 MPAHBRAM Register Map . . . . .                                       | .121 |
| 6.6.8 MPAHBRAM Register Description . . . . .                               | .122 |
| 6.7 MSC Register Map . . . . .                                              | .129 |
| 6.8 MSC Register Description . . . . .                                      | .131 |
| 6.8.1 MSC_IPVERSION - IP Version ID . . . . .                               | .131 |
| 6.8.2 MSC_READCTRL - Read Control Register . . . . .                        | .132 |
| 6.8.3 MSC_RDATACTRL - Read Data Control Register. . . . .                   | .133 |
| 6.8.4 MSC_WRITECTRL - Write Control Register. . . . .                       | .134 |
| 6.8.5 MSC_WRITECMD - Write Command Register . . . . .                       | .135 |
| 6.8.6 MSC_ADDRB - Page Erase/Write Address Buffer. . . . .                  | .136 |
| 6.8.7 MSC_WDATA - Write Data Register . . . . .                             | .136 |
| 6.8.8 MSC_STATUS - Status Register . . . . .                                | .137 |
| 6.8.9 MSC_IF - Interrupt Flag Register . . . . .                            | .138 |
| 6.8.10 MSC_IEN - Interrupt Enable Register . . . . .                        | .139 |
| 6.8.11 MSC_USERDATASIZE - User Data Region Size Register . . . . .          | .140 |
| 6.8.12 MSC_CMD - Command Register . . . . .                                 | .140 |
| 6.8.13 MSC_LOCK - Configuration Lock Register . . . . .                     | .141 |
| 6.8.14 MSC_MISCLOCKWORD - Mass Erase and User Data Page Lock Word . . . . . | .141 |
| 6.8.15 MSC_PWRCTRL - Power Control Register . . . . .                       | .142 |

|                                                                              |            |
|------------------------------------------------------------------------------|------------|
| 6.8.16 MSC_PAGELOCK0 - Main Space Page 0-31 Lock Word . . . . .              | 143        |
| 6.8.17 MSC_PAGELOCK1 - Main Space Page 32-63 Lock Word . . . . .             | 143        |
| 6.8.18 MSC_PAGELOCK2 - Main Space Page 64-95 Lock Word . . . . .             | 144        |
| 6.8.19 MSC_PAGELOCK3 - Main Space Page 96-127 Lock Word . . . . .            | 144        |
| 6.8.20 MSC_PAGELOCK4 - Main Space Page 128-159 Lock Word . . . . .           | 145        |
| 6.8.21 MSC_PAGELOCK5 - Main Space Page 160-191 Lock Word . . . . .           | 145        |
| <b>7. DBG - Debug Interface . . . . .</b>                                    | <b>146</b> |
| 7.1 Introduction . . . . .                                                   | 146        |
| 7.2 Features . . . . .                                                       | 146        |
| 7.3 Functional Description . . . . .                                         | 147        |
| 7.3.1 Debug Pins . . . . .                                                   | 147        |
| 7.3.2 Embedded Trace Macrocell (ETM) . . . . .                               | 147        |
| 7.3.3 Debug and EM2/EM3 . . . . .                                            | 147        |
| <b>8. CMU - Clock Management Unit . . . . .</b>                              | <b>148</b> |
| 8.1 Introduction . . . . .                                                   | 148        |
| 8.2 Features . . . . .                                                       | 148        |
| 8.3 Functional Description . . . . .                                         | 149        |
| 8.3.1 System Clocks . . . . .                                                | 152        |
| 8.3.2 Switching Clock Source . . . . .                                       | 156        |
| 8.3.3 RC Oscillator Calibration . . . . .                                    | 158        |
| 8.3.4 Energy Modes . . . . .                                                 | 161        |
| 8.3.5 Clock Output . . . . .                                                 | 162        |
| 8.3.6 Clock Input from a Pin . . . . .                                       | 162        |
| 8.3.7 Interrupts . . . . .                                                   | 162        |
| 8.3.8 Protection . . . . .                                                   | 162        |
| 8.4 CMU Register Map . . . . .                                               | 163        |
| 8.5 CMU Register Description . . . . .                                       | 166        |
| 8.5.1 CMU_IPVERSION - IP Version ID . . . . .                                | 166        |
| 8.5.2 CMU_STATUS - Status Register . . . . .                                 | 167        |
| 8.5.3 CMU_LOCK - Configuration Lock Register . . . . .                       | 168        |
| 8.5.4 CMU_WDOGLOCK - WDOG Configuration Lock Register . . . . .              | 168        |
| 8.5.5 CMU_IF - Interrupt Flag Register . . . . .                             | 169        |
| 8.5.6 CMU_IEN - Interrupt Enable Register . . . . .                          | 169        |
| 8.5.7 CMU_CALCMD - Calibration Command Register . . . . .                    | 170        |
| 8.5.8 CMU_CALCTRL - Calibration Control Register . . . . .                   | 171        |
| 8.5.9 CMU_CALCNT - Calibration Result Counter Register . . . . .             | 172        |
| 8.5.10 CMU_CLKEN0 - Clock Enable Register 0 . . . . .                        | 173        |
| 8.5.11 CMU_CLKEN1 - Clock Enable Register 1 . . . . .                        | 175        |
| 8.5.12 CMU_SYSCLKCTRL - System Clock Control . . . . .                       | 177        |
| 8.5.13 CMU_TRACECLKCTRL - Debug Trace Clock Control . . . . .                | 178        |
| 8.5.14 CMU_EXPORTCLKCTRL - Export Clock Control . . . . .                    | 179        |
| 8.5.15 CMU_DPLLREFCLKCTRL - Digital PLL Reference Clock Control . . . . .    | 181        |
| 8.5.16 CMU_EM01GRPACLKCTRL - EM01 Peripheral Group a Clock Control . . . . . | 182        |
| 8.5.17 CMU_EM01GRPCCLKCTRL - EM01 Peripheral Group C Clock Control . . . . . | 183        |
| 8.5.18 CMU_EM23GRPACLKCTRL - EM23 Peripheral Group a Clock Control . . . . . | 184        |

|                                                                            |            |
|----------------------------------------------------------------------------|------------|
| 8.5.19 CMU_EM4GRPACLKCTRL - EM4 Peripheral Group a Clock Control . . . . . | 184        |
| 8.5.20 CMU_IADCCLKCTRL - IADC Clock Control . . . . .                      | 185        |
| 8.5.21 CMU_WDOG0CLKCTRL - Watchdog0 Clock Control . . . . .                | 185        |
| 8.5.22 CMU_WDOG1CLKCTRL - Watchdog1 Clock Control . . . . .                | 186        |
| 8.5.23 CMU_EUSART0CLKCTRL - EUSART0 Clock Control . . . . .                | 187        |
| 8.5.24 CMU_SYSRTC0CLKCTRL - System RTC0 Clock Control . . . . .            | 188        |
| 8.5.25 CMU_VDAC0CLKCTRL - VDAC0 Clock Control . . . . .                    | 189        |
| 8.5.26 CMU_PCNT0CLKCTRL - Pulse Counter 0 Clock Control . . . . .          | 190        |
| 8.5.27 CMU_RADIOCLKCTRL - Radio Clock Control . . . . .                    | 190        |
| 8.5.28 CMU_VDAC1CLKCTRL - VDAC1 Clock Control . . . . .                    | 191        |
| <b>9. Oscillators . . . . .</b>                                            | <b>192</b> |
| 9.1 Introduction . . . . .                                                 | 192        |
| 9.2 HFXO - High Frequency Crystal Oscillator . . . . .                     | 192        |
| 9.2.1 Introduction . . . . .                                               | 192        |
| 9.2.2 Features . . . . .                                                   | 192        |
| 9.2.3 Functional Description . . . . .                                     | 193        |
| 9.2.4 HFXO Register Map . . . . .                                          | 197        |
| 9.2.5 HFXO Register Description . . . . .                                  | 198        |
| 9.3 HFRCO - High-Frequency RC Oscillator . . . . .                         | 217        |
| 9.3.1 Introduction . . . . .                                               | 217        |
| 9.3.2 Features . . . . .                                                   | 217        |
| 9.3.3 Functional Description . . . . .                                     | 217        |
| 9.3.4 HFRCO Register Map . . . . .                                         | 220        |
| 9.3.5 HFRCO Register Description . . . . .                                 | 221        |
| 9.4 DPLL - Digital Phased Locked Loop . . . . .                            | 225        |
| 9.4.1 Introduction . . . . .                                               | 225        |
| 9.4.2 Features . . . . .                                                   | 225        |
| 9.4.3 Functional Description . . . . .                                     | 225        |
| 9.4.4 DPLL Register Map . . . . .                                          | 227        |
| 9.4.5 DPLL Register Description . . . . .                                  | 228        |
| 9.5 LFXO - Low-Frequency Crystal Oscillator . . . . .                      | 233        |
| 9.5.1 Introduction . . . . .                                               | 233        |
| 9.5.2 Features . . . . .                                                   | 233        |
| 9.5.3 Functional Description . . . . .                                     | 233        |
| 9.5.4 LFXO Register Map . . . . .                                          | 235        |
| 9.5.5 LFXO Register Description . . . . .                                  | 236        |
| 9.6 LFRCO - Low-Frequency RC Oscillator . . . . .                          | 243        |
| 9.6.1 Introduction . . . . .                                               | 243        |
| 9.6.2 Features . . . . .                                                   | 243        |
| 9.6.3 Functional Description . . . . .                                     | 243        |
| 9.6.4 LFRCO Register Map . . . . .                                         | 246        |
| 9.6.5 LFRCO Register Description . . . . .                                 | 247        |
| 9.7 FSRCO - Fast Start RCO . . . . .                                       | 254        |
| 9.7.1 Introduction . . . . .                                               | 254        |
| 9.7.2 Features . . . . .                                                   | 254        |
| 9.7.3 Functional Description . . . . .                                     | 254        |

|                                                           |            |
|-----------------------------------------------------------|------------|
| 9.7.4 FSRCO Register Map . . . . .                        | 254        |
| 9.7.5 FSRCO Register Description . . . . .                | 255        |
| 9.8 ULFRCO - Ultra Low Frequency RC Oscillator . . . . .  | 255        |
| 9.8.1 Introduction . . . . .                              | 255        |
| 9.8.2 Features . . . . .                                  | 255        |
| 9.8.3 Functional Description . . . . .                    | 255        |
| <b>10. SMU - Security Management Unit . . . . .</b>       | <b>256</b> |
| 10.1 Introduction . . . . .                               | 256        |
| 10.2 Features . . . . .                                   | 256        |
| 10.3 Functional Description . . . . .                     | 257        |
| 10.3.1 Bus Level Security . . . . .                       | 257        |
| 10.3.2 Privileged Access Control . . . . .                | 258        |
| 10.3.3 Secure Access Control . . . . .                    | 258        |
| 10.3.4 ARM TrustZone . . . . .                            | 259        |
| 10.3.5 Configuring Managers . . . . .                     | 259        |
| 10.3.6 Configuring Peripherals . . . . .                  | 259        |
| 10.3.7 Configuring Memory . . . . .                       | 260        |
| 10.3.8 Cortex®-M33 Integration . . . . .                  | 260        |
| 10.3.9 Exception Handling . . . . .                       | 261        |
| 10.3.10 SMU Lock . . . . .                                | 261        |
| 10.4 SMU Register Map . . . . .                           | 262        |
| 10.5 SMU Register Description . . . . .                   | 264        |
| 10.5.1 SMU_IPVERSION - IP Version . . . . .               | 264        |
| 10.5.2 SMU_STATUS - Status Register . . . . .             | 265        |
| 10.5.3 SMU_LOCK - Lock Register . . . . .                 | 265        |
| 10.5.4 SMU_IF - Interrupt Flag Register . . . . .         | 266        |
| 10.5.5 SMU_IEN - Interrupt Enable Register . . . . .      | 267        |
| 10.5.6 SMU_M33CTRL - M33 Control Settings . . . . .       | 268        |
| 10.5.7 SMU_PPUPATD0 - Privileged Access . . . . .         | 269        |
| 10.5.8 SMU_PPUPATD1 - Privileged Access . . . . .         | 271        |
| 10.5.9 SMU_PPUSATD0 - Secure Access . . . . .             | 273        |
| 10.5.10 SMU_PPUSATD1 - Secure Access . . . . .            | 275        |
| 10.5.11 SMU_PPUFS - Fault Status . . . . .                | 276        |
| 10.5.12 SMU_BMPUPATD0 - Privileged Attribute . . . . .    | 277        |
| 10.5.13 SMU_BMPUSATD0 - Secure Attribute . . . . .        | 278        |
| 10.5.14 SMU_BMPUFS - Fault Status . . . . .               | 279        |
| 10.5.15 SMU_BMPUFSADDR - Fault Status Address . . . . .   | 279        |
| 10.5.16 SMU_ESAURTYPE0 - Region Types 0 . . . . .         | 280        |
| 10.5.17 SMU_ESAURTYPE1 - Region Types 1 . . . . .         | 280        |
| 10.5.18 SMU_ESAUMRB01 - Movable Region Boundary . . . . . | 281        |
| 10.5.19 SMU_ESAUMRB12 - Movable Region Boundary . . . . . | 281        |
| 10.5.20 SMU_ESAUMRB45 - Movable Region Boundary . . . . . | 282        |
| 10.5.21 SMU_ESAUMRB56 - Movable Region Boundary . . . . . | 282        |
| <b>11. SE - Secure Engine Subsystem . . . . .</b>         | <b>283</b> |
| 11.1 Introduction . . . . .                               | 283        |

|                                                                       |     |
|-----------------------------------------------------------------------|-----|
| <b>11.2 Security Features</b>                                         | 283 |
| 11.2.1 Security Features Overview                                     | 283 |
| 11.2.2 Secure Boot with Root of Trust and Secure Loader (RTSL)        | 284 |
| 11.2.3 Secure Debug                                                   | 284 |
| 11.2.4 Cryptographic Accelerator                                      | 284 |
| 11.2.5 True Random Number Generation                                  | 284 |
| <b>11.3 SE Mailbox</b>                                                | 285 |
| 11.3.1 Sending Commands                                               | 285 |
| 11.3.2 Receiving Responses                                            | 285 |
| 11.3.3 MAILBOX Register Map                                           | 285 |
| 11.3.4 MAILBOX Register Description                                   | 286 |
| <b>12. EMU - Energy Management Unit</b>                               | 288 |
| 12.1 Introduction.                                                    | 288 |
| 12.2 Features                                                         | 289 |
| 12.3 Functional Description                                           | 290 |
| 12.3.1 Energy Modes                                                   | 291 |
| 12.3.2 Entering Low Energy Modes                                      | 295 |
| 12.3.3 Exiting a Low Energy Mode                                      | 297 |
| 12.3.4 Power Domains                                                  | 298 |
| 12.3.5 Voltage Scaling                                                | 298 |
| 12.3.6 EM0 / EM1 Peripheral Register Retention                        | 299 |
| 12.3.7 Power Configurations                                           | 300 |
| 12.3.8 Buck DC-DC Interface                                           | 304 |
| 12.3.9 EFP01 Communication                                            | 307 |
| 12.3.10 Brown Out Detector (BOD)                                      | 308 |
| 12.3.11 Reset Management Unit                                         | 309 |
| 12.3.12 Temperature Sensor.                                           | 311 |
| 12.3.13 Register Locks.                                               | 312 |
| 12.4 EMU Register Map                                                 | 313 |
| 12.5 EMU Register Description                                         | 316 |
| 12.5.1 EMU_DECBOD - DECOUPLE LVBOD Control Register                   | 316 |
| 12.5.2 EMU_BOD3SENSE - BOD3SENSE Control Register                     | 317 |
| 12.5.3 EMU_VREGVDDCMPCTRL - DC-DC VREGVDD Comparator Control Register | 317 |
| 12.5.4 EMU_PD1PARETCTRL - PD1 Partial Retention Control               | 318 |
| 12.5.5 EMU_IPVERSION - IP Version                                     | 318 |
| 12.5.6 EMU_LOCK - EMU Configuration Lock Register                     | 319 |
| 12.5.7 EMU_IF - Interrupt Flags                                       | 320 |
| 12.5.8 EMU_IEN - Interrupt Enables                                    | 321 |
| 12.5.9 EMU_EM4CTRL - EM4 Control                                      | 322 |
| 12.5.10 EMU_CMD - EMU Command Register                                | 323 |
| 12.5.11 EMU_CTRL - EMU Control Register                               | 324 |
| 12.5.12 EMU_TEMPLIMITS - EMU Temperature Thresholds                   | 325 |
| 12.5.13 EMU_STATUS - EMU Status Register.                             | 326 |
| 12.5.14 EMU_TEMP - Temperature                                        | 327 |
| 12.5.15 EMU_RSTCTRL - Reset Management Control Register               | 328 |
| 12.5.16 EMU_RSTCAUSE - Reset Cause                                    | 330 |

|            |                                                             |            |
|------------|-------------------------------------------------------------|------------|
| 12.5.17    | EMU_TAMPERRSTCAUSE - Tamper Reset Cause                     | 331        |
| 12.5.18    | EMU_DGIF - Interrupt Flags Debug                            | 332        |
| 12.5.19    | EMU_DGIEN - Interrupt Enables Debug                         | 333        |
| 12.5.20    | EMU_EFPIF - EFP Interrupt Register                          | 333        |
| 12.5.21    | EMU_EFPIEN - EFP Interrupt Enable Register                  | 334        |
| 12.6       | DCDC Register Map                                           | 335        |
| 12.7       | DCDC Register Description                                   | 336        |
| 12.7.1     | DCDC_IPVERSION - IPVERSION                                  | 336        |
| 12.7.2     | DCDC_CTRL - Control                                         | 337        |
| 12.7.3     | DCDC_EM01CTRL0 - EM01 Control                               | 338        |
| 12.7.4     | DCDC_EM23CTRL0 - EM23 Control                               | 339        |
| 12.7.5     | DCDC_PFMXCTRL - PFMX Control Register                       | 340        |
| 12.7.6     | DCDC_IF - Interrupt Flags                                   | 341        |
| 12.7.7     | DCDC_IEN - Interrupt Enable                                 | 342        |
| 12.7.8     | DCDC_STATUS - Status Register                               | 343        |
| 12.7.9     | DCDC_SYNCBUSY - Syncbusy Status Register                    | 344        |
| 12.7.10    | DCDC_LOCK - Lock Register                                   | 345        |
| 12.7.11    | DCDC_LOCKSTATUS - Lock Status Register                      | 345        |
| <b>13.</b> | <b>PRS - Peripheral Reflex System</b>                       | <b>346</b> |
| 13.1       | Introduction                                                | 346        |
| 13.2       | Features                                                    | 346        |
| 13.3       | Functional Description                                      | 347        |
| 13.3.1     | Asynchronous Channel Functions                              | 347        |
| 13.3.2     | Configurable Logic                                          | 348        |
| 13.3.3     | Producers                                                   | 349        |
| 13.3.4     | Consumers                                                   | 356        |
| 13.4       | PRS Register Map                                            | 357        |
| 13.5       | PRS Register Description                                    | 374        |
| 13.5.1     | PRS_IPVERSION - PRS IPVERSION                               | 374        |
| 13.5.2     | PRS_ASYNC_SWPULSE - Software Pulse Register                 | 375        |
| 13.5.3     | PRS_ASYNC_SWLEVEL - Software Level Register                 | 377        |
| 13.5.4     | PRS_ASYNC_PEEK - Async Channel Values                       | 379        |
| 13.5.5     | PRS_SYNC_PEEK - Sync Channel Values                         | 380        |
| 13.5.6     | PRS_ASYNC_CHx_CTRL - Async Channel Control Register         | 381        |
| 13.5.7     | PRS_SYNC_CHx_CTRL - Sync Channel Control Register           | 382        |
| 13.5.8     | PRS_CONSUMER_CMU_CALDN - CALDN Consumer Register            | 383        |
| 13.5.9     | PRS_CONSUMER_CMU_CALUP - CALUP Consumer Register            | 383        |
| 13.5.10    | PRS_CONSUMER_EUSART0_CLK - CLK Consumer Register            | 384        |
| 13.5.11    | PRS_CONSUMER_EUSART0_RX - RX Consumer Register              | 384        |
| 13.5.12    | PRS_CONSUMER_EUSART0_TRIGGER - TRIGGER Consumer Register    | 385        |
| 13.5.13    | PRS_CONSUMER_EUSART1_CLK - CLK Consumer Register            | 385        |
| 13.5.14    | PRS_CONSUMER_EUSART1_RX - RX Consumer Register              | 386        |
| 13.5.15    | PRS_CONSUMER_EUSART1_TRIGGER - TRIGGER Consumer Register    | 386        |
| 13.5.16    | PRS_CONSUMER_IADC0_SCANTRIGGER - SCAN Consumer Register     | 387        |
| 13.5.17    | PRS_CONSUMER_IADC0_SINGLEtrigger - SINGLE Consumer Register | 387        |
| 13.5.18    | PRS_CONSUMER_LDMAXBAR_DMAREQ0 - DMAREQ0 Consumer Register   | 388        |

|         |                                                                     |     |
|---------|---------------------------------------------------------------------|-----|
| 13.5.19 | PRS_CONSUMER_LDMAXBAR_DMAREQ1 - DMAREQ1 Consumer Register . . . . . | 388 |
| 13.5.20 | PRS_CONSUMER_LETIMERO_CLEAR - CLEAR Consumer Register . . . . .     | 389 |
| 13.5.21 | PRS_CONSUMER_LETIMERO_START - START Consumer Register . . . . .     | 389 |
| 13.5.22 | PRS_CONSUMER_LETIMERO_STOP - STOP Consumer Register . . . . .       | 390 |
| 13.5.23 | PRS_CONSUMER_MODEM_DIN - DIN Consumer Register . . . . .            | 390 |
| 13.5.24 | PRS_CONSUMER_MODEM_PAEN - PAEN Consumer Register . . . . .          | 391 |
| 13.5.25 | PRS_CONSUMER_PCNT0_S0IN - S0IN Consumer Register . . . . .          | 391 |
| 13.5.26 | PRS_CONSUMER_PCNT0_S1IN - S1IN Consumer Register . . . . .          | 392 |
| 13.5.27 | PRS_CONSUMER_RAC_CLR - CLR Consumer Register . . . . .              | 392 |
| 13.5.28 | PRS_CONSUMER_RAC_CTIIN0 - CTI Consumer Register . . . . .           | 393 |
| 13.5.29 | PRS_CONSUMER_RAC_CTIIN1 - CTI Consumer Register . . . . .           | 393 |
| 13.5.30 | PRS_CONSUMER_RAC_CTIIN2 - CTI Consumer Register . . . . .           | 394 |
| 13.5.31 | PRS_CONSUMER_RAC_CTIIN3 - CTI Consumer Register . . . . .           | 394 |
| 13.5.32 | PRS_CONSUMER_RAC_FORCETX - FORCETX Consumer Register . . . . .      | 395 |
| 13.5.33 | PRS_CONSUMER_RAC_RXDIS - RXDIS Consumer Register . . . . .          | 395 |
| 13.5.34 | PRS_CONSUMER_RAC_RXEN - RXEN Consumer Register . . . . .            | 396 |
| 13.5.35 | PRS_CONSUMER_RAC_TXEN - TXEN Consumer Register . . . . .            | 396 |
| 13.5.36 | PRS_CONSUMER_SETAMPER_TAMPERSRC25 - TAMPERSRC25 Consumer Register . | 397 |
| 13.5.37 | PRS_CONSUMER_SETAMPER_TAMPERSRC26 - TAMPERSRC26 Consumer Register . | 397 |
| 13.5.38 | PRS_CONSUMER_SETAMPER_TAMPERSRC27 - TAMPERSRC27 Consumer Register . | 398 |
| 13.5.39 | PRS_CONSUMER_SETAMPER_TAMPERSRC28 - TAMPERSRC28 Consumer Register . | 398 |
| 13.5.40 | PRS_CONSUMER_SETAMPER_TAMPERSRC29 - TAMPERSRC29 Consumer Register . | 399 |
| 13.5.41 | PRS_CONSUMER_SETAMPER_TAMPERSRC30 - TAMPERSRC30 Consumer Register . | 399 |
| 13.5.42 | PRS_CONSUMER_SETAMPER_TAMPERSRC31 - TAMPERSRC31 Consumer Register . | 400 |
| 13.5.43 | PRS_CONSUMER_SYSRTC0_IN0 - IN0 Consumer Register . . . . .          | 400 |
| 13.5.44 | PRS_CONSUMER_SYSRTC0_IN1 - IN1 Consumer Register . . . . .          | 401 |
| 13.5.45 | PRS_CONSUMER_HFX00_OSCREQ - OSCREQ Consumer Register . . . . .      | 401 |
| 13.5.46 | PRS_CONSUMER_HFX00_TIMEOUT - TIMEOUT Consumer Register . . . . .    | 402 |
| 13.5.47 | PRS_CONSUMER_CORE_CTIIN0 - CTI0 Consumer Selection . . . . .        | 402 |
| 13.5.48 | PRS_CONSUMER_CORE_CTIIN1 - CTI1 Consumer Selection . . . . .        | 403 |
| 13.5.49 | PRS_CONSUMER_CORE_CTIIN2 - CTI2 Consumer Selection . . . . .        | 403 |
| 13.5.50 | PRS_CONSUMER_CORE_CTIIN3 - CTI3 Consumer Selection . . . . .        | 404 |
| 13.5.51 | PRS_CONSUMER_CORE_M33RXEV - M33 Consumer Selection . . . . .        | 404 |
| 13.5.52 | PRS_CONSUMER_TIMER0_CC0 - CC0 Consumer Register . . . . .           | 405 |
| 13.5.53 | PRS_CONSUMER_TIMER0_CC1 - CC1 Consumer Register . . . . .           | 405 |
| 13.5.54 | PRS_CONSUMER_TIMER0_CC2 - CC2 Consumer Register . . . . .           | 406 |
| 13.5.55 | PRS_CONSUMER_TIMER0_DTI - DTI Consumer Register . . . . .           | 406 |
| 13.5.56 | PRS_CONSUMER_TIMER0_DTIFS1 - DTI Consumer Register . . . . .        | 407 |
| 13.5.57 | PRS_CONSUMER_TIMER0_DTIFS2 - DTI Consumer Register . . . . .        | 407 |
| 13.5.58 | PRS_CONSUMER_TIMER1_CC0 - CC0 Consumer Register . . . . .           | 408 |
| 13.5.59 | PRS_CONSUMER_TIMER1_CC1 - CC1 Consumer Register . . . . .           | 408 |
| 13.5.60 | PRS_CONSUMER_TIMER1_CC2 - CC2 Consumer Register . . . . .           | 409 |
| 13.5.61 | PRS_CONSUMER_TIMER1_DTI - DTI Consumer Register . . . . .           | 409 |
| 13.5.62 | PRS_CONSUMER_TIMER1_DTIFS1 - DTI Consumer Register . . . . .        | 410 |
| 13.5.63 | PRS_CONSUMER_TIMER1_DTIFS2 - DTI Consumer Register . . . . .        | 410 |
| 13.5.64 | PRS_CONSUMER_TIMER2_CC0 - CC0 Consumer Register . . . . .           | 411 |
| 13.5.65 | PRS_CONSUMER_TIMER2_CC1 - CC1 Consumer Register . . . . .           | 411 |
| 13.5.66 | PRS_CONSUMER_TIMER2_CC2 - CC2 Consumer Register . . . . .           | 412 |

|                                                                                 |     |
|---------------------------------------------------------------------------------|-----|
| 13.5.67 PRS_CONSUMER_TIMER2_DTI - DTI Consumer Register . . . . .               | 412 |
| 13.5.68 PRS_CONSUMER_TIMER2_DTIFS1 - DTI Consumer Register . . . . .            | 413 |
| 13.5.69 PRS_CONSUMER_TIMER2_DTIFS2 - DTI Consumer Register . . . . .            | 413 |
| 13.5.70 PRS_CONSUMER_TIMER3_CC0 - CC0 Consumer Register . . . . .               | 414 |
| 13.5.71 PRS_CONSUMER_TIMER3_CC1 - CC1 Consumer Register . . . . .               | 414 |
| 13.5.72 PRS_CONSUMER_TIMER3_CC2 - CC2 Consumer Register . . . . .               | 415 |
| 13.5.73 PRS_CONSUMER_TIMER3_DTI - DTI Consumer Register . . . . .               | 415 |
| 13.5.74 PRS_CONSUMER_TIMER3_DTIFS1 - DTI Consumer Register . . . . .            | 416 |
| 13.5.75 PRS_CONSUMER_TIMER3_DTIFS2 - DTI Consumer Register . . . . .            | 416 |
| 13.5.76 PRS_CONSUMER_TIMER4_CC0 - CC0 Consumer Register . . . . .               | 417 |
| 13.5.77 PRS_CONSUMER_TIMER4_CC1 - CC1 Consumer Register . . . . .               | 417 |
| 13.5.78 PRS_CONSUMER_TIMER4_CC2 - CC2 Consumer Register . . . . .               | 418 |
| 13.5.79 PRS_CONSUMER_TIMER4_DTI - DTI Consumer Register . . . . .               | 418 |
| 13.5.80 PRS_CONSUMER_TIMER4_DTIFS1 - DTI Consumer Register . . . . .            | 419 |
| 13.5.81 PRS_CONSUMER_TIMER4_DTIFS2 - DTI Consumer Register . . . . .            | 419 |
| 13.5.82 PRS_CONSUMER_USART0_CLK - CLK Consumer Register . . . . .               | 420 |
| 13.5.83 PRS_CONSUMER_USART0_IR - IR Consumer Register . . . . .                 | 420 |
| 13.5.84 PRS_CONSUMER_USART0_RX - RX Consumer Register . . . . .                 | 421 |
| 13.5.85 PRS_CONSUMER_USART0_TRIGGER - TRIGGER Consumer Register . . . . .       | 421 |
| 13.5.86 PRS_CONSUMER_VDAC0_ASYNCTRIGCH0 - ASYNCTRIG Consumer Register . . . . . | 422 |
| 13.5.87 PRS_CONSUMER_VDAC0_ASYNCTRIGCH1 - ASYNCTRIG Consumer Register . . . . . | 422 |
| 13.5.88 PRS_CONSUMER_VDAC0_SYNCTRIGCH0 - SYNCTRIG Consumer Register . . . . .   | 423 |
| 13.5.89 PRS_CONSUMER_VDAC0_SYNCTRIGCH1 - SYNCTRIG Consumer Register . . . . .   | 423 |
| 13.5.90 PRS_CONSUMER_VDAC1_ASYNCTRIGCH0 - ASYNCTRIG Consumer Register . . . . . | 424 |
| 13.5.91 PRS_CONSUMER_VDAC1_ASYNCTRIGCH1 - ASYNCTRIG Consumer Register . . . . . | 424 |
| 13.5.92 PRS_CONSUMER_VDAC1_SYNCTRIGCH0 - SYNCTRIG Consumer Register . . . . .   | 425 |
| 13.5.93 PRS_CONSUMER_VDAC1_SYNCTRIGCH1 - SYNCTRIG Consumer Register . . . . .   | 425 |
| 13.5.94 PRS_CONSUMER_WDOG0_SRC0 - SRC0 Consumer Register . . . . .              | 426 |
| 13.5.95 PRS_CONSUMER_WDOG0_SRC1 - SRC1 Consumer Register . . . . .              | 426 |
| 13.5.96 PRS_CONSUMER_WDOG1_SRC0 - SRC0 Consumer Register . . . . .              | 427 |
| 13.5.97 PRS_CONSUMER_WDOG1_SRC1 - SRC1 Consumer Register . . . . .              | 427 |

## 14. GPCRC - General Purpose Cyclic Redundancy Check . . . . .

|                                                              |     |
|--------------------------------------------------------------|-----|
| 14.1 Introduction. . . . .                                   | 428 |
| 14.2 Features . . . . .                                      | 428 |
| 14.3 Functional Description . . . . .                        | 429 |
| 14.3.1 Polynomial Specification . . . . .                    | 430 |
| 14.3.2 Input and Output Specification . . . . .              | 430 |
| 14.3.3 Initialization . . . . .                              | 430 |
| 14.3.4 DMA Usage . . . . .                                   | 430 |
| 14.3.5 Byte-Level Bit Reversal and Byte Reordering . . . . . | 431 |
| 14.4 GPCRC Register Map . . . . .                            | 434 |
| 14.5 GPCRC Register Description. . . . .                     | 435 |
| 14.5.1 GPCRC_IPVERSION - IP Version ID . . . . .             | 435 |
| 14.5.2 GPCRC_EN - CRC Enable . . . . .                       | 436 |
| 14.5.3 GPCRC_CTRL - Control Register . . . . .               | 437 |
| 14.5.4 GPCRC_CMD - Command Register . . . . .                | 438 |

|                                                                        |            |
|------------------------------------------------------------------------|------------|
| 14.5.5 GPCRC_INIT - CRC Init Value . . . . .                           | 438        |
| 14.5.6 GPCRC_POLY - CRC Polynomial Value . . . . .                     | 439        |
| 14.5.7 GPCRC_INPUTDATA - Input 32-Bit Data Register . . . . .          | 439        |
| 14.5.8 GPCRC_INPUTDATAHWORD - Input 16-Bit Data Register . . . . .     | 440        |
| 14.5.9 GPCRC_INPUTDATABYTE - Input 8-Bit Data Register . . . . .       | 440        |
| 14.5.10 GPCRC_DATA - CRC Data Register . . . . .                       | 441        |
| 14.5.11 GPCRC_DATAREV - CRC Data Reverse Register . . . . .            | 441        |
| 14.5.12 GPCRC_DATABYTEREV - CRC Data Byte Reverse Register . . . . .   | 442        |
| <b>15. SYSRTC - System RTC . . . . .</b>                               | <b>443</b> |
| 15.1 Introduction. . . . .                                             | 443        |
| 15.2 Features . . . . .                                                | 443        |
| 15.3 Functional Description . . . . .                                  | 443        |
| 15.3.1 Interrupts and Wake Events. . . . .                             | 444        |
| 15.3.2 Counter . . . . .                                               | 444        |
| 15.3.3 Compare Events . . . . .                                        | 444        |
| 15.3.4 Capture Events . . . . .                                        | 444        |
| 15.3.5 SYSRTC Behavior on SWRST/Disablement/STOP . . . . .             | 444        |
| 15.3.6 Debug Functionality . . . . .                                   | 445        |
| 15.4 SYSRTC Register Map . . . . .                                     | 446        |
| 15.5 SYSRTC Register Description . . . . .                             | 448        |
| 15.5.1 SYSRTC_IPVERSION - IP VERSION . . . . .                         | 448        |
| 15.5.2 SYSRTC_EN - Module Enable Register . . . . .                    | 448        |
| 15.5.3 SYSRTC_SWRST - Software Reset Register . . . . .                | 449        |
| 15.5.4 SYSRTC_CFG - Configuration Register . . . . .                   | 449        |
| 15.5.5 SYSRTC_CMD - Command Register . . . . .                         | 450        |
| 15.5.6 SYSRTC_STATUS - Status Register . . . . .                       | 450        |
| 15.5.7 SYSRTC_CNT - Counter Value Register . . . . .                   | 451        |
| 15.5.8 SYSRTC_SYNCBUSY - Synchronization Busy Register . . . . .       | 451        |
| 15.5.9 SYSRTC_LOCK - Configuration Lock Register . . . . .             | 452        |
| 15.5.10 SYSRTC_GRP0_IF - Group Interrupt Flags . . . . .               | 452        |
| 15.5.11 SYSRTC_GRP0_IEN - Group Interrupt Enables . . . . .            | 453        |
| 15.5.12 SYSRTC_GRP0_CTRL - Group Control Register . . . . .            | 454        |
| 15.5.13 SYSRTC_GRP0_CMP0VALUE - Compare 0 Value Register . . . . .     | 455        |
| 15.5.14 SYSRTC_GRP0_CMP1VALUE - Compare 1 Value Register . . . . .     | 455        |
| 15.5.15 SYSRTC_GRP0_CAP0VALUE - Capture 0 Value Register . . . . .     | 456        |
| 15.5.16 SYSRTC_GRP0_SYNCBUSY - Synchronization Busy Register . . . . . | 456        |
| <b>16. BURTC - Back-Up Real Time Counter . . . . .</b>                 | <b>457</b> |
| 16.1 Introduction. . . . .                                             | 457        |
| 16.2 Features . . . . .                                                | 457        |
| 16.3 Functional Description . . . . .                                  | 458        |
| 16.3.1 Clock Selection . . . . .                                       | 458        |
| 16.3.2 Configuration . . . . .                                         | 458        |
| 16.3.3 Debug Features and Description . . . . .                        | 458        |
| 16.3.4 Counter . . . . .                                               | 459        |
| 16.3.5 Compare Channel . . . . .                                       | 460        |

|                                                                      |            |
|----------------------------------------------------------------------|------------|
| 16.3.6 Interrupts . . . . .                                          | 460        |
| 16.3.7 Register Lock . . . . .                                       | 460        |
| <b>16.4 BURTC Register Map . . . . .</b>                             | <b>461</b> |
| <b>16.5 BURTC Register Description . . . . .</b>                     | <b>462</b> |
| 16.5.1 BURTC_IPVERSION - IP Version ID. . . . .                      | 462        |
| 16.5.2 BURTC_EN - Module Enable Register . . . . .                   | 463        |
| 16.5.3 BURTC_CFG - Configuration Register . . . . .                  | 464        |
| 16.5.4 BURTC_CMD - Command Register . . . . .                        | 465        |
| 16.5.5 BURTC_STATUS - Status Register . . . . .                      | 466        |
| 16.5.6 BURTC_IF - Interrupt Flag Register . . . . .                  | 466        |
| 16.5.7 BURTC_IEN - Interrupt Enable Register . . . . .               | 467        |
| 16.5.8 BURTC_PRECNT - Pre-Counter Value Register . . . . .           | 467        |
| 16.5.9 BURTC_CNT - Counter Value Register . . . . .                  | 468        |
| 16.5.10 BURTC_EM4WUEN - EM4 Wakeup Request Enable Register . . . . . | 468        |
| 16.5.11 BURTC_SYNCBUSY - Synchronization Busy Register . . . . .     | 469        |
| 16.5.12 BURTC_LOCK - Configuration Lock Register . . . . .           | 470        |
| 16.5.13 BURTC_COMP - Compare Value Register . . . . .                | 470        |
| <b>17. BURAM - Backup RAM . . . . .</b>                              | <b>471</b> |
| 17.1 Introduction. . . . .                                           | 471        |
| 17.2 Functional Description . . . . .                                | 471        |
| 17.3 BURAM Register Map . . . . .                                    | 471        |
| 17.4 BURAM Register Description. . . . .                             | 472        |
| 17.4.1 BURAM_RETx_REG - Retention Register . . . . .                 | 472        |
| <b>18. LETIMER - Low Energy Timer . . . . .</b>                      | <b>473</b> |
| 18.1 Introduction. . . . .                                           | 473        |
| 18.2 Features . . . . .                                              | 473        |
| 18.3 Functional Description . . . . .                                | 474        |
| 18.3.1 Internal Overview . . . . .                                   | 475        |
| 18.3.2 Free Running Mode . . . . .                                   | 476        |
| 18.3.3 One-shot Mode . . . . .                                       | 477        |
| 18.3.4 Buffered Mode . . . . .                                       | 478        |
| 18.3.5 Double Mode . . . . .                                         | 479        |
| 18.4 Clock Frequency . . . . .                                       | 480        |
| 18.5 PRS Input Triggers . . . . .                                    | 481        |
| 18.6 Debug . . . . .                                                 | 481        |
| 18.7 Output Action . . . . .                                         | 482        |
| 18.8 PRS Output . . . . .                                            | 482        |
| 18.9 Interrupts . . . . .                                            | 482        |
| 18.10 Using the LETIMER in EM3 . . . . .                             | 482        |
| 18.11 Register Access. . . . .                                       | 482        |
| 18.12 Programmer's Model . . . . .                                   | 483        |
| 18.12.1 Free Running Mode . . . . .                                  | 483        |

|                                                                     |            |
|---------------------------------------------------------------------|------------|
| 18.12.2 One Shot Mode . . . . .                                     | 484        |
| 18.12.3 DOUBLE Mode . . . . .                                       | 484        |
| 18.12.4 BUFFERED Mode . . . . .                                     | 485        |
| 18.12.5 Continuous Output Generation . . . . .                      | 486        |
| 18.12.6 PWM Output . . . . .                                        | 487        |
| <b>18.13 LETIMER Register Map . . . . .</b>                         | <b>488</b> |
| <b>18.14 LETIMER Register Description . . . . .</b>                 | <b>490</b> |
| 18.14.1 LETIMER_IPVERSION - IP Version . . . . .                    | 490        |
| 18.14.2 LETIMER_EN - Module En . . . . .                            | 490        |
| 18.14.3 LETIMER_SWRST - Software Reset Register . . . . .           | 491        |
| 18.14.4 LETIMER_CTRL - Control Register . . . . .                   | 492        |
| 18.14.5 LETIMER_CMD - Command Register . . . . .                    | 494        |
| 18.14.6 LETIMER_STATUS - Status Register . . . . .                  | 495        |
| 18.14.7 LETIMER_CNT - Counter Value Register . . . . .              | 495        |
| 18.14.8 LETIMER_COMP0 - Compare Value Register 0 . . . . .          | 496        |
| 18.14.9 LETIMER_COMP1 - Compare Value Register 1 . . . . .          | 496        |
| 18.14.10 LETIMER_TOP - Counter TOP Value Register . . . . .         | 497        |
| 18.14.11 LETIMER_TOPBUFF - Buffered Counter TOP Value . . . . .     | 497        |
| 18.14.12 LETIMER_REPEAT0 - Repeat Counter Register 0 . . . . .      | 498        |
| 18.14.13 LETIMER_REPEAT1 - Repeat Counter Register 1 . . . . .      | 498        |
| 18.14.14 LETIMER_IF - Interrupt Flag Register . . . . .             | 499        |
| 18.14.15 LETIMER_IEN - Interrupt Enable Register . . . . .          | 500        |
| 18.14.16 LETIMER_LOCK - Configuration Lock Register . . . . .       | 501        |
| 18.14.17 LETIMER_SYNCBUSY - Synchronization Busy Register . . . . . | 502        |
| 18.14.18 LETIMER_PRSMODE - PRS Input Mode Select Register . . . . . | 503        |
| <b>19. TIMER - Timer/Counter . . . . .</b>                          | <b>505</b> |
| 19.1 Introduction. . . . .                                          | 505        |
| 19.2 Features . . . . .                                             | 506        |
| 19.3 Functional Description . . . . .                               | 507        |
| 19.3.1 Register Access. . . . .                                     | 507        |
| 19.3.2 Counter Modes . . . . .                                      | 508        |
| 19.3.3 Compare/Capture Channels . . . . .                           | 514        |
| 19.3.4 Dead-Time Insertion Unit . . . . .                           | 525        |
| 19.3.5 Debug Mode . . . . .                                         | 529        |
| 19.3.6 Interrupts, DMA and PRS Output . . . . .                     | 529        |
| 19.3.7 GPIO Input/Output . . . . .                                  | 529        |
| 19.4 TIMER Register Map . . . . .                                   | 530        |
| 19.5 TIMER Register Description . . . . .                           | 533        |
| 19.5.1 TIMER_IPVERSION - IP Version ID . . . . .                    | 533        |
| 19.5.2 TIMER_CFG - Configuration Register . . . . .                 | 534        |
| 19.5.3 TIMER_CTRL - Control Register . . . . .                      | 537        |
| 19.5.4 TIMER_CMD - Command Register . . . . .                       | 538        |
| 19.5.5 TIMER_STATUS - Status Register . . . . .                     | 539        |
| 19.5.6 TIMER_IF - Interrupt Flag Register . . . . .                 | 542        |
| 19.5.7 TIMER_IEN - Interrupt Enable Register . . . . .              | 544        |
| 19.5.8 TIMER_TOP - Counter Top Value Register . . . . .             | 545        |

|            |                                                                                  |            |
|------------|----------------------------------------------------------------------------------|------------|
| 19.5.9     | TIMER_TOPB - Counter Top Value Buffer Register . . . . .                         | 545        |
| 19.5.10    | TIMER_CNT - Counter Value Register . . . . .                                     | 546        |
| 19.5.11    | TIMER_LOCK - TIMER Configuration Lock Register . . . . .                         | 546        |
| 19.5.12    | TIMER_EN - Module En . . . . .                                                   | 547        |
| 19.5.13    | TIMER_CCx_CFG - CC Channel Configuration Register . . . . .                      | 548        |
| 19.5.14    | TIMER_CCx_CTRL - CC Channel Control Register . . . . .                           | 550        |
| 19.5.15    | TIMER_CCx_OC - OC Channel Value Register . . . . .                               | 551        |
| 19.5.16    | TIMER_CCx_OCB - OC Channel Value Buffer Register . . . . .                       | 552        |
| 19.5.17    | TIMER_CCx_ICF - IC Channel Value Register . . . . .                              | 552        |
| 19.5.18    | TIMER_CCx_ICOF - IC Channel Value Overflow Register . . . . .                    | 552        |
| 19.5.19    | TIMER_DTCFG - DTI Configuration Register . . . . .                               | 553        |
| 19.5.20    | TIMER_DTTIMECFG - DTI Time Configuration Register . . . . .                      | 554        |
| 19.5.21    | TIMER_DTFCFG - DTI Fault Configuration Register . . . . .                        | 555        |
| 19.5.22    | TIMER_DTCTRL - DTI Control Register . . . . .                                    | 556        |
| 19.5.23    | TIMER.DTOGEN - DTI Output Generation Enable Register . . . . .                   | 557        |
| 19.5.24    | TIMER_DTFAULT - DTI Fault Register . . . . .                                     | 558        |
| 19.5.25    | TIMER_DTFAULTC - DTI Fault Clear Register . . . . .                              | 559        |
| 19.5.26    | TIMER_DTLOCK - DTI Configuration Lock Register . . . . .                         | 560        |
| <b>20.</b> | <b>USART - Universal Synchronous Asynchronous Receiver/Transmitter . . . . .</b> | <b>561</b> |
| 20.1       | Introduction . . . . .                                                           | 561        |
| 20.2       | Features . . . . .                                                               | 562        |
| 20.3       | Functional Description . . . . .                                                 | 563        |
| 20.3.1     | Modes of Operation . . . . .                                                     | 564        |
| 20.3.2     | Asynchronous Operation . . . . .                                                 | 564        |
| 20.3.3     | Synchronous Operation . . . . .                                                  | 580        |
| 20.3.4     | Hardware Flow Control . . . . .                                                  | 586        |
| 20.3.5     | Debug Halt . . . . .                                                             | 586        |
| 20.3.6     | PRS-triggered Transmissions . . . . .                                            | 586        |
| 20.3.7     | PRS RX Input . . . . .                                                           | 586        |
| 20.3.8     | PRS CLK Input . . . . .                                                          | 587        |
| 20.3.9     | DMA Support . . . . .                                                            | 587        |
| 20.3.10    | Timer . . . . .                                                                  | 588        |
| 20.3.11    | Interrupts . . . . .                                                             | 593        |
| 20.3.12    | IrDA Modulator/ Demodulator . . . . .                                            | 594        |
| 20.4       | USART Register Map . . . . .                                                     | 595        |
| 20.5       | USART Register Description . . . . .                                             | 598        |
| 20.5.1     | USART_IPVERSION - IPVERSION . . . . .                                            | 598        |
| 20.5.2     | USART_EN - USART Enable . . . . .                                                | 598        |
| 20.5.3     | USART_CTRL - Control Register . . . . .                                          | 599        |
| 20.5.4     | USART_FRAME - USART Frame Format Register . . . . .                              | 604        |
| 20.5.5     | USART_TRIGCTRL - USART Trigger Control Register . . . . .                        | 606        |
| 20.5.6     | USART_CMD - Command Register . . . . .                                           | 607        |
| 20.5.7     | USART_STATUS - USART Status Register . . . . .                                   | 609        |
| 20.5.8     | USART_CLKDIV - Clock Control Register . . . . .                                  | 610        |
| 20.5.9     | USART_RXDATABX - RX Buffer Data Extended Register . . . . .                      | 611        |
| 20.5.10    | USART_RXDATA - RX Buffer Data Register . . . . .                                 | 611        |

|                                                                               |     |
|-------------------------------------------------------------------------------|-----|
| 20.5.11 USART_RXDOUBLEX - RX Buffer Double Data Extended Register . . . . .   | 612 |
| 20.5.12 USART_RXDOUBLE - RX FIFO Double Data Register . . . . .               | 613 |
| 20.5.13 USART_RXDATAXP - RX Buffer Data Extended Peek Register . . . . .      | 613 |
| 20.5.14 USART_RXDOUBLEXP - RX Buffer Double Data Extended Peek R... . . . . . | 614 |
| 20.5.15 USART_TXDATAAX - TX Buffer Data Extended Register . . . . .           | 615 |
| 20.5.16 USART_TXDATA - TX Buffer Data Register . . . . .                      | 616 |
| 20.5.17 USART_TXDOUBLEX - TX Buffer Double Data Extended Register . . . . .   | 617 |
| 20.5.18 USART_TXDOUBLE - TX Buffer Double Data Register . . . . .             | 618 |
| 20.5.19 USART_IF - Interrupt Flag Register . . . . .                          | 619 |
| 20.5.20 USART_IEN - Interrupt Enable Register . . . . .                       | 621 |
| 20.5.21 USART_IRCTRL - IrDA Control Register . . . . .                        | 622 |
| 20.5.22 USART_I2SCTRL - I2S Control Register . . . . .                        | 623 |
| 20.5.23 USART_TIMING - Timing Register . . . . .                              | 625 |
| 20.5.24 USART_CTRLX - Control Register Extended . . . . .                     | 627 |
| 20.5.25 USART_TIMECMP0 - Timer Compare 0 . . . . .                            | 629 |
| 20.5.26 USART_TIMECMP1 - Timer Compare 1 . . . . .                            | 631 |
| 20.5.27 USART_TIMECMP2 - Timer Compare 2 . . . . .                            | 633 |

## 21. EUSART - Universal Synchronous Asynchronous Receiver/Transmitter . . . . . **635**

|                                                                 |     |
|-----------------------------------------------------------------|-----|
| 21.1 Introduction . . . . .                                     | 635 |
| 21.2 Features . . . . .                                         | 636 |
| 21.3 Functional Description . . . . .                           | 637 |
| 21.3.1 Modes of Operation . . . . .                             | 638 |
| 21.3.2 Asynchronous Operation . . . . .                         | 638 |
| 21.3.3 Synchronous Operation . . . . .                          | 659 |
| 21.3.4 Debug Halt . . . . .                                     | 662 |
| 21.3.5 PRS-triggered Transmissions . . . . .                    | 662 |
| 21.3.6 PRS RX Input . . . . .                                   | 663 |
| 21.3.7 PRS CLK Input . . . . .                                  | 663 |
| 21.3.8 DMA Support . . . . .                                    | 663 |
| 21.4 EUSART Register Map . . . . .                              | 664 |
| 21.5 EUSART Register Description . . . . .                      | 667 |
| 21.5.1 EUSART_IPVERSION - IP Version ID . . . . .               | 667 |
| 21.5.2 EUSART_EN - Enable Register . . . . .                    | 667 |
| 21.5.3 EUSART_CFG0 - Configuration 0 Register . . . . .         | 668 |
| 21.5.4 EUSART_CFG1 - Configuration 1 Register . . . . .         | 671 |
| 21.5.5 EUSART_CFG2 - Configuration 2 Register . . . . .         | 676 |
| 21.5.6 EUSART_FRAMECFG - Frame Format Register . . . . .        | 678 |
| 21.5.7 EUSART_DTXDATCFG - Default TX DATA Register . . . . .    | 679 |
| 21.5.8 EUSART_IRHFCFG - HF IrDA Mod Config Register . . . . .   | 680 |
| 21.5.9 EUSART_IRLFCFG - LF IrDA Pulse Config Register . . . . . | 681 |
| 21.5.10 EUSART_TIMINGCFG - Timing Register . . . . .            | 682 |
| 21.5.11 EUSART_STARTFRAMECFG - Start Frame Register . . . . .   | 684 |
| 21.5.12 EUSART_SIGFRAMECFG - Signal Frame Register . . . . .    | 684 |
| 21.5.13 EUSART_CLKDIV - Clock Divider Register . . . . .        | 685 |
| 21.5.14 EUSART_TRIGCTRL - Trigger Control Register . . . . .    | 685 |
| 21.5.15 EUSART_CMD - Command Register . . . . .                 | 686 |

|                                                                            |            |
|----------------------------------------------------------------------------|------------|
| 21.5.16 EUSART_RXDATA - RX Data Register . . . . .                         | 687        |
| 21.5.17 EUSART_RXDATAP - RX Data Peek Register . . . . .                   | 687        |
| 21.5.18 EUSART_TXDATA - TX Data Register . . . . .                         | 688        |
| 21.5.19 EUSART_STATUS - Status Register . . . . .                          | 689        |
| 21.5.20 EUSART_IF - Interrupt Flag Register . . . . .                      | 691        |
| 21.5.21 EUSART_IEN - Interrupt Enable Register . . . . .                   | 693        |
| 21.5.22 EUSART_SYNCBUSY - Synchronization Busy Register . . . . .          | 695        |
| 21.5.23 EUSART_DALICFG - DALI Config Register . . . . .                    | 697        |
| <b>22. I2C - Inter-Integrated Circuit Interface . . . . .</b>              | <b>700</b> |
| 22.1 Introduction . . . . .                                                | 700        |
| 22.2 Features . . . . .                                                    | 700        |
| 22.3 Functional Description . . . . .                                      | 701        |
| 22.3.1 I2C-Bus Overview . . . . .                                          | 702        |
| 22.3.2 Enable and Reset . . . . .                                          | 706        |
| 22.3.3 Pin Configuration . . . . .                                         | 706        |
| 22.3.4 Safely Disabling and Changing Follower Configuration. . . . .       | 706        |
| 22.3.5 Clock Generation . . . . .                                          | 707        |
| 22.3.6 Arbitration . . . . .                                               | 707        |
| 22.3.7 Buffers . . . . .                                                   | 707        |
| 22.3.8 Leader Operation . . . . .                                          | 710        |
| 22.3.9 Bus States . . . . .                                                | 718        |
| 22.3.10 Follower Operation . . . . .                                       | 718        |
| 22.3.11 Transfer Automation . . . . .                                      | 722        |
| 22.3.12 Using 10-bit Addresses . . . . .                                   | 723        |
| 22.3.13 Error Handling . . . . .                                           | 723        |
| 22.3.14 DMA Support . . . . .                                              | 725        |
| 22.3.15 Interrupts . . . . .                                               | 725        |
| 22.3.16 Wake-up . . . . .                                                  | 725        |
| 22.4 I2C Register Map . . . . .                                            | 726        |
| 22.5 I2C Register Description . . . . .                                    | 728        |
| 22.5.1 I2C_IPVERSION - IP VERSION Register . . . . .                       | 728        |
| 22.5.2 I2C_EN - Enable Register . . . . .                                  | 728        |
| 22.5.3 I2C_CTRL - Control Register . . . . .                               | 729        |
| 22.5.4 I2C_CMD - Command Register . . . . .                                | 733        |
| 22.5.5 I2C_STATE - State Register . . . . .                                | 734        |
| 22.5.6 I2C_STATUS - Status Register . . . . .                              | 735        |
| 22.5.7 I2C_CLKDIV - Clock Division Register . . . . .                      | 736        |
| 22.5.8 I2C_SADDR - Follower Address Register . . . . .                     | 736        |
| 22.5.9 I2C_SADDRMASK - Follower Address Mask Register . . . . .            | 737        |
| 22.5.10 I2C_RXDATA - Receive Buffer Data Register . . . . .                | 737        |
| 22.5.11 I2C_RXDOUBLE - Receive Buffer Double Data Register . . . . .       | 738        |
| 22.5.12 I2C_RXDATAP - Receive Buffer Data Peek Register . . . . .          | 738        |
| 22.5.13 I2C_RXDOUBLEP - Receive Buffer Double Data Peek Register . . . . . | 739        |
| 22.5.14 I2C_TXDATA - Transmit Buffer Data Register . . . . .               | 739        |
| 22.5.15 I2C_TXDOUBLE - Transmit Buffer Double Data Register . . . . .      | 740        |
| 22.5.16 I2C_IF - Interrupt Flag Register . . . . .                         | 741        |

|                                                           |            |
|-----------------------------------------------------------|------------|
| 22.5.17 I2C_IEN - Interrupt Enable Register               | 743        |
| <b>23. IADC - Incremental Analog to Digital Converter</b> | <b>745</b> |
| 23.1 Introduction                                         | 745        |
| 23.2 Features                                             | 746        |
| 23.3 Functional Description                               | 747        |
| 23.3.1 Register Access                                    | 748        |
| 23.3.2 Clocking                                           | 749        |
| 23.3.3 Conversion Timing                                  | 750        |
| 23.3.4 Reference Selection and Analog Gain                | 759        |
| 23.3.5 Input and Configuration Selection                  | 760        |
| 23.3.6 Gain and Offset Correction                         | 765        |
| 23.3.7 Output Data FIFOs                                  | 770        |
| 23.3.8 Window Compare                                     | 773        |
| 23.3.9 Interrupts                                         | 774        |
| 23.4 IADC Register Map                                    | 775        |
| 23.5 IADC Register Description                            | 778        |
| 23.5.1 IADC_IPVERSION - IPVERSION                         | 778        |
| 23.5.2 IADC_EN - Enable                                   | 778        |
| 23.5.3 IADC_CTRL - Control                                | 779        |
| 23.5.4 IADC_CMD - Command                                 | 781        |
| 23.5.5 IADC_TIMER - Timer                                 | 782        |
| 23.5.6 IADC_STATUS - Status                               | 783        |
| 23.5.7 IADC_MASKREQ - Mask Request                        | 784        |
| 23.5.8 IADC_STMASK - Scan Table Mask                      | 785        |
| 23.5.9 IADC_CMPTHR - Digital Window Comparator Threshold  | 785        |
| 23.5.10 IADC_IF - Interrupt Flags                         | 786        |
| 23.5.11 IADC_IEN - Interrupt Enable                       | 788        |
| 23.5.12 IADC_TRIGGER - Trigger                            | 790        |
| 23.5.13 IADC_CFGx - Configuration                         | 793        |
| 23.5.14 IADC_SCALEx - Scaling                             | 795        |
| 23.5.15 IADC_SCHEDx - Scheduling                          | 796        |
| 23.5.16 IADC_SINGLEFIFO CFG - Single FIFO Configuration   | 797        |
| 23.5.17 IADC_SINGLEFIFO DATA - Single FIFO DATA           | 798        |
| 23.5.18 IADC_SINGLEFIFO STAT - Single FIFO Status         | 799        |
| 23.5.19 IADC_SINGLEDATA - Single Data                     | 799        |
| 23.5.20 IADC_SCANFIFO CFG - Scan FIFO Configuration       | 800        |
| 23.5.21 IADC_SCANFIFO DATA - Scan FIFO Read Data          | 801        |
| 23.5.22 IADC_SCANFIFO STAT - Scan FIFO Status             | 802        |
| 23.5.23 IADC_SCANDATA - Scan Data                         | 802        |
| 23.5.24 IADC_SINGLE - Single Queue Port Selection         | 803        |
| 23.5.25 IADC_SCANx - SCAN Entry                           | 805        |
| <b>24. GPIO - General Purpose Input/Output</b>            | <b>807</b> |
| 24.1 Introduction                                         | 807        |
| 24.2 Features                                             | 808        |
| 24.3 Functional Description                               | 809        |

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| 24.3.1 Pin Configuration . . . . .                                        | .810 |
| 24.3.2 Alternate Port Control . . . . .                                   | .812 |
| 24.3.3 Slew Rate . . . . .                                                | .812 |
| 24.3.4 Input Disable . . . . .                                            | .812 |
| 24.3.5 Configuration Lock . . . . .                                       | .812 |
| 24.3.6 EM2 Functionality . . . . .                                        | .812 |
| 24.3.7 EM4 Functionality . . . . .                                        | .812 |
| 24.3.8 EM4 Wakeup . . . . .                                               | .813 |
| 24.3.9 Debug Connections . . . . .                                        | .813 |
| 24.3.10 Interrupt Generation . . . . .                                    | .814 |
| 24.3.11 Output to PRS . . . . .                                           | .815 |
| 24.3.12 Peripheral Resource Routing . . . . .                             | .815 |
| 24.4 Synchronization . . . . .                                            | .823 |
| 24.5 GPIO Register Map . . . . .                                          | .824 |
| 24.6 GPIO Register Description . . . . .                                  | .849 |
| 24.6.1 GPIO_IPVERSION - Main . . . . .                                    | .849 |
| 24.6.2 GPIO_PORTA_CTRL - Port Control . . . . .                           | .850 |
| 24.6.3 GPIO_PORTA_MODEL - Mode Low . . . . .                              | .851 |
| 24.6.4 GPIO_PORTA_MODEH - Mode High . . . . .                             | .856 |
| 24.6.5 GPIO_PORTA_DOUT - Data Out . . . . .                               | .857 |
| 24.6.6 GPIO_PORTA_DIN - Data in . . . . .                                 | .858 |
| 24.6.7 GPIO_PORTB_CTRL - Port Control . . . . .                           | .859 |
| 24.6.8 GPIO_PORTB_MODEL - Mode Low . . . . .                              | .860 |
| 24.6.9 GPIO_PORTB_DOUT - Data Out . . . . .                               | .863 |
| 24.6.10 GPIO_PORTB_DIN - Data in . . . . .                                | .864 |
| 24.6.11 GPIO_PORTC_CTRL - Port Control . . . . .                          | .865 |
| 24.6.12 GPIO_PORTC_MODEL - Mode Low . . . . .                             | .866 |
| 24.6.13 GPIO_PORTC_MODEH - Mode High . . . . .                            | .871 |
| 24.6.14 GPIO_PORTC_DOUT - Data Out . . . . .                              | .872 |
| 24.6.15 GPIO_PORTC_DIN - Data in . . . . .                                | .873 |
| 24.6.16 GPIO_PORTD_CTRL - Port Control . . . . .                          | .874 |
| 24.6.17 GPIO_PORTD_MODEL - Mode Low . . . . .                             | .875 |
| 24.6.18 GPIO_PORTD_DOUT - Data Out . . . . .                              | .878 |
| 24.6.19 GPIO_PORTD_DIN - Data in . . . . .                                | .879 |
| 24.6.20 GPIO_LOCK - Lock Register . . . . .                               | .879 |
| 24.6.21 GPIO_GPIOLOCKSTATUS - Lock Status . . . . .                       | .880 |
| 24.6.22 GPIO_ABUSALLOC - A Bus Allocation . . . . .                       | .881 |
| 24.6.23 GPIO_BBUSALLOC - B Bus Allocation . . . . .                       | .883 |
| 24.6.24 GPIO_CDBUSALLOC - CD Bus Allocation . . . . .                     | .885 |
| 24.6.25 GPIO_EXTIPSELL - External Interrupt Port Select Low . . . . .     | .887 |
| 24.6.26 GPIO_EXTIPSELH - External Interrupt Port Select High . . . . .    | .890 |
| 24.6.27 GPIO_EXTIPINSELL - External Interrupt Pin Select Low . . . . .    | .892 |
| 24.6.28 GPIO_EXTIPINSELH - External Interrupt Pin Select High . . . . .   | .895 |
| 24.6.29 GPIO_EXTIRISE - External Interrupt Rising Edge Trigger . . . . .  | .896 |
| 24.6.30 GPIO_EXTIFALL - External Interrupt Falling Edge Trigger . . . . . | .897 |
| 24.6.31 GPIO_IF - Interrupt Flag . . . . .                                | .898 |
| 24.6.32 GPIO_IEN - Interrupt Enable . . . . .                             | .900 |

|         |                                                         |           |     |
|---------|---------------------------------------------------------|-----------|-----|
| 24.6.33 | GPIO_EM4WUEN - EM4 Wakeup Enable                        | . . . . . | 902 |
| 24.6.34 | GPIO_EM4WUPOL - EM4 Wakeup Polarity                     | . . . . . | 902 |
| 24.6.35 | GPIO_DBGROUTEOPEN - Debugger Route Pin Enable           | . . . . . | 903 |
| 24.6.36 | GPIO_TRACEROUTEPEN - Trace Route Pin Enable             | . . . . . | 904 |
| 24.6.37 | GPIO_ACMP0_ROUTEEN - ACMP0 Pin Enable                   | . . . . . | 905 |
| 24.6.38 | GPIO_ACMP0_ACMPOUTROUTE - ACMPOUT Port/Pin Select       | . . . . . | 905 |
| 24.6.39 | GPIO_ACMP1_ROUTEEN - ACMP1 Pin Enable                   | . . . . . | 906 |
| 24.6.40 | GPIO_ACMP1_ACMPOUTROUTE - ACMPOUT Port/Pin Select       | . . . . . | 906 |
| 24.6.41 | GPIO_CMU_ROUTEEN - CMU Pin Enable                       | . . . . . | 907 |
| 24.6.42 | GPIO_CMU_CLKIN0ROUTE - CLKIN0 Port/Pin Select           | . . . . . | 907 |
| 24.6.43 | GPIO_CMU_CLKOUT0ROUTE - CLKOUT0 Port/Pin Select         | . . . . . | 908 |
| 24.6.44 | GPIO_CMU_CLKOUT1ROUTE - CLKOUT1 Port/Pin Select         | . . . . . | 908 |
| 24.6.45 | GPIO_CMU_CLKOUT2ROUTE - CLKOUT2 Port/Pin Select         | . . . . . | 909 |
| 24.6.46 | GPIO_EUSART0_ROUTEEN - EUSART0 Pin Enable               | . . . . . | 910 |
| 24.6.47 | GPIO_EUSART0_CSROUTE - CS Port/Pin Select               | . . . . . | 911 |
| 24.6.48 | GPIO_EUSART0_CTSROUTE - CTS Port/Pin Select             | . . . . . | 911 |
| 24.6.49 | GPIO_EUSART0_RTSROUTE - RTS Port/Pin Select             | . . . . . | 912 |
| 24.6.50 | GPIO_EUSART0_RXROUTE - RX Port/Pin Select               | . . . . . | 912 |
| 24.6.51 | GPIO_EUSART0_SCLKROUTE - SCLK Port/Pin Select           | . . . . . | 913 |
| 24.6.52 | GPIO_EUSART0_TXROUTE - TX Port/Pin Select.              | . . . . . | 913 |
| 24.6.53 | GPIO_EUSART1_ROUTEEN - EUSART1 Pin Enable               | . . . . . | 914 |
| 24.6.54 | GPIO_EUSART1_CSROUTE - CS Port/Pin Select               | . . . . . | 915 |
| 24.6.55 | GPIO_EUSART1_CTSROUTE - CTS Port/Pin Select             | . . . . . | 915 |
| 24.6.56 | GPIO_EUSART1_RTSROUTE - RTS Port/Pin Select             | . . . . . | 916 |
| 24.6.57 | GPIO_EUSART1_RXROUTE - RX Port/Pin Select               | . . . . . | 916 |
| 24.6.58 | GPIO_EUSART1_SCLKROUTE - SCLK Port/Pin Select           | . . . . . | 917 |
| 24.6.59 | GPIO_EUSART1_TXROUTE - TX Port/Pin Select.              | . . . . . | 917 |
| 24.6.60 | GPIO_FRC_ROUTEEN - FRC Pin Enable                       | . . . . . | 918 |
| 24.6.61 | GPIO_FRC_DCLKROUTE - DCLK Port/Pin Select               | . . . . . | 918 |
| 24.6.62 | GPIO_FRC_DFRAMEROUTE - DFRAIME Port/Pin Select          | . . . . . | 919 |
| 24.6.63 | GPIO_FRC_DOUTROUTE - DOUT Port/Pin Select               | . . . . . | 919 |
| 24.6.64 | GPIO_I2C0_ROUTEEN - I2C0 Pin Enable                     | . . . . . | 920 |
| 24.6.65 | GPIO_I2C0_SCLROUTE - SCL Port/Pin Select                | . . . . . | 920 |
| 24.6.66 | GPIO_I2C0_SDAROUTE - SDA Port/Pin Select                | . . . . . | 921 |
| 24.6.67 | GPIO_I2C1_ROUTEEN - I2C1 Pin Enable                     | . . . . . | 921 |
| 24.6.68 | GPIO_I2C1_SCLROUTE - SCL Port/Pin Select                | . . . . . | 922 |
| 24.6.69 | GPIO_I2C1_SDAROUTE - SDA Port/Pin Select                | . . . . . | 922 |
| 24.6.70 | GPIO_KEYSCAN_ROUTEEN - KEYSCAN Pin Enable               | . . . . . | 923 |
| 24.6.71 | GPIO_KEYSCAN_COLOUT0ROUTE - COLOUT0 Port/Pin Select     | . . . . . | 924 |
| 24.6.72 | GPIO_KEYSCAN_COLOUT1ROUTE - COLOUT1 Port/Pin Select     | . . . . . | 924 |
| 24.6.73 | GPIO_KEYSCAN_COLOUT2ROUTE - COLOUT2 Port/Pin Select     | . . . . . | 925 |
| 24.6.74 | GPIO_KEYSCAN_COLOUT3ROUTE - COLOUT3 Port/Pin Select     | . . . . . | 925 |
| 24.6.75 | GPIO_KEYSCAN_COLOUT4ROUTE - COLOUT4 Port/Pin Select     | . . . . . | 926 |
| 24.6.76 | GPIO_KEYSCAN_COLOUT5ROUTE - COLOUT5 Port/Pin Select     | . . . . . | 926 |
| 24.6.77 | GPIO_KEYSCAN_COLOUT6ROUTE - COLOUT6 Port/Pin Select     | . . . . . | 927 |
| 24.6.78 | GPIO_KEYSCAN_COLOUT7ROUTE - COLOUT7 Port/Pin Select     | . . . . . | 927 |
| 24.6.79 | GPIO_KEYSCAN_ROWSENSE0ROUTE - ROWSENSE0 Port/Pin Select | . . . . . | 928 |
| 24.6.80 | GPIO_KEYSCAN_ROWSENSE1ROUTE - ROWSENSE1 Port/Pin Select | . . . . . | 928 |

|          |                                                           |           |     |
|----------|-----------------------------------------------------------|-----------|-----|
| 24.6.81  | GPIO_KEYSCAN_ROWSENSE2ROUTE - ROWSENSE2 Port/Pin Select   | . . . . . | 929 |
| 24.6.82  | GPIO_KEYSCAN_ROWSENSE3ROUTE - ROWSENSE3 Port/Pin Select   | . . . . . | 929 |
| 24.6.83  | GPIO_KEYSCAN_ROWSENSE4ROUTE - ROWSENSE4 Port/Pin Select   | . . . . . | 930 |
| 24.6.84  | GPIO_KEYSCAN_ROWSENSE5ROUTE - ROWSENSE5 Port/Pin Select   | . . . . . | 930 |
| 24.6.85  | GPIO_LETIMER_ROUTEEN - LETIMER Pin Enable                 | . . . . . | 931 |
| 24.6.86  | GPIO_LETIMER_OUT0ROUTE - OUT0 Port/Pin Select             | . . . . . | 931 |
| 24.6.87  | GPIO_LETIMER_OUT1ROUTE - OUT1 Port/Pin Select             | . . . . . | 932 |
| 24.6.88  | GPIO_MODEM_ROUTEEN - MODEM Pin Enable                     | . . . . . | 933 |
| 24.6.89  | GPIO_MODEM_ANT0ROUTE - ANT0 Port/Pin Select               | . . . . . | 934 |
| 24.6.90  | GPIO_MODEM_ANT1ROUTE - ANT1 Port/Pin Select               | . . . . . | 935 |
| 24.6.91  | GPIO_MODEM_ANTROLLOVERROUTE - ANTROLLOVER Port/Pin Select | . . . . . | 935 |
| 24.6.92  | GPIO_MODEM_ANTRR0ROUTE - ANTRR0 Port/Pin Select           | . . . . . | 936 |
| 24.6.93  | GPIO_MODEM_ANTRR1ROUTE - ANTRR1 Port/Pin Select           | . . . . . | 936 |
| 24.6.94  | GPIO_MODEM_ANTRR2ROUTE - ANTRR2 Port/Pin Select           | . . . . . | 937 |
| 24.6.95  | GPIO_MODEM_ANTRR3ROUTE - ANTRR3 Port/Pin Select           | . . . . . | 937 |
| 24.6.96  | GPIO_MODEM_ANTRR4ROUTE - ANTRR4 Port/Pin Select           | . . . . . | 938 |
| 24.6.97  | GPIO_MODEM_ANTRR5ROUTE - ANTRR5 Port/Pin Select           | . . . . . | 938 |
| 24.6.98  | GPIO_MODEM_ANTSWENROUTE - ANTSWEN Port/Pin Select         | . . . . . | 939 |
| 24.6.99  | GPIO_MODEM_ANTSWUSROUTE - ANTSWUS Port/Pin Select         | . . . . . | 939 |
| 24.6.100 | GPIO_MODEM_ANTRIGROUTE - ANTRIG Port/Pin Select           | . . . . . | 940 |
| 24.6.101 | GPIO_MODEM_ANTRIGSTOPROUTE - ANTRIGSTOP Port/Pin Select   | . . . . . | 940 |
| 24.6.102 | GPIO_MODEM_DCLKROUTE - DCLK Port/Pin Select               | . . . . . | 941 |
| 24.6.103 | GPIO_MODEM_DINROUTE - DIN Port/Pin Select                 | . . . . . | 941 |
| 24.6.104 | GPIO_MODEM_DOUTROUTE - DOUT Port/Pin Select               | . . . . . | 942 |
| 24.6.105 | GPIO_PCNT0_S0INROUTE - S0IN Port/Pin Select               | . . . . . | 942 |
| 24.6.106 | GPIO_PCNT0_S1INROUTE - S1IN Port/Pin Select               | . . . . . | 943 |
| 24.6.107 | GPIO_PRS0_ROUTEEN - PRS0 Pin Enable                       | . . . . . | 944 |
| 24.6.108 | GPIO_PRS0_ASYNCH0ROUTE - ASYNCH0 Port/Pin Select          | . . . . . | 945 |
| 24.6.109 | GPIO_PRS0_ASYNCH1ROUTE - ASYNCH1 Port/Pin Select          | . . . . . | 946 |
| 24.6.110 | GPIO_PRS0_ASYNCH2ROUTE - ASYNCH2 Port/Pin Select          | . . . . . | 946 |
| 24.6.111 | GPIO_PRS0_ASYNCH3ROUTE - ASYNCH3 Port/Pin Select          | . . . . . | 947 |
| 24.6.112 | GPIO_PRS0_ASYNCH4ROUTE - ASYNCH4 Port/Pin Select          | . . . . . | 947 |
| 24.6.113 | GPIO_PRS0_ASYNCH5ROUTE - ASYNCH5 Port/Pin Select          | . . . . . | 948 |
| 24.6.114 | GPIO_PRS0_ASYNCH6ROUTE - ASYNCH6 Port/Pin Select          | . . . . . | 948 |
| 24.6.115 | GPIO_PRS0_ASYNCH7ROUTE - ASYNCH7 Port/Pin Select          | . . . . . | 949 |
| 24.6.116 | GPIO_PRS0_ASYNCH8ROUTE - ASYNCH8 Port/Pin Select          | . . . . . | 949 |
| 24.6.117 | GPIO_PRS0_ASYNCH9ROUTE - ASYNCH9 Port/Pin Select          | . . . . . | 950 |
| 24.6.118 | GPIO_PRS0_ASYNCH10ROUTE - ASYNCH10 Port/Pin Select        | . . . . . | 950 |
| 24.6.119 | GPIO_PRS0_ASYNCH11ROUTE - ASYNCH11 Port/Pin Select        | . . . . . | 951 |
| 24.6.120 | GPIO_PRS0_ASYNCH12ROUTE - ASYNCH12 Port/Pin Select        | . . . . . | 951 |
| 24.6.121 | GPIO_PRS0_ASYNCH13ROUTE - ASYNCH13 Port/Pin Select        | . . . . . | 952 |
| 24.6.122 | GPIO_PRS0_ASYNCH14ROUTE - ASYNCH14 Port/Pin Select        | . . . . . | 952 |
| 24.6.123 | GPIO_PRS0_ASYNCH15ROUTE - ASYNCH15 Port/Pin Select        | . . . . . | 953 |
| 24.6.124 | GPIO_PRS0_SYNCH0ROUTE - SYNCH0 Port/Pin Select            | . . . . . | 953 |
| 24.6.125 | GPIO_PRS0_SYNCH1ROUTE - SYNCH1 Port/Pin Select            | . . . . . | 954 |
| 24.6.126 | GPIO_PRS0_SYNCH2ROUTE - SYNCH2 Port/Pin Select            | . . . . . | 954 |
| 24.6.127 | GPIO_PRS0_SYNCH3ROUTE - SYNCH3 Port/Pin Select            | . . . . . | 955 |
| 24.6.128 | GPIO_RAC_ROUTEEN - RAC Pin Enable                         | . . . . . | 955 |

|            |                                                                                |            |
|------------|--------------------------------------------------------------------------------|------------|
| 24.6.129   | GPIO_RAC_LNAENROUTE - LNAEN Port/Pin Select . . . . .                          | 956        |
| 24.6.130   | GPIO_RAC_PAENROUTE - PAEN Port/Pin Select . . . . .                            | 956        |
| 24.6.131   | GPIO_SYXO0_BUFOUTREQINASYNCRROUTE - BUFOUTREQINASYNC Port/Pin Select . . . . . | 957        |
| 24.6.132   | GPIO_TIMER0_ROUTEEN - TIMER0 Pin Enable . . . . .                              | 958        |
| 24.6.133   | GPIO_TIMER0_CC0ROUTE - CC0 Port/Pin Select . . . . .                           | 959        |
| 24.6.134   | GPIO_TIMER0_CC1ROUTE - CC1 Port/Pin Select . . . . .                           | 959        |
| 24.6.135   | GPIO_TIMER0_CC2ROUTE - CC2 Port/Pin Select . . . . .                           | 960        |
| 24.6.136   | GPIO_TIMER0_CDTI0ROUTE - CDTI0 Port/Pin Select . . . . .                       | 960        |
| 24.6.137   | GPIO_TIMER0_CDTI1ROUTE - CDTI1 Port/Pin Select . . . . .                       | 961        |
| 24.6.138   | GPIO_TIMER0_CDTI2ROUTE - CDTI2 Port/Pin Select . . . . .                       | 961        |
| 24.6.139   | GPIO_TIMER1_ROUTEEN - TIMER1 Pin Enable . . . . .                              | 962        |
| 24.6.140   | GPIO_TIMER1_CC0ROUTE - CC0 Port/Pin Select . . . . .                           | 963        |
| 24.6.141   | GPIO_TIMER1_CC1ROUTE - CC1 Port/Pin Select . . . . .                           | 963        |
| 24.6.142   | GPIO_TIMER1_CC2ROUTE - CC2 Port/Pin Select . . . . .                           | 964        |
| 24.6.143   | GPIO_TIMER1_CDTI0ROUTE - CDTI0 Port/Pin Select . . . . .                       | 964        |
| 24.6.144   | GPIO_TIMER1_CDTI1ROUTE - CDTI1 Port/Pin Select . . . . .                       | 965        |
| 24.6.145   | GPIO_TIMER1_CDTI2ROUTE - CDTI2 Port/Pin Select . . . . .                       | 965        |
| 24.6.146   | GPIO_TIMER2_ROUTEEN - TIMER2 Pin Enable . . . . .                              | 966        |
| 24.6.147   | GPIO_TIMER2_CC0ROUTE - CC0 Port/Pin Select . . . . .                           | 967        |
| 24.6.148   | GPIO_TIMER2_CC1ROUTE - CC1 Port/Pin Select . . . . .                           | 967        |
| 24.6.149   | GPIO_TIMER2_CC2ROUTE - CC2 Port/Pin Select . . . . .                           | 968        |
| 24.6.150   | GPIO_TIMER2_CDTI0ROUTE - CDTI0 Port/Pin Select . . . . .                       | 968        |
| 24.6.151   | GPIO_TIMER2_CDTI1ROUTE - CDTI1 Port/Pin Select . . . . .                       | 969        |
| 24.6.152   | GPIO_TIMER2_CDTI2ROUTE - CDTI2 Port/Pin Select . . . . .                       | 969        |
| 24.6.153   | GPIO_TIMER3_ROUTEEN - TIMER3 Pin Enable . . . . .                              | 970        |
| 24.6.154   | GPIO_TIMER3_CC0ROUTE - CC0 Port/Pin Select . . . . .                           | 971        |
| 24.6.155   | GPIO_TIMER3_CC1ROUTE - CC1 Port/Pin Select . . . . .                           | 971        |
| 24.6.156   | GPIO_TIMER3_CC2ROUTE - CC2 Port/Pin Select . . . . .                           | 972        |
| 24.6.157   | GPIO_TIMER3_CDTI0ROUTE - CDTI0 Port/Pin Select . . . . .                       | 972        |
| 24.6.158   | GPIO_TIMER3_CDTI1ROUTE - CDTI1 Port/Pin Select . . . . .                       | 973        |
| 24.6.159   | GPIO_TIMER3_CDTI2ROUTE - CDTI2 Port/Pin Select . . . . .                       | 973        |
| 24.6.160   | GPIO_TIMER4_ROUTEEN - TIMER4 Pin Enable . . . . .                              | 974        |
| 24.6.161   | GPIO_TIMER4_CC0ROUTE - CC0 Port/Pin Select . . . . .                           | 975        |
| 24.6.162   | GPIO_TIMER4_CC1ROUTE - CC1 Port/Pin Select . . . . .                           | 975        |
| 24.6.163   | GPIO_TIMER4_CC2ROUTE - CC2 Port/Pin Select . . . . .                           | 976        |
| 24.6.164   | GPIO_TIMER4_CDTI0ROUTE - CDTI0 Port/Pin Select . . . . .                       | 976        |
| 24.6.165   | GPIO_TIMER4_CDTI1ROUTE - CDTI1 Port/Pin Select . . . . .                       | 977        |
| 24.6.166   | GPIO_TIMER4_CDTI2ROUTE - CDTI2 Port/Pin Select . . . . .                       | 977        |
| 24.6.167   | GPIO_USART0_ROUTEEN - USART0 Pin Enable . . . . .                              | 978        |
| 24.6.168   | GPIO_USART0_CSROUTE - CS Port/Pin Select . . . . .                             | 979        |
| 24.6.169   | GPIO_USART0_CTSROUTE - CTS Port/Pin Select. . . . .                            | 979        |
| 24.6.170   | GPIO_USART0_RTSROUTE - RTS Port/Pin Select. . . . .                            | 980        |
| 24.6.171   | GPIO_USART0_RXROUTE - RX Port/Pin Select . . . . .                             | 980        |
| 24.6.172   | GPIO_USART0_CLKROUTE - SCLK Port/Pin Select . . . . .                          | 981        |
| 24.6.173   | GPIO_USART0_TXROUTE - TX Port/Pin Select . . . . .                             | 981        |
| <b>25.</b> | <b>LDMA - Linked DMA . . . . .</b>                                             | <b>982</b> |
| 25.1       | Introduction. . . . .                                                          | 982        |

|                                                                          |       |
|--------------------------------------------------------------------------|-------|
| 25.1.1 Features . . . . .                                                | .983  |
| 25.2 Block Diagram. . . . .                                              | 984   |
| 25.3 Functional Description . . . . .                                    | 985   |
| 25.3.1 Channel Descriptor . . . . .                                      | 985   |
| 25.3.2 Channel Configuration . . . . .                                   | 990   |
| 25.3.3 Channel Select Configuration . . . . .                            | 990   |
| 25.3.4 Starting a Transfer . . . . .                                     | 990   |
| 25.3.5 Managing Transfer Errors . . . . .                                | 991   |
| 25.3.6 Arbitration . . . . .                                             | 991   |
| 25.3.7 Channel Descriptor Data Structure . . . . .                       | 993   |
| 25.3.8 Interaction with the EMU . . . . .                                | 996   |
| 25.3.9 Interrupts . . . . .                                              | 997   |
| 25.3.10 Debugging . . . . .                                              | 997   |
| 25.4 Examples . . . . .                                                  | .997  |
| 25.4.1 Single Direct Register DMA Transfer . . . . .                     | 997   |
| 25.4.2 Descriptor Linked List . . . . .                                  | 998   |
| 25.4.3 Single Descriptor Looped Transfer . . . . .                       | 1000  |
| 25.4.4 Descriptor List with Looping . . . . .                            | 1001  |
| 25.4.5 Simple Inter-Channel Synchronization . . . . .                    | 1002  |
| 25.4.6 2D Copy . . . . .                                                 | 1004  |
| 25.4.7 Ping-Pong . . . . .                                               | 1006  |
| 25.4.8 Scatter-Gather . . . . .                                          | 1007  |
| 25.5 LDMA Source Selection Details . . . . .                             | .1007 |
| 25.5.1 LDMA Source Selection Details . . . . .                           | 1008  |
| 25.6 LDMA Register Map . . . . .                                         | .1010 |
| 25.7 LDMA Register Description . . . . .                                 | .1013 |
| 25.7.1 LDMA_IPVERSION - IP Version . . . . .                             | 1013  |
| 25.7.2 LDMA_EN - DMA Module Enable Disable Register . . . . .            | 1013  |
| 25.7.3 LDMA_CTRL - DMA Control Register . . . . .                        | 1014  |
| 25.7.4 LDMA_STATUS - DMA Status Register . . . . .                       | 1015  |
| 25.7.5 LDMA_SYNCSWSET - DMA Sync Trig Sw Set Register . . . . .          | 1016  |
| 25.7.6 LDMA_SYNCSWCLR - DMA Sync Trig Sw Clear Register . . . . .        | 1016  |
| 25.7.7 LDMA_SYNCHWEN - DMA Sync HW Trigger Enable Register . . . . .     | 1017  |
| 25.7.8 LDMA_SYNCHWSEL - DMA Sync HW Trigger Selection Register . . . . . | 1018  |
| 25.7.9 LDMA_SYNCSTATUS - DMA Sync Trigger Status Register . . . . .      | 1019  |
| 25.7.10 LDMA_CHEN - DMA Channel Enable Register . . . . .                | 1019  |
| 25.7.11 LDMA_CHDIS - DMA Channel Disable Register . . . . .              | 1020  |
| 25.7.12 LDMA_CHSTATUS - DMA Channel Status Register . . . . .            | 1020  |
| 25.7.13 LDMA_CHBUSY - DMA Channel Busy Register . . . . .                | 1021  |
| 25.7.14 LDMA_CHDONE - DMA Channel Linking Done Register . . . . .        | 1022  |
| 25.7.15 LDMA_DBGHALT - DMA Channel Debug Halt Register . . . . .         | 1023  |
| 25.7.16 LDMA_SWREQ - DMA Channel Software Transfer Request . . . . .     | 1023  |
| 25.7.17 LDMA_REQDIS - DMA Channel Request Disable Register . . . . .     | 1024  |
| 25.7.18 LDMA_REQPEND - DMA Channel Requests Pending Register . . . . .   | 1024  |
| 25.7.19 LDMA_LINKLOAD - DMA Channel Link Load Register . . . . .         | 1025  |
| 25.7.20 LDMA_REQCLEAR - DMA Channel Request Clear Register . . . . .     | 1025  |
| 25.7.21 LDMA_IF - Interrupt Flag Register . . . . .                      | 1026  |

|                                                                                 |             |
|---------------------------------------------------------------------------------|-------------|
| 25.7.22 LDMA_IEN - Interrupt Enable Register . . . . .                          | 1027        |
| 25.7.23 LDMA_CHx_CFG - Channel Configuration Register . . . . .                 | 1028        |
| 25.7.24 LDMA_CHx_LOOP - Channel Loop Counter Register . . . . .                 | 1029        |
| 25.7.25 LDMA_CHx_CTRL - Channel Descriptor Control Word Register . . . . .      | 1030        |
| 25.7.26 LDMA_CHx_SRC - Channel Descriptor Source Address . . . . .              | 1033        |
| 25.7.27 LDMA_CHx_DST - Channel Descriptor Destination Address . . . . .         | 1033        |
| 25.7.28 LDMA_CHx_LINK - Channel Descriptor Link Address . . . . .               | 1034        |
| 25.8 LDMAXBAR Register Map . . . . .                                            | 1034        |
| 25.9 LDMAXBAR Register Description . . . . .                                    | 1035        |
| 25.9.1 LDMAXBAR_IPVERSION - IP Version ID . . . . .                             | 1035        |
| 25.9.2 LDMAXBAR_CHx_REQSEL - Channel Peripheral Request Select Reg... . . . . . | 1035        |
| <b>26. WDOG - Watch Dog Timer . . . . .</b>                                     | <b>1036</b> |
| 26.1 Introduction . . . . .                                                     | 1036        |
| 26.2 Features . . . . .                                                         | 1036        |
| 26.3 Functional Description . . . . .                                           | 1037        |
| 26.3.1 Clock Source . . . . .                                                   | 1037        |
| 26.3.2 Debug Functionality . . . . .                                            | 1037        |
| 26.3.3 Energy Mode Handling . . . . .                                           | 1037        |
| 26.3.4 Warning Interrupt . . . . .                                              | 1037        |
| 26.3.5 Window Interrupt . . . . .                                               | 1038        |
| 26.3.6 PRS as Watchdog Clear . . . . .                                          | 1039        |
| 26.3.7 PRS Rising Edge Monitoring . . . . .                                     | 1039        |
| 26.4 WDOG Register Map . . . . .                                                | 1040        |
| 26.5 WDOG Register Description . . . . .                                        | 1041        |
| 26.5.1 WDOG_IPVERSION - IP Version Register . . . . .                           | 1041        |
| 26.5.2 WDOG_EN - Enable Register . . . . .                                      | 1041        |
| 26.5.3 WDOG_CFG - Configuration Register . . . . .                              | 1042        |
| 26.5.4 WDOG_CMD - Command Register . . . . .                                    | 1045        |
| 26.5.5 WDOG_STATUS - Status Register . . . . .                                  | 1045        |
| 26.5.6 WDOG_IF - Interrupt Flag Register . . . . .                              | 1046        |
| 26.5.7 WDOG_IEN - Interrupt Enable Register . . . . .                           | 1047        |
| 26.5.8 WDOG_LOCK - Lock Register . . . . .                                      | 1048        |
| 26.5.9 WDOG_SYNCBUSY - Synchronization Busy Register . . . . .                  | 1048        |
| <b>27. PCNT - Pulse Counter . . . . .</b>                                       | <b>1049</b> |
| 27.1 Introduction . . . . .                                                     | 1049        |
| 27.2 Features . . . . .                                                         | 1049        |
| 27.3 Functional Description . . . . .                                           | 1050        |
| 27.3.1 Pulse Counter Modes . . . . .                                            | 1050        |
| 27.3.2 Hysteresis . . . . .                                                     | 1057        |
| 27.3.3 Auxiliary Counter . . . . .                                              | 1058        |
| 27.3.4 Register Access. . . . .                                                 | 1058        |
| 27.3.5 Clock Sources . . . . .                                                  | 1058        |
| 27.3.6 Input Filter . . . . .                                                   | 1059        |
| 27.3.7 Edge Polarity . . . . .                                                  | 1059        |

|                                                                  |             |
|------------------------------------------------------------------|-------------|
| 27.3.8 PRS and PCNTn_S0IN,PCNTn_S1IN Inputs . . . . .            | 1059        |
| 27.3.9 Interrupts . . . . .                                      | 1059        |
| <b>27.4 PCNT Register Map . . . . .</b>                          | <b>1061</b> |
| <b>27.5 PCNT Register Description . . . . .</b>                  | <b>1063</b> |
| 27.5.1 PCNT_IPVERSION - IP Version ID . . . . .                  | 1063        |
| 27.5.2 PCNT_EN - Module Enable Register . . . . .                | 1063        |
| 27.5.3 PCNT_SWRST - Software Reset Register . . . . .            | 1064        |
| 27.5.4 PCNT_CFG - Configuration Register . . . . .               | 1065        |
| 27.5.5 PCNT_CTRL - Control Register . . . . .                    | 1067        |
| 27.5.6 PCNT_CMD - Command Register . . . . .                     | 1069        |
| 27.5.7 PCNT_STATUS - Status Register . . . . .                   | 1070        |
| 27.5.8 PCNT_IF - Interrupt Flag Register . . . . .               | 1071        |
| 27.5.9 PCNT_IEN - Interrupt Enable Register . . . . .            | 1072        |
| 27.5.10 PCNT_CNT - Counter Value Register . . . . .              | 1072        |
| 27.5.11 PCNT_AUXCNT - Auxiliary Counter Value Register . . . . . | 1073        |
| 27.5.12 PCNT_TOP - Top Value Register . . . . .                  | 1073        |
| 27.5.13 PCNT_TOPB - Counter Top Value Buffer Register . . . . .  | 1074        |
| 27.5.14 PCNT_OVSCTRL - Oversampling Control Register . . . . .   | 1074        |
| 27.5.15 PCNT_SYNCBUSY - Synchronization Busy Register . . . . .  | 1075        |
| 27.5.16 PCNT_LOCK - Configuration Lock Register . . . . .        | 1076        |
| <b>28. VDAC - Digital to Analog Converter . . . . .</b>          | <b>1077</b> |
| 28.1 Introduction . . . . .                                      | 1077        |
| 28.2 Features . . . . .                                          | 1078        |
| 28.3 Functional Description . . . . .                            | 1079        |
| 28.3.1 Power Supply . . . . .                                    | 1079        |
| 28.3.2 I/O Pin Considerations . . . . .                          | 1079        |
| 28.3.3 Enabling and Disabling a Channel . . . . .                | 1080        |
| 28.3.4 Clock Selection . . . . .                                 | 1081        |
| 28.3.5 Conversions . . . . .                                     | 1082        |
| 28.3.6 Conversion Trigger . . . . .                              | 1083        |
| 28.3.7 Refresh Trigger . . . . .                                 | 1083        |
| 28.3.8 PRS Communication . . . . .                               | 1083        |
| 28.3.9 Reference Selection . . . . .                             | 1084        |
| 28.3.10 Power Modes . . . . .                                    | 1084        |
| 28.3.11 Warmup Time and Initial Conversion . . . . .             | 1084        |
| 28.3.12 Output Mode . . . . .                                    | 1085        |
| 28.3.13 Internal Timers . . . . .                                | 1085        |
| 28.3.14 FIFO . . . . .                                           | 1086        |
| 28.3.15 Keepwarm Sub-modes . . . . .                             | 1086        |
| 28.3.16 LDMA Interface . . . . .                                 | 1086        |
| 28.3.17 Sine Generation Mode . . . . .                           | 1087        |
| 28.3.18 Interrupts and Wakeup . . . . .                          | 1088        |
| 28.3.19 VDAC Output Configuration . . . . .                      | 1089        |
| 28.4 VDAC Register Map . . . . .                                 | 1090        |
| 28.5 VDAC Register Description . . . . .                         | 1091        |
| 28.5.1 VDAC_IPVERSION - IPVERSION . . . . .                      | 1091        |

|            |                                                            |             |
|------------|------------------------------------------------------------|-------------|
| 28.5.2     | VDAC_EN - Module Enable . . . . .                          | 1092        |
| 28.5.3     | VDAC_SWRST - Software Reset Register . . . . .             | 1092        |
| 28.5.4     | VDAC_CFG - Config Register . . . . .                       | 1093        |
| 28.5.5     | VDAC_STATUS - Status Register . . . . .                    | 1096        |
| 28.5.6     | VDAC_CH0CFG - Channel 0 Config Register . . . . .          | 1098        |
| 28.5.7     | VDAC_CH1CFG - Channel 1 Config Register . . . . .          | 1100        |
| 28.5.8     | VDAC_CMD - Command Register . . . . .                      | 1102        |
| 28.5.9     | VDAC_IF - Interrupt Flag Register . . . . .                | 1103        |
| 28.5.10    | VDAC_IEN - Interrupt Enable Register . . . . .             | 1105        |
| 28.5.11    | VDAC_CH0F - Channel 0 Data Write Fifo . . . . .            | 1106        |
| 28.5.12    | VDAC_CH1F - Channel 1 Data Write Fifo . . . . .            | 1106        |
| 28.5.13    | VDAC_OUTCTRL - DAC Output Control . . . . .                | 1107        |
| 28.5.14    | VDAC_OUTTIMERCFG - DAC Out Timer Config Register . . . . . | 1108        |
| <b>29.</b> | <b>ACMP - Analog Comparator . . . . .</b>                  | <b>1109</b> |
| 29.1       | Introduction . . . . .                                     | 1109        |
| 29.2       | Features . . . . .                                         | 1109        |
| 29.3       | Functional Description . . . . .                           | 1110        |
| 29.3.1     | Configuration and Control . . . . .                        | 1111        |
| 29.3.2     | Warmup Time . . . . .                                      | 1111        |
| 29.3.3     | Response Time . . . . .                                    | 1111        |
| 29.3.4     | Hysteresis . . . . .                                       | 1112        |
| 29.3.5     | Supply Voltage Monitoring (VSENSE) . . . . .               | 1112        |
| 29.3.6     | VREFDIV Sources . . . . .                                  | 1112        |
| 29.3.7     | Input Range and Accuracy Settings . . . . .                | 1112        |
| 29.3.8     | Interrupts and PRS Output . . . . .                        | 1113        |
| 29.3.9     | Output to GPIO . . . . .                                   | 1113        |
| 29.4       | ACMP Register Map . . . . .                                | 1114        |
| 29.5       | ACMP Register Description . . . . .                        | 1115        |
| 29.5.1     | ACMP_IPVERSION - IP Version ID . . . . .                   | 1115        |
| 29.5.2     | ACMP_EN - ACMP Enable . . . . .                            | 1116        |
| 29.5.3     | ACMP_SWRST - Software Reset . . . . .                      | 1116        |
| 29.5.4     | ACMP_CFG - Configuration Register . . . . .                | 1117        |
| 29.5.5     | ACMP_CTRL - Control Register . . . . .                     | 1118        |
| 29.5.6     | ACMP_INPUTCTRL - Input Control Register . . . . .          | 1119        |
| 29.5.7     | ACMP_STATUS - Status Register . . . . .                    | 1124        |
| 29.5.8     | ACMP_IF - Interrupt Flag Register . . . . .                | 1125        |
| 29.5.9     | ACMP_IEN - Interrupt Enable Register . . . . .             | 1126        |
| 29.5.10    | ACMP_SYNCBUSY - Syncbusy . . . . .                         | 1126        |
| <b>30.</b> | <b>KEYSCAN - Keyboard Scan . . . . .</b>                   | <b>1127</b> |
| 30.1       | Introduction. . . . .                                      | 1127        |
| 30.2       | Features . . . . .                                         | 1127        |
| 30.3       | Functional Description . . . . .                           | 1128        |
| 30.3.1     | Row and Column Configuration . . . . .                     | 1128        |
| 30.3.2     | Clocking and Timing . . . . .                              | 1128        |
| 30.3.3     | Scanning . . . . .                                         | 1129        |

|                                                         |             |
|---------------------------------------------------------|-------------|
| 30.3.4 Wake on Key . . . . .                            | 1130        |
| <b>30.4 KEYS defense Register Map . . . . .</b>         | <b>1131</b> |
| <b>30.5 KEYS defense Register Description . . . . .</b> | <b>1132</b> |
| 30.5.1 KEYS_IPVERSION - IPVERSION . . . . .             | 1132        |
| 30.5.2 KEYS_EN - Enable . . . . .                       | 1132        |
| 30.5.3 KEYS_SWRST - Software Reset . . . . .            | 1133        |
| 30.5.4 KEYS_CFG - Config . . . . .                      | 1134        |
| 30.5.5 KEYS_CMD - Command . . . . .                     | 1135        |
| 30.5.6 KEYS_DELAY - Delay . . . . .                     | 1136        |
| 30.5.7 KEYS_STATUS - Status . . . . .                   | 1138        |
| 30.5.8 KEYS_IF - Interrupt Flags . . . . .              | 1139        |
| 30.5.9 KEYS_IEN - Interrupt Enables . . . . .           | 1140        |
| <b>31. MVP - Matrix Vector Processor . . . . .</b>      | <b>1141</b> |
| 31.1 Introduction . . . . .                             | 1141        |
| 31.2 Features . . . . .                                 | 1142        |
| 31.3 Functional Description . . . . .                   | 1144        |
| <b>32. Revision History . . . . .</b>                   | <b>1145</b> |
| <b>Appendix 1. Abbreviations . . . . .</b>              | <b>1149</b> |

## 1. About This Document

### 1.1 Introduction

This document contains reference material for the EFR32xG24 devices. All modules and peripherals in the EFR32xG24 devices are described in general terms. Not all modules are present in all devices and the feature set for each device might vary. Such differences, including pinout, are covered in the device data sheets.

## 1.2 Conventions

### Register Names

Register names are given with a module name prefix followed by the short register name:

TIMERn\_CTRL - Control Register

The "n" denotes the module number for modules which can exist in more than one instance.

Some registers are grouped which leads to a group name following the module prefix:

GPIO\_Px\_DOUT - Port Data Out Register

The "x" denotes the different ports.

### Bit Fields

Registers contain one or more bit fields which can be 1 to 32 bits wide. Bit fields wider than 1 bit are given with start (x) and stop (y) bit [y:x].

Bit fields containing more than one bit are unsigned integers unless otherwise is specified.

Unspecified bit field settings must not be used, as this may lead to unpredictable behaviour.

### Address

The address for each register can be found by adding the base address of the module found in the Memory Map (see [Figure 4.1 System Address Space with Core and Code Space Listing on page 42](#)), and the offset address for the register (found in module Register Map).

### Access Type

The register access types used in the register descriptions are explained in [Table 1.1 Register Access Types on page 28](#).

**Table 1.1. Register Access Types**

| Access Type           | Description                                                                                                                                                    |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R                     | Read only. Writes are ignored                                                                                                                                  |
| RW                    | Readable and writable                                                                                                                                          |
| RW1                   | Readable and writable. Only writes to 1 have effect                                                                                                            |
| W1                    | Read value undefined. Only writes to 1 have effect                                                                                                             |
| W                     | Write only. Read value undefined.                                                                                                                              |
| RWH                   | Readable, writable, and updated by hardware                                                                                                                    |
| RW(nB), RWH(nB), etc. | "(nB)" suffix indicates that a bitfield explicitly does not support peripheral bit set/clear/toggle operations (see <a href="#">4. Memory and Bus System</a> ) |
| RW(r), R(r), etc.     | "(r)" suffix indicates that reading the register causes an action and may alter the register value.                                                            |

### Number format

**0x** prefix is used for hexadecimal numbers

**0b** prefix is used for binary numbers

Numbers without prefix are in decimal representation.

### Reserved

Registers and bit fields marked with **reserved** are reserved for future use. These should be written to their reset value unless otherwise stated in the Register Description. Read values for reserved bits may be different in future or prior devices.

### Reset Value

---

The reset value denotes the value after reset.

Registers denoted with X have unknown value out of reset and need to be initialized before use. Note that read-modify-write operations on these registers before they are initialized results in undefined register values.

### Pin Connections

Pin connections are given with a module prefix followed by a short pin name:

CMU\_CLKOUT1 (Clock management unit, clock output pin number 1)

The location for the pin names given in the module documentation can be found in the device-specific datasheet.

### 1.3 Related Documentation

Further documentation on the EFR32xG24 devices and the ARM Cortex®-M33 can be found at the Silicon Labs and ARM web pages:

[www.silabs.com](http://www.silabs.com)

[www.arm.com](http://www.arm.com)

## 2. System Overview



### Quick Facts

#### What?

The EFR32 Wireless Gecko is a highly integrated, configurable and low power wireless System-on-Chip (SoC) with a robust set of MCU and radio peripherals.

#### Why?

The Radio enables support for Bluetooth, Proprietary, and ZigBee protocols in 2.4 GHz frequency bands while the MCU system allows customized protocols and applications to run efficiently.

#### How?

Dynamic or fixed packet lengths, optional address recognition, and flexible CRC and security schemes makes the EFR32xG24 ideal for many wireless IoT applications. High performance analog and digital peripherals allow complete applications to run on the EFR32xG24 SoC.

## 2.1 Introduction

The high level features of EFR32xG24 include:

- High performance radio transceiver
  - Low power consumption in transmit, receive, and standby modes
  - Excellent receiver performance, including sensitivity, selectivity, and blocking
  - Excellent transmitter performance, including programmable output power, low phase noise, and power-amplifier (PA) ramping
- Configurable protocol support, including standards and customer-developed protocols
  - Preamble and frame synchronization insertion in transmit, and recovery in receive
  - Flexible CRC support, including configurable polynomial and multiple CRCs for single data frames
  - Basic address filtering performed in hardware
- High performance, low power MCU system
  - High Performance 32-bit ARM Cortex®-M33 CPU
  - Flexible and efficient energy management
  - Complete set of digital peripherals
  - Peripheral Reflex System (PRS)
  - Precision analog peripherals
- Low external component count
  - Fully integrated 2.4 GHz BALUN
  - Integrated tunable crystal loading capacitors
- Security
  - Secure Boot with Root of Trust and Secure Loader (RTSL)
  - Hardware Cryptographic Acceleration with DPA countermeasures for AES128/256, SHA-1, SHA-2 (up to 256-bit), ECC (up to 256-bit), ECDSA, ECDH and J-Pake
  - True Random Number Generator (TRNG) compliant with NIST SP800-90 and AIS-31
  - ARM® TrustZone®
  - Secure Debug with lock/unlock

A further introduction to the MCU and radio system is included in the following sections.

**Note:** Detailed performance numbers, current consumption, pinout etc. are available in the device datasheets.

## 2.2 Block Diagrams

The block diagram for the EFR32xG24 System-On-Chip series is shown in (Figure 2.1 EFR32xG24 System-On-Chip Block Diagram on page 32).



Figure 2.1. EFR32xG24 System-On-Chip Block Diagram

## 2.3 MCU Features overview

- **ARM Cortex®-M33 CPU platform**
  - High Performance 32-bit processor @ up to 78.0 MHz
  - DSP instruction support and floating-point unit
  - Memory Protection Unit
  - Wake-up Interrupt Controller
- **Flexible Energy Management System**
  - Five Energy Modes from EM0 to EM4 provide flexibility between higher performance and low power
  - Power routing configurations including DCDC control
  - Voltage Monitoring and Brown Out Detection
  - Automatic voltage scaling for additional energy savings
  - State Retention
- **Up to 1536 kB Flash**
- **Up to 256 kB RAM**
- **Up to 32 General Purpose I/O pins**
  - Configurable push-pull, open-drain, pull-up/down, input filter, slew rate
  - Configurable peripheral I/O locations
  - 16 asynchronous external interrupts
  - Output state retention and wake-up from Shutoff Mode
- **8 Channel DMA Controller**
  - Alternate/primary descriptors with scatter-gather/ping-pong operation
- **20 Channel Peripheral Reflex System (PRS)**
  - Autonomous inter-peripheral signaling enables smart operation in low energy modes
  - 16 asynchronous channels with configurable logic functionality
  - 4 synchronous channels for high-speed signalling between TIMER, IADC, and VDAC
- **General Purpose Cyclic Redundancy Check (GPCRC)**
  - Programmable 16-bit polynomial, fixed 32-bit polynomial
  - The GPCRC module is in addition to the radio CRC
- **Communication interfaces**
  - 1 × Universal Synchronous/Asynchronous Receiver/Transmitter (USART)
    - UART/SPI/SmartCard (ISO 7816)/IrDA/I2S
    - Triple buffered full/half-duplex operation
    - Hardware flow control
    - 4-16 data bits
  - 2 × Enhanced Universal Asynchronous Receiver/Transmitter (EUSART)
    - UART/SPI/IrDA/DALI support
    - High-speed operation in EM0/1 using high-frequency clock source
    - Low-energy operation in EM2 using 32.768 kHz clock source
    - Buffered full/half-duplex operation
    - Hardware flow control
    - 7/8/9 data bits
  - 2 × I<sup>2</sup>C Interface (I2C) with SMBus support
    - Address recognition in EM3 Stop Mode
- **Timers/Counters**
  - 2 × 32-bit and 3 × 16-bit Timer/Counters (TIMER)
    - 3 Compare/Capture/PWM channels
    - Dead-Time Insertion
  - 24-bit Low Energy Timer (LETIMER)
  - 32-bit Real-Time Capture Counter (SYSRTC)
  - 32-bit Ultra Low Energy Backup Real Time Counter (BURTC) for periodic wake-up from any Energy Mode
  - 2 × Watchdog Timer (WDOG)

- **Ultra low power precision analog peripherals**

- Incremental Analog to Digital Converter (IADC) with 12-bit resolution at 1 Msps and 16-bit resolution at 76.9 ksps
  - Single ended or differential operation
  - Conversion tailgating for predictable latency
- 2 × Analog Comparator (ACMP)
  - Programmable speed/current
- 2 × 12-bit 500 ksps Digital to Analog Converter (VDAC)
  - 2 single ended channels/1 differential channel each
- Analog Bus (ABUS) signal routing
- Accurate die temperature sensor
- External thermistor interface

- **Low-energy keypad scanner**

- Up to 6 × 8 key switches supported
- Autonomous keypad scanning in EM0 / EM1
- Wake on key press from EM2 / EM3

- **Ultra efficient Power-on Reset (POR) and Brown-Out Detector (BOD)**

- **Debug Interface**

- 4-pin Joint Test Action Group (JTAG) interface
- 2-pin serial-wire debug (SWD) interface

- **Security**

- Secure Boot with Root of Trust and Secure Loader (RTSL)
  - Prevents malware injection and rollback
  - Ensures authentic firmware execution and OTA updates
- Dedicated Secure Core
  - Delivers faster, more energy efficient hardware crypto with Differential Power Analysis (DPA) countermeasures for AES128/256, SHA-1, SHA-2 (up to 256-bit), ECC (up to 256-bit), ECDSA, ECDH and J-Pake
  - Provides isolation with the application core
  - Provides hardware cryptographic acceleration
  - True Random Number Generator (TRNG) compliant with NIST SP800-90 and AIS-31
- ARM® TrustZone®
- Secure Debug with lock/unlock
  - Allows authenticated access for enhanced Failure Analysis (FA)

### 3. System Processor



| Quick Facts  |                                                                                                                                                                                                                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b> | The EFR32xG24 features the industry leading Cortex®-M33 CPU from ARM.                                                                                                                                                                                                                                  |
| <b>Why?</b>  | The ARM Cortex®-M33 is designed for exceptionally short response time, high code density, and high 32-bit throughput while maintaining a strict cost and power consumption budget.                                                                                                                     |
| <b>How?</b>  | Combined with the ultra low energy peripherals available in EFR32xG24 devices, the Cortex®-M33 processor's Harvard architecture, 3 stage pipeline, single cycle instructions, Thumb-2 instruction set support, and fast interrupt handling make it perfect for 8-bit, 16-bit, and 32-bit applications. |

#### 3.1 Introduction

The ARM Cortex®-M33 32-bit RISC processor provides outstanding computational performance and exceptional system response to interrupts while meeting low cost requirements and low power consumption.

The ARM Cortex®-M33 implemented is revision r0p4.

### 3.2 Features

- Harvard architecture
  - Separate data and program memory buses (No memory bottleneck as in a single bus system)
- 3-stage pipeline
- Thumb-2 instruction set
  - Enhanced levels of performance, energy efficiency, and code density
- Single cycle multiply and hardware divide instructions
  - 32-bit multiplication in a single cycle
  - Signed and unsigned divide operations between 2 and 11 cycles
- 1.5 DMIPS/MHz
- TrustZone
  - Independent Secure and Privileged states
  - Accelerated context switching
- 16 Region MPU
- 24-bit System Tick Timer for Real Time OS
- Excellent 32-bit migration choice for 8/16 bit architecture based designs
  - Simplified stack-based programmer's model is compatible with traditional ARM architecture and retains the programming simplicity of legacy 8-bit and 16-bit architectures
- Aligned or unaligned data storage and access
  - Contiguous storage of data requiring different byte lengths
  - Data access in a single core access cycle
- Integrated power modes
  - Sleep Now mode for immediate transfer to low power state
  - Sleep on Exit mode for entry into low power state after the servicing of an interrupt
  - Ability to extend power savings to other system components
- Optimized for low latency, nested interrupts

### 3.3 Functional Description

For a full functional description of the ARM Cortex®-M33 implementation in the EFR32xG24 family, the reader is referred to the ARM Cortex®-M33 documentation.

### 3.3.1 Interrupt Operation



**Figure 3.1. Interrupt Operation**

The interrupt request (IRQ) lines are connected to the Cortex®-M33. Each of these lines (shown in [3.3.3 Interrupt Request Lines \(IRQ\)](#)) is connected to one or more interrupt flags in one or more modules. The interrupt flags are set by hardware on an interrupt condition. It is also possible to set/clear the interrupt flags through the IF register interface. When setting or clearing an interrupt through the IF register use of the IF\_SET or IF\_CLR bit operation registers is required; directly writing the main interrupt flag register will have no effect.

Each interrupt flag is then qualified with its own interrupt enable bit (IEN register), before being OR'ed with the other interrupt flags to generate the IRQ. A high IRQ line will set the corresponding pending bit (can also be set/cleared with the SETPEND/CLRPEND bits in ISPRn/ICPRn) in the Cortex®-M33 NVIC. The pending bit is then qualified with an enable bit (set/cleared with SETENA/CLRENA bits in ISERn/ICERN) before generating an interrupt request to the core. [Figure 3.1 Interrupt Operation on page 37](#) illustrates the interrupt system. For more information on how the interrupts are handled inside the Cortex®-M33, the reader is referred to the [ARM Cortex®-M33 Processor Technical Reference Manual](#).

#### 3.3.1.1 Avoiding Extraneous Interrupts

There can be latencies in the system such that clearing an interrupt flag could take longer than leaving an Interrupt Service Routine (ISR). This can lead to the ISR being re-entered as the interrupt flag has yet to clear immediately after leaving the ISR. To avoid this, when clearing an interrupt flag at the end of an ISR, the user should execute ARM's Data Synchronization Barrier (DSB) instruction. Another approach is to clear the interrupt flag immediately after identifying the interrupt source and then service the interrupt as shown in the pseudo-code below. The ISR typically is sufficiently long to more than cover the few cycles it may take to clear the interrupt status, and also allows the status to be checked for further interrupts before exiting the ISR.

```
irqXServiceRoutine() {
    do {
        clearIrqXStatus();
        serviceIrqX();
    } while(irqXStatusIsActive());
}
```

### 3.3.2 TrustZone

The Cortex®-M33 implements ARM TrustZone which provides the ability to restrict access to peripherals and memory regions based on the CPU security attribute. TrustZone works in combination with the MPU which controls privileged/unprivileged execution of code to provide a full security solution. The Security Management Unit (SMU) is used to configure access restrictions in the various modes. Refer to [10. SMU - Security Management Unit](#) for more information.

For information about TrustZone features in the core or information on TrustZone specific instructions please see the ARM Cortex®-M33 Processor Technical Reference Manual provided by ARM

### 3.3.3 Interrupt Request Lines (IRQ)

This table shows all IRQ's for the system processor. M33 High Speed interrupts are indicated by an \*\*.

See the individual peripheral chapters for more information on interrupt function.

| IRQ # | Name              |
|-------|-------------------|
| 0*    | SMU_SECURE        |
| 1*    | SMU_S_PRIVILEGED  |
| 2*    | SMU_NS_PRIVILEGED |
| 3*    | EMU               |
| 4*    | TIMER0            |
| 5*    | TIMER1            |
| 6*    | TIMER2            |
| 7*    | TIMER3            |
| 8*    | TIMER4            |
| 9*    | USART0_RX         |
| 10*   | USART0_TX         |
| 11*   | EUSART0_RX        |
| 12*   | EUSART0_TX        |
| 13*   | EUSART1_RX        |
| 14*   | EUSART1_TX        |
| 15*   | MVP               |
| 16*   | ICACHE0           |
| 17*   | BURTC             |
| 18*   | LETIMERO          |
| 19*   | SYSCFG            |
| 20*   | MPAHBRAM          |
| 21*   | LDMA              |
| 22*   | LFXO              |
| 23*   | LFRCO             |
| 24*   | ULFRCO            |
| 25*   | GPIO_ODD          |
| 26*   | GPIO_EVEN         |
| 27*   | I2C0              |
| 28*   | I2C1              |
| 29*   | EMUDG             |
| 30*   | AGC               |
| 31*   | BUFC              |
| 32*   | FRC_PRI           |
| 33*   | FRC               |

| IRQ # | Name         |
|-------|--------------|
| 34*   | MODEM        |
| 35*   | PROTIMER     |
| 36*   | RAC_RSM      |
| 37*   | RAC_SEQ      |
| 38*   | HOSTMAILBOX  |
| 39*   | SYNTH        |
| 40*   | ACMP0        |
| 41*   | ACMP1        |
| 42*   | WDOG0        |
| 43*   | WDOG1        |
| 44*   | HFXO0        |
| 45*   | HFRC00       |
| 46*   | HFRCOEM23    |
| 47*   | CMU          |
| 48*   | AES          |
| 49*   | IADC         |
| 50*   | MSC          |
| 51*   | DPLL0        |
| 52*   | EMUEFP       |
| 53*   | DCDC         |
| 54*   | PCNT0        |
| 55*   | SW0          |
| 56*   | SW1          |
| 57*   | SW2          |
| 58*   | SW3          |
| 59*   | KERNEL0      |
| 60*   | KERNEL1      |
| 61*   | M33CTI0      |
| 62*   | M33CTI1      |
| 63*   | FPUEXH       |
| 64*   | SETAMPERHOST |
| 65*   | SEMBRX       |
| 66*   | SEMBTX       |
| 67*   | SYSRTC_APP   |
| 68*   | SYSRTC_SEQ   |
| 69*   | KEYSCAN      |
| 70*   | RFECA0       |

| IRQ # | Name     |
|-------|----------|
| 71*   | RFECA1   |
| 72*   | VDAC0    |
| 73*   | VDAC1    |
| 74*   | AHB2AHB0 |
| 75*   | AHB2AHB1 |

## 4. Memory and Bus System



### Quick Facts

#### What?

A low latency memory system including low energy Flash and RAM with data retention which makes the low energy modes attractive.

#### Why?

RAM retention reduces the need for storing data in Flash and enables frequent use of the ultra low energy modes EM2 and EM3.

#### How?

Low energy and non-volatile Flash memory stores program and application data in all energy modes and can easily be reprogrammed in system. Low leakage RAM with data retention in EM0 to EM3 removes the data restore time penalty, and the DMA ensures fast autonomous transfers with predictable response time.

### 4.1 Introduction

The EFR32xG24 contains a set of AMBA buses which move data between peripherals, memory, and the CPU. All memories and register interfaces are memory mapped into a unified address space.

## 4.2 Functional Description

The internal memory segments of the Cortex®-M33 are mapped into the system memory map as shown by [Figure 4.1 System Address Space with Core and Code Space Listing on page 42](#).



**Figure 4.1. System Address Space with Core and Code Space Listing**

Flash for the main program memory (CODE) is located at address 0x08000000 in the memory map of the EFR32xG24. Flash memory also contains a USERDATA area intended for user-defined data storage, the DEVINFO space with device characteristics and identifying information, and CHIPCONFIG with internal production test and calibration information.

SRAM for the main data memory (RAM) is located at address 0x20000000 in the memory map of the EFR32xG24. When running code located in RAM, the Cortex®-M33 uses the System bus interface to fetch instructions. This results in reduced performance as the Cortex®-M33 accesses stack, other data in SRAM and peripherals using the System bus interface.

The Sequencer RAM (SEQRAM) is located at address 0xA0000000 and is used by the Sequencer for both instructions and data. This RAM is also available for general use if not required by the RF subsystem.

#### 4.2.1 Bus Matrix

A multilayer AMBA AHB bus matrix connects the manager bus interfaces to the AHB subordinates. The bus matrix allows several AHB subordinates to be accessed simultaneously. An AMBA APB interface is used for the peripherals, which are accessed through an AHB-to-APB bridge connected to the AHB bus matrix.

The CPU has two AHB bus managers (Code and System) so that it may retrieve instructions and data in parallel. The Code manager is used to access all memory below address 0x20000000 and the System manager access addresses 0x20000000 and above.



**Figure 4.2. EFR32xG24 Bus System**

##### 4.2.1.1 Arbitration

The Bus Matrix uses a round-robin arbitration algorithm which enables high throughput and low latency, while starvation of simultaneous accesses to the same bus subordinate are eliminated. Round-robin does not assign a fixed priority to each bus manager. The arbiter does not insert any bus wait-states during peak interaction. However, one wait state is inserted for manager accesses occurring after a prolonged inactive time. This wait state allows for increased power efficiency during manager idle time.

##### 4.2.1.2 Bus Faults

System accesses from the core can receive a bus fault in the following condition(s):

- The core attempts to access an address that is not assigned to any peripheral or other system device. These faults can be enabled or disabled by setting the ADDRFAULTEN bit in the SYSCFG\_CTRL register.
- The core attempts to access a peripheral register that is LOCKED.
- The core attempts to access a peripheral or system device that has its clock disabled. This fault can be enabled or disabled by setting the ADDRFAULTEN bit in the SYSCFG\_CTRL register.
- System RAM controller or RADIO RAM controller detects a 2 bit ECC error. These faults can be enabled or disabled by setting the RAMECCERRFAULTEN bit in the SYSCFG\_CTRL register
- Registers with synchronization requirements may generate bus faults if accessed incorrectly. See [4.2.4.4 Peripheral Access Performance](#) for more details on register access types. In particular the following actions can cause bus faults:
  - Config register written while peripheral enabled.
  - Sync register written while peripheral disabled
  - LfSync register written while a previous write is pending
  - Peripheral disabled while any LfSync write is pending

In addition to any condition-specific bus fault control bits, the bus fault interrupt itself can be enabled or disabled in the same way as all other internal core interrupts.

#### 4.2.2 Flash

The Flash retains data in any state and typically stores the application code and special user data. The Flash memory is typically programmed through the debug interface, but can also be erased and written to from software.

- Up to 1536 kB of memory
- Page size of 8 KB (minimum erase unit)
- Lock registers for memory protection
- Data retention in any state

#### 4.2.3 SRAM

The primary task of the SRAM memory is to store application data. Additionally, it is possible to execute instructions from SRAM, and the DMA may be set up to transfer data between the SRAM, flash and peripherals.

The device contains several blocks of SRAM for various purposes including general data memory (DRAM) and various RF subsystem rams (SEQRAM, FRCRAM). For more detailed information see [6. MSC - Memory System Controller](#).

- Up to 256 kB of memory (RAM)
- RAM blocks may be powered down when not in use
- Data retention of the entire memory or selected banks in EM2 and EM3

**Note:** Root code requires some RAM storage during a system reset. The RAM used by root code is located at the top of the DRAM memory space. If the user application requires RAM that persists through reset, it is recommended to use a statically allocated section at the bottom of the SRAM memory space (address 0x20000000).

#### 4.2.4 Peripherals

The peripherals are mapped into the peripheral memory segment, each with a fixed size address range shown in the [4.2.4.1 Peripheral Map](#)

#### 4.2.4.1 Peripheral Map

This table shows the address range for each peripheral. In addition it shows the lowest energy mode in which the peripheral is powered. Note that EM3 is defined as EM2 with all clocks disabled. Therefore all peripherals powered in EM2 are also powered in EM3 but may not function if they require a running clock.

See the individual peripheral chapters for more information on low power operation.

| Address Range           | Module Name | Power Domain     |
|-------------------------|-------------|------------------|
| 0x40000000 - 0x40003FFF | SCRATCHPAD  | EM1              |
| 0x40004000 - 0x40007FFF | EMU         | EM2 (PD0A)       |
| 0x40008000 - 0x4000BFFF | CMU         | EM2 (PD0B)       |
| 0x40010000 - 0x40013FFF | HFRCO0      | EM1              |
| 0x40018000 - 0x4001BFFF | FSRCO       | EM2 (PD0A)       |
| 0x4001C000 - 0x4001FFFF | DPLL0       | EM1              |
| 0x40020000 - 0x40023FFF | LFXO        | EM4              |
| 0x40024000 - 0x40027FFF | LFRCO       | EM2 (PD0C) / EM4 |
| 0x40028000 - 0x4002BFFF | ULFRCO      | EM4              |
| 0x40030000 - 0x40033FFF | MSC         | EM1              |
| 0x40034000 - 0x40037FFF | ICACHE0     | EM1              |
| 0x40038000 - 0x4003BFFF | PRS         | EM2 (PD0E)       |
| 0x4003C000 - 0x4003FFFF | GPIO        | EM2 (PD0B)       |
| 0x40040000 - 0x40043FFF | LDMA        | EM1              |
| 0x40044000 - 0x40047FFF | LDMAXBAR    | EM1              |
| 0x40048000 - 0x4004BFFF | TIMER0      | EM1              |
| 0x4004C000 - 0x4004FFFF | TIMER1      | EM1              |
| 0x40050000 - 0x40053FFF | TIMER2      | EM1              |
| 0x40054000 - 0x40057FFF | TIMER3      | EM1              |
| 0x40058000 - 0x4005BFFF | TIMER4      | EM1              |
| 0x4005C000 - 0x4005FFFF | USART0      | EM1              |
| 0x40064000 - 0x40067FFF | BURTC       | EM4              |
| 0x40068000 - 0x4006BFFF | I2C1        | EM1              |
| 0x40078000 - 0x4007BFFF | SYSCFG      | EM1              |
| 0x4007C000 - 0x4007FFFF | SYSCFG      | EM1              |
| 0x40080000 - 0x40083FFF | BURAM       | EM4              |
| 0x40088000 - 0x4008BFFF | GPCRC       | EM1              |
| 0x40094000 - 0x40097FFF | DCDC        | EM2 (PD0B)       |
| 0x40098000 - 0x4009BFFF | HOSTMAILBOX | EM1              |
| 0x400A0000 - 0x400A3FFF | EUSART1     | EM1              |
| 0x400A8000 - 0x400ABFFF | SYSRTC0     | EM2 (PD0A)       |
| 0x400B0000 - 0x400B3FFF | KEYSCAN     | EM2 (PD0E)       |
| 0x400B4000 - 0x400B7FFF | DMEM        | EM1              |

| Address Range           | Module Name   | Power Domain     |
|-------------------------|---------------|------------------|
| 0x44000000 - 0x440007FF | RADIOAES      | EM1              |
| 0x44008000 - 0x4400BFFF | SMU           | EM1              |
| 0x4400C000 - 0x4400FFFF | SMU           | EM1              |
| 0x49000000 - 0x49003FFF | LETIMER0      | EM2 (PD0B)       |
| 0x49004000 - 0x49007FFF | IADC0         | EM2 (PD0B)       |
| 0x49008000 - 0x4900BFFF | ACMP0         | EM2 (PD0B)       |
| 0x4900C000 - 0x4900FFFF | ACMP1         | EM2 (PD0B)       |
| 0x49024000 - 0x49027FFF | VDAC0         | EM2 (PD0B)       |
| 0x49028000 - 0x4902BFFF | VDAC1         | EM2 (PD0B)       |
| 0x49030000 - 0x49033FFF | PCNT0         | EM2 (PD0B)       |
| 0x4A000000 - 0x4A003FFF | HFRCOEM23     | EM2 (PD0C)       |
| 0x4A004000 - 0x4A007FFF | HFXO0         | EM2 (PD0C)       |
| 0x4B000000 - 0x4B003FFF | I2C0          | EM2, (PD0D)      |
| 0x4B004000 - 0x4B007FFF | WDOG0         | EM2, (PD0D)      |
| 0x4B008000 - 0x4B00BFFF | WDOG1         | EM2, (PD0D)      |
| 0x4B010000 - 0x4B013FFF | EUSART0       | EM2, (PD0D)      |
| 0x4C000000 - 0x4C00007F | SEMAILBOX     | EM1              |
| 0x4D000000 - 0x4D003FFF | MVP           | EM1              |
| 0x50000000 - 0x50003FFF | SCRATCHPAD_NS | EM1              |
| 0x50004000 - 0x50007FFF | EMU_NS        | EM2 (PD0A)       |
| 0x50008000 - 0x5000BFFF | CMU_NS        | EM2 (PD0B)       |
| 0x50010000 - 0x50013FFF | HFRCO0_NS     | EM1              |
| 0x50018000 - 0x5001BFFF | FSRCO_NS      | EM2 (PD0A)       |
| 0x5001C000 - 0x5001FFFF | DPLL0_NS      | EM1              |
| 0x50020000 - 0x50023FFF | LFXO_NS       | EM4              |
| 0x50024000 - 0x50027FFF | LFRCO_NS      | EM2 (PD0C) / EM4 |
| 0x50028000 - 0x5002BFFF | ULFRCO_NS     | EM4              |
| 0x50030000 - 0x50033FFF | MSC_NS        | EM1              |
| 0x50034000 - 0x50037FFF | ICACHE0_NS    | EM1              |
| 0x50038000 - 0x5003BFFF | PRS_NS        | EM2 (PD0E)       |
| 0x5003C000 - 0x5003FFFF | GPIO_NS       | EM2 (PD0B)       |
| 0x50040000 - 0x50043FFF | LDMA_NS       | EM1              |
| 0x50044000 - 0x50047FFF | LDMAXBAR_NS   | EM1              |
| 0x50048000 - 0x5004BFFF | TIMER0_NS     | EM1              |
| 0x5004C000 - 0x5004FFFF | TIMER1_NS     | EM1              |
| 0x50050000 - 0x50053FFF | TIMER2_NS     | EM1              |
| 0x50054000 - 0x50057FFF | TIMER3_NS     | EM1              |

| Address Range           | Module Name    | Power Domain |
|-------------------------|----------------|--------------|
| 0x50058000 - 0x5005BFFF | TIMER4_NS      | EM1          |
| 0x5005C000 - 0x5005FFFF | USART0_NS      | EM1          |
| 0x50064000 - 0x50067FFF | BURTC_NS       | EM4          |
| 0x50068000 - 0x5006BFFF | I2C1_NS        | EM1          |
| 0x50078000 - 0x5007BFFF | SYSCFG_NS      | EM1          |
| 0x5007C000 - 0x5007FFFF | SYSCFG_NS      | EM1          |
| 0x50080000 - 0x50083FFF | BURAM_NS       | EM4          |
| 0x50088000 - 0x5008BFFF | GPCRC_NS       | EM1          |
| 0x50094000 - 0x50097FFF | DCDC_NS        | EM2 (PD0B)   |
| 0x50098000 - 0x5009BFFF | HOSTMAILBOX_NS | EM1          |
| 0x500A0000 - 0x500A3FFF | EUSART1_NS     | EM1          |
| 0x500A8000 - 0x500ABFFF | SYSRTC0_NS     | EM2 (PD0A)   |
| 0x500B0000 - 0x500B3FFF | KEYSCAN_NS     | EM2 (PD0E)   |
| 0x500B4000 - 0x500B7FFF | DMEM_NS        | EM1          |
| 0x54000000 - 0x540007FF | RADIOAES_NS    | EM1          |
| 0x54008000 - 0x5400BFFF | SMU_NS         | EM1          |
| 0x5400C000 - 0x5400FFFF | SMU_NS         | EM1          |
| 0x59000000 - 0x59003FFF | LETIMER0_NS    | EM2 (PD0B)   |
| 0x59004000 - 0x59007FFF | IADC0_NS       | EM2 (PD0B)   |
| 0x59008000 - 0x5900BFFF | ACMP0_NS       | EM2 (PD0B)   |
| 0x5900C000 - 0x5900FFFF | ACMP1_NS       | EM2 (PD0B)   |
| 0x59024000 - 0x59027FFF | VDAC0_NS       | EM2 (PD0B)   |
| 0x59028000 - 0x5902BFFF | VDAC1_NS       | EM2 (PD0B)   |
| 0x59030000 - 0x59033FFF | PCNT0_NS       | EM2 (PD0B)   |
| 0x5A000000 - 0x5A003FFF | HFRCOEM23_NS   | EM2 (PD0C)   |
| 0x5A004000 - 0x5A007FFF | HFXO0_NS       | EM2 (PD0C)   |
| 0x5B000000 - 0x5B003FFF | I2C0_NS        | EM2, (PD0D)  |
| 0x5B004000 - 0x5B007FFF | WDOG0_NS       | EM2, (PD0D)  |
| 0x5B008000 - 0x5B00BFFF | WDOG1_NS       | EM2, (PD0D)  |
| 0x5B010000 - 0x5B013FFF | EUSART0_NS     | EM2, (PD0D)  |
| 0x5C000000 - 0x5C00007F | SEMAILBOX_NS   | EM1          |
| 0x5D000000 - 0x5D003FFF | MVP_NS         | EM1          |

**Note:**

1. Peripherals listed as being in EM2 (PD0A) always remain powered in EM2 and EM3. Other EM2 power domains (PD0B, PD0C, etc.) are powered down in EM2 and EM3 if all peripherals on that domain are unused.
2. LFRCO requires EM0, EM1, or EM2 when operating in precision mode, but can operate down to EM4 when precision mode is not used.

#### 4.2.4.2 Peripheral non-word access behavior

When writing to peripheral registers, all accesses are treated as 32-bit accesses. This means that writes to a register need to be large enough to cover all bits of register, otherwise, any uncovered bits may become corrupted from the partial-word transfer. Thus, the safest practice is to always do 32-bit writes to peripheral registers.

When reading, there is generally no issue with partial word accesses, however, note that any read action (e.g. FIFO popping) will be triggered regardless of whether the actual FIFO bit-field was included in the transfer size.

#### 4.2.4.3 Peripheral Bit Set and Clear

The EFR32xG24 supports bit set, bit clear, and bit toggle access to most peripheral registers. The bit set and bit clear functionality (also called Bit Access) enables modification of bit fields without the need to perform a read-modify-write. Also, the operation is contained within a single bus access. Bit access registers and their addresses are shown in the register map for each peripheral. Peripherals with no \_SET, \_CLR, or \_TGL registers in the register map do not support these functions.

Each register with Bit Set functionality will have a \_SET register. Whenever a bit in the SET register is written to a 1 the corresponding bit in its target register is set. The SET register is located at TARGET + 0x1000 where TARGET is the address of the target register and has the same name as the target register with '\_SET' appended.

Each register with Bit Clear functionality will have a CLR register. Whenever a bit in the CLR register is written to a 1 the corresponding bit in its target register is cleared. The CLR register is located at TARGET + 0x2000 where TARGET is the address of the target register and has the same name as the target register with '\_CLR' appended.

Each register with Bit Toggle functionality will have a TGL register. Whenever a bit in the TGL register is written to a 1 the corresponding bit in its target register is inverted. The TGL register is located at TARGET + 0x3000 where TARGET is the address of the target register and has the same name as the target register with '\_TGL' appended.

**Note:** It is possible to combine bit clear and bit set operations in order to arbitrarily modify multi-bit register fields without affecting other fields in the same register. In this case, care should be taken to ensure that the field does not have intermediate values that can lead to erroneous behavior. For example, if bit clear and bit set operations are used to change an analog tuning register field from 0x2 to 0x4 by clearing bit 1 and then setting bit 2, the field would take on a value of zero for short time. If the analog module is active at the time, this could lead to undesired behavior.

#### 4.2.4.4 Peripheral Access Performance

The Cortex®-M33, DMA Controller, and peripherals run on clocks which can be pre-scaled separately. Clocks and pre-scaling are described in more detail in [8. CMU - Clock Management Unit](#). This section describes the access performance for a peripheral register based on its frequency relative to the CPUCLK frequency and its access type. For this discussion, PERCLK refers to a selected peripheral's clock frequency and CPUCLK refers to the core's clock frequency.

The type of each register in a peripheral is indicated in the 'Access' column of the peripherals register table. Register types are: ENABLE, CONFIG, SYNC, LFSYNC, and INTFLAG. If not type is listed then the register is a Generic register.

##### 4.2.4.4.1 Generic Registers

Registers with no type listed are generic registers. They may be read or written to at any time. Access will not stall the CPU.

##### 4.2.4.4.2 CONFIG Registers

CONFIG Registers contain configuration that does not change during peripheral operation.

CONFIG registers may only be written when a peripheral is disabled. Writing to a CONFIG register when a peripheral is enabled will result in a BUSFAULT. CONFIG register writes will not stall the CPU.

CONFIG registers may be read at any time. Reads will not stall the CPU.

#### 4.2.4.4.3 SYNC Registers

SYNC registers are used to communicate with running high-speed peripherals where PERCLK is expected to be either higher or marginally slower (within an order of magnitude) than CPUCLK. For example a timer running at 76.8 MHz when the core is at 38.4 MHz or at 9.6 MHz when the core is 76.8 MHz. In this case CPU stalls of several PERCLK cycles do not significantly impact overall system performance in most systems.

SYNC registers may only be written to when the peripheral is enabled. Writing to a SYNC register when a peripheral is disabled will result in a BUSFAULT. A write will take several (2 - 3) PERCLK cycles to complete (take effect) during which time the entire module will be in a pending state. If a SYNC register is written to while the peripheral is already in a pending state, the CPU is stalled until the previous write finishes. If a SYNC register is written to while the peripheral is not in a pending state, the CPU is not stalled.

SYNC registers may be read at any time. If a SYNC register is read while the peripheral is disabled, the CPU is not stalled. If a SYNC register is read while the peripheral is enabled, the CPU will be stalled for several (2 - 3) PERCLK cycles while up to date values are retrieved from the peripheral.

#### 4.2.4.4.4 LFSYNC Registers

LFSYNC registers are used to communicate with running low frequency peripherals where PERCLK is expected to be much lower than the CPU clock and synchronization delays may be long. For example, a LETIMER running at 32 kHz when the core is at 76.8 MHz. In this case CPU stalls of several PERCLK cycles represent a significant blockage of the CPU and need to be avoided whenever possible. LFSYNC registers accommodate this by allowing the CPU to write the register and continue to do other work while the value is synchronized.

LFSYNC registers may be written at any time. A write will take several (3 - 4) PERCLK cycles to complete during which the register will be in a pending state. If a LFSYNC register is written to while it is in a pending state, a BUSFAULT will occur. Each LFSYNC register has a status bit indicating if it is currently pending.

LFSYNC registers may be read at any time. The CPU is never stalled on a read. If a LFSYNC register is read while pending, the pending (recently written) data will be returned even though it has not yet taken effect. Software may use the busy status bit to determine if the read value has been applied to the hardware.

#### 4.2.4.4.5 ENABLE Registers

ENABLE registers contain the enable bit for a peripheral.

ENABLE registers may be written at any time. When the peripheral is enabled it takes some time for the enable to take effect during which time the module is pending. Peripherals will be in the pending state for a few (2 - 3) PERCLK cycles when first enabled. Since the clock source for the peripheral may not be running before the peripheral is enabled, the start up time for the clock source may increase the pending time. See [EFR32xG24 Wireless SoC](#) for more information on on-demand clock sources.

Disabling a high frequency module will stall the CPU until all pending SYNC writes have completed and any pending enable has completed. If the module is fully enabled and no SYNC writes are pending, the disable will be instantaneous. Disabling low frequency peripheral which a LFSYNC is pending will result in a bus fault. Disabling a low frequency peripherals while an enable is still pending causes no CPU stall.

ENABLE registers may be read at any time.

#### 4.2.4.4.6 INTFLAG Registers

INTFLAG registers contain interrupt flags. To set or clear an interrupt flag, the \_SET or \_CLR register alias must be used. Writing directly to the INTFLAG register will have no effect.

Note that for an interrupt to occur when a flag is set the IRQ must be enabled in the NVIC.

## 5. Radio Transceiver



### Quick Facts

#### What?

The Radio Transceiver provides access to transmit and receive data, radio settings and control interface.

#### Why?

The Radio Transceiver enables the user to communicate using a wide range of data rates, modulation and frame formats.

#### How?

Dynamic or fixed frame lengths, optional address recognition, flexible CRC and crypto schemes makes the EFR32 Series 2 perfectly suit any application using low or medium data rate radio communication.

## 5.1 Introduction

The Radio Transceiver of the EFR32 Series 2 enables the user to control a wide range of settings and options for tailoring radio operation precisely to the users need. It provides access to the transmit and receive data buffers and supports both dynamic and static frame lengths, as well as automatic address filtering and CRC insertion/verification.

As seen in the Radio Overview illustration (Figure 5.1 Radio Overview on page 51), the radio consists of several modules all responsible for specific tasks. Please refer to the abbreviations section (Appendix 1. Abbreviations) for a comprehensive description of acronyms.



**Figure 5.1. Radio Overview**

During transmission (TX), the Radio Controller enables the Frequency Synthesizer (SYNTH), Modulator (MOD), and Power Amplifier (PA). The Modulator requests data from the Frame Controller (FRC), which reads data from a buffer. Based upon modulation format and data to send, the Modulator manipulates the SYNTH to output the correct frequency and phase. When the whole frame has been transmitted, the radio can automatically switch to receive mode.

In receive mode (RX), the radio controller enables the Low Noise Amplifier (LNA), Frequency Synthesizer (SYNTH), Mixers, Intermediate Frequency ADCs (IFADC), and Demodulator (DEMOD). The Demodulator searches for valid frames according to modulation format and data rate. If a frame is detected, the demodulated data is handed to the Frame Controller (FRC), which stores the data in the Buffer. When the complete frame has been received (determined by the Frame Controller), it is possible to either go to TX or stay in RX to search for a new frame.

The Radio Transceiver interface is accessible through software drivers provided by Silicon Labs.

### 5.1.1 RF Frequency Synthesizer

The Fractional-N RF Frequency Synthesizer (SYNTH) provides a low phase noise LO signal to be used in both receive and transmit modes.

The capabilities of the SYNTH include:

- High performance, low phase noise
- Fast frequency settling
- Fast and fully automated calibration
- Sub 100 Hz frequency resolution across the supported frequency bands

### 5.1.2 Modulation Modes

EFR32xG24 supports a wide range of modulation modes in transmit and receive:

- 2-FSK, 2-GFSK, 4-FSK, MSK, GMSK, O-QPSK with half-sine shaping, ASK / OOK, DBPSK TX
- NRZ or Manchester support
- UART mode over air for legacy protocols
- Baudrates ranging from below 100 Baud/s to 2 MBaud/s, allowing data rates up to 4 MBit/s
- Configurable frequency deviation
- Configurable Direct Sequence Spread Spectrum (DSSS), with spread sequences up to 32 chips encoding up to 4 information bits
- Configurable 4-FSK symbol encoding

### 5.1.3 Transmit Mode

In transmit mode EFR32xG24 performs the following functionality:

- Automatic PA power ramping during the start and end of a frame transmit
- Programmable output power
- Optional preamble and synchronization word insertion
- Accurate transmit frame timing to support time synchronized radio protocols
- Optional Carrier Sense Multiple Access - Collision Avoidance (CSMA-CA) or Listen Before Talk (LBT) hardware support
- Integrated transmit test modes, as described in [5.1.12 RF Test Modes](#)

### 5.1.4 Receive Mode

In receive mode EFR32xG24 performs the following functionality:

- A single-ended LNA amplifies the input RF signal. The amplified signal is then mixed to a low-IF signal through the quadrature down-conversion mixer. Further signal filtering is performed before conversion to a digital signal through the I/Q ADC.
- Digitally configurable receiver bandwidth from 100 Hz to 2.5 MHz
- Timing recovery on received data, including simultaneous support for two different frame synchronization words
- Automatic frequency offset compensation, to compensate for carrier frequency offset between the transmitter and receiver
- Support for a wide range of modulation formats as described in section [5.1.2 Modulation Modes](#)

### 5.1.5 Data Buffering

EFR32xG24 supports buffered transmit and receive modes through its buffer controller (BUFC), with four individually configurable buffers. The BUFC uses the system RAM as storage, and each buffer can be individually configured with parameters such as:

- Buffer size
- Buffer interrupt thresholds
- Buffer RAM location
- Overflow and underflow detection

In receive mode, data following frame synchronization is moved directly from the demodulator to the buffer storage.

In transmit mode, data following the inserted preamble and synchronization word is moved directly from the buffer storage to the modulator.

### 5.1.6 Unbuffered Data Transfer

For most system designs it is recommended to use the data buffering within EFR32xG24 to provide a convenient user interface.

In unbuffered data transfer modes the hardware support provided by EFR32xG24 to perform preamble and frame synchronization insertion in transmit mode and detection in receive mode can still optionally be used.

### 5.1.7 Frame Format Support

EFR32xG24 has an extensive support for frame handling in transmit and receive modes, which allows effective handling of even advanced protocols. The frame format support is controlled by the Frame Controller (FRC). The support includes:

- Preamble and frame synchronization inserted into transmitted frames
- Full frame synchronization of received frames
- Simple address matching of received frames in hardware, further configurable address and frame filtering supported through sequencer
- Support for variable length frames
- Automated CRC calculation and verification
- Configurable bit ordering, with the most or least significant bit transmitted and received first

### 5.1.8 Hardware CRC Support

EFR32xG24 supports a configurable CRC generation in transmit and verification in receive mode:

- 8, 16, 24 or 32 bit CRC value
- Configurable polynomial and initialization value
- Optional inversion of CRC value over air
- Configurable CRC byte ordering
- Support for multiple CRC values calculated and verified per transmitted or received frame
- The CRC module is typically controlled by the Frame Controller (FRC) for in-line operations in transmit and receive modes. Alternatively, the CRC module may be accessed directly from software to calculate and verify CRC data.

### 5.1.9 Convolutional Encoding / Decoding

EFR32xG24 includes hardware support for convolutional encoding and decoding, for forward error correction (FEC). This feature is performed by the Frame Controller (FRC) module:

- Constraint length configurable up to 7, for the highest robustness
- Configurable puncturing, to achieve rates between 1/2 rate and full rate
- Configurable soft decision or hard decision decoding
- Convolutional coding may be used together with the symbol interleaver to improve robustness against burst errors

### 5.1.10 Binary Block Encoding / Decoding

EFR32xG24 includes hardware support for binary block encoding and decoding, both performed real-time in the the transmit and receive path. This is performed in the Frame Controller (FRC) module:

The block coding works on blocks of up to 16 bits of data and adds parity bits to be capable of single or multiple bit corrections by the receiver.

- One or more parity bits can be added and verified
- Bit error correction
- Lookup-codes can be used to implement virtually any block coding scheme

### 5.1.11 Data Encryption and Authentication

EFR32xG24 has hardware support for AES encryption, decryption and authentication modes. These security operations can be performed on data in RAM or any data buffer, without further CPU intervention. The key size is 128 bits.

AES modes of operations directly supported by the EFR32xG24 hardware are listed in [Table 5.1 AES modes of operation with hardware support on page 54](#). In addition to these modes, other modes can also be implemented by using combinations of modes. For example, the CCM mode can be implemented using the CTR and CBC-MAC modes in combination.

**Table 5.1. AES modes of operation with hardware support**

| AES Mode | Encryption / Decryption | Authentication | Comment                                                  |
|----------|-------------------------|----------------|----------------------------------------------------------|
| ECB      | Yes                     | -              | Electronic Code Book                                     |
| CTR      | Yes                     | -              | Counter mode                                             |
| CCM      | Yes                     | Yes            | Counter with CBC-MAC                                     |
| CCM*     | Yes                     | Yes            | CCM with encryption-only and integrity-only capabilities |
| GCM      | Yes                     | Yes            | Galois Counter Mode                                      |
| CBC      | Yes                     | -              | Cipher Block Chaining                                    |
| CBC-MAC  | -                       | Yes            | Cipher Block Chaining, Message Authentication Code       |
| CMAC     | -                       | Yes            | Cipher-based MAC                                         |
| CFB      | Yes                     | -              | Cipher Feedback                                          |
| OFB      | Yes                     | -              | Output Feedback                                          |

The Cryptographic Acceleration module can operate directly on data buffers provided by the buffer controller (BUFC) module. It is also possible to provide data directly from the embedded Cortex®-M33 or via DMA.

### 5.1.12 RF Test Modes

EFR32xG24 supports a wide range of RF test modes typically used for characterization and regulation compliance testing, including:

- Unmodulated carrier transmit
- Modulated carrier transmit, with internal configurable pseudo random data generator
- Continuous data reception for Bit Error Rate (BER) measurements
- Storing of raw receiver data to RAM
- Transmit of raw frequency data from RAM

## 6. MSC - Memory System Controller



```

01000101011011100110010101110010
01100111011110010010000001001101
01101001011000110111001001101111
00100000011100100111010101101100
01100101011100110010000001110100
01101000011001010010000001110111
01101111011100100110110001100100
00100000011011110110011000100000
01101100011011110111011100101101
01100101011011100110010101110010
01100111011110010010000001101101
01101001011000110111001001101111
01100011011011110110111001110100
01110010011011110110110001101100
01100101011100100010000001100100
01100101011100110110100101100111
01101110001000010100010101101110

```

### Quick Facts

#### What?

The user can perform flash memory read, read configuration, and write operations through the Memory System Controller (MSC). SRAM operation may be configured through System Configuration (SYSCFG).

#### Why?

The MSC allows the application code and user data to be stored in non-volatile flash memory. Certain memory system functions, such as program memory wait-states and flash lock bits are configured from the MSC peripheral register interface, giving the developer the ability to dynamically customize the memory system performance, security level, energy consumption and error handling capabilities to the requirements at hand.

#### How?

The MSC integrates a low-energy flash IP with a charge pump, enabling minimum energy consumption while eliminating the need for external programming voltage to erase the memory. An easy to use write and erase interface is supported by an internal, fixed-frequency oscillator and autonomous flash timing and control reduces software complexity while not using other timer resources.

A highly efficient low energy instruction cache reduces the number of flash reads significantly, thus saving energy. Performance is also improved when wait-states are used, since many of the wait-states are eliminated. Built-in performance counters can be used to measure the efficiency of the instruction cache.

Instruction prefetcher improves program execution performance by reducing the number of wait-state cycles needed.

### 6.1 Introduction

The Memory System Controller (MSC) is the program memory unit of the EFR32xG24 microcontroller. The flash memory is readable and writable from both the Cortex®-M33 and DMA. The flash memory is divided into two blocks: the main block and the information block. Program code is normally written to the main block. The information block is available for special user data. There is also a read-only page in the information block containing system and device calibration data. Flash read and write operations are supported in energy modes EM0 and EM1.

## 6.2 Features

- AHB read interface
  - Scalable access performance to optimize the Cortex®-M33 code interface
    - Advanced energy optimization functionality
      - Conditional branch target prefetch suppression
      - Cortex®-M33 unfolding of if-then (IT) blocks
      - Instruction Cache
      - Instruction Prefetch
    - DMA read support in EM0 and EM1
  - Command and status interface
    - Flash write and erase
      - Accessible from Cortex®-M33 in EM0
      - DMA write support in EM0 and EM1
    - Core clock independent flash timing
      - Internal oscillator and internal timers for precise and autonomous flash timing
        - General purpose timers are not occupied during flash erase and write operations
        - No special time scaling registers needed
    - Configurable interrupt erase abort
      - Improved interrupt predictability
    - Memory and bus fault control
  - Security features
    - Lockable debug access
    - Page lock registers
    - SW Mass erase and User Data lock bits
  - End-of-write and end-of-erase interrupts

## 6.3 Functional Description

The size of the main flash block is device dependent. The largest size available is 1536 kB (192 pages). The information block has 1 kB available for user data. The information block also contains chip configuration data located in a reserved area. The main block is mapped to address 0x08000000 and the information block is mapped to address 0x0FE00000. [Table 6.1 MSC Flash Memory Mapping on page 56](#) outlines how the flash is mapped in the memory space. All flash memory is organized into 8 kB pages.

**Table 6.1. MSC Flash Memory Mapping**

| Block       | Page             | Base address | Write/Erase by... | Software Readable? | Purpose/Name            | Size            |
|-------------|------------------|--------------|-------------------|--------------------|-------------------------|-----------------|
| Main        | 0                | 0x08000000   | Software, debug   | Yes                | User code and data      | 16 kB - 1536 kB |
|             | 1                | 0x08002000   | Software, debug   | Yes                |                         |                 |
|             | ...              |              | Software, debug   | Yes                |                         |                 |
|             | 191 <sup>1</sup> | 0x0817E000   | Software, debug   | Yes                |                         |                 |
| Information | N/A              | 0x0FE00000   | Software, debug   | Yes                | User Data (UD)          | 1 kB            |
|             | N/A              | 0x0FE08000   | -                 | Yes                | Device Information (DI) | 1 kB            |

**Note:**

1. 192 pages for largest device.

### 6.3.1 RAM Configuration

The SYSCFG and MPAHBRAM modules contain controls for configuring the various RAM blocks on the device. Options include enabling EM2/EM3 data retention, ECC, and RAM port priorities. For a complete description see [6.6 SYSCFG - System Configuration](#).

### 6.3.2 Instruction Cache

The instruction cache improves the speed and power consumption of the Cortex®-M33 by providing fast, low-power access to recently executed instructions. For detailed information see [6.5 ICACHE - Instruction Cache](#)

### 6.3.3 Device Information (DI) Page

This read-only page holds calibration data from the production test, several unique device IDs, and other part specific information. For a complete description see [6.4 DEVINFO - Device Info Page](#).

### 6.3.4 User Data (UD) Page Description

This is the user data page in the information block. The page can be erased and written by software when MISCLOCKWORD.UDLOCKBIT is 0.

### 6.3.5 Bootloader

The EFR32xG24 supports use of the Gecko Bootloader detailed in *UG489: Silicon Labs Gecko Bootloader User's Guide for GSDK 4.0 and Higher* (<https://www.silabs.com/support/resources>). To enable bootloader functionality, the second stage of the bootloader must be configured and programmed into the beginning of flash. The first stage of the bootloader is provided by the SE and is not user accessible. For more details on SE bootloader support, see the SE peripheral documentation.

### 6.3.6 Post-reset Behavior

Calibration values are automatically written to registers by the MSC before application code start-up. The values can also be read from the DI page by software. Other information such as the device ID and production date is also stored in the DI page and is readable from software.

As part of the reset, hardware performs repeated flash reads to determine when flash is fully powered up and available for use by the CPU. PWRUPCKBDFAILCOUNT in MSC\_STATUS contains the number of failed reads during the last reset.

### 6.3.7 Flash Startup

Flash wakeup on demand is supported when waking from EM2/3 to EM0. Set bit FLASHPWRUPONDEMAND of register EMU\_CTRL to enable the power up on demand. When enabled, flash will not be powered up until accessed. In this case it is possible for the MCU to wake, execute out of RAM or cache, and return to sleep mode without ever powering on the flash. Software can force the flash to power up by writing PWRUP in MSC\_CMD. When flash is powered via MSC\_CMD the MSC\_IF.PWRUPF interrupt flag will be set when power up is complete and the CPU will be interrupted if MSC\_IEN.PWRUPF is set.

### 6.3.8 Flash EM0 / EM1 Power Down

It is also possible to put the flash in a power-saving sleep mode when the system is in EM0 or EM1. Flash power down can be configured to happen on entering EM1, radio-only sleep, or with an immediate manual operation.

During EM0, software can instruct the flash to go to power down mode with the MSC\_CMD.PWROFF command. Any system IRQ or flash read will wake the flash. The MSC\_CMD.PWRUP command is used to power the flash back up in the absence of a wake event.

The MSC\_PWRCTRL register allows the flash to be configured to automatically enter sleep mode on entering EM1 or radio-only sleep with the bits PWROFFONEM1ENTRY and PWROFFONEM1PENTRY, respectively. If the flash is configured to sleep during one of these states, it may sometimes be powered back up without processor intervention in EM0 (for example, if DMA reads flash in EM1). By default, the flash will remain powered on after such access. If the PWROFFENTRYAGAIN bit is set, it instructs the flash to re-enter the power down state if no further access is seen during the timeout period defined by PWROFFDLY. Flash must be idle for PWROFFDLY \* 64 bus clocks before it will enter sleep again.

### 6.3.9 Wait-states

Since the CPU may be clocked faster than the flash can respond, it is necessary to configure wait-states for flash accesses at higher CPU clock speeds. See the device Datasheet for information on the maximum allowed frequency for each wait-state setting. To configure the flash wait-states set the MODE field in MSC\_READCTRL.

When changing wait states, care should be taken that the system is never in an invalid state. To ensure this, MODE should be changed after the clock is changed when reducing clock speed and before the clock is changed when increasing clock speed.

### 6.3.10 Cortex®-M33 If-Then Block Folding

The Cortex®-M33 offers a mechanism known as if-then block folding. This is a form of speculative prefetching where small if-then blocks are collapsed in the prefetch buffer if the condition evaluates to false. The instructions in the block then appear to execute in zero cycles. With this scheme, performance is optimized at the cost of higher energy consumption as the processor fetches more instructions from memory than it actually executes. To disable the mode, write a 1 to the DISFOLD bit in the NVIC Auxiliary Control Register; see the Cortex®-M33 Technical Reference Manual for details. Normally, it is expected that this feature is most efficient when operating with 0 wait-states. Folding is enabled by default.

### 6.3.11 Line Buffering (Prefetch)

The MSC reads a 2-word line from flash on any flash access. The data being accessed is returned immediately and the other word locally cached so that it can be provided immediately if accessed. This has the effect of pre-fetching the second word when the first is read, resulting in fewer wait-states when executing sequential code. This feature may be disabled by setting DOUTBUFEN in MSC\_READCTRL.

### 6.3.12 Erase and Write Operations

To erase a page first set WREN in MSC\_WRITECTRL and load any address in the page to be erased into the MSC\_ADDRB register. Next check INVADDR, LOCKED, and WREADY in MSC\_STATUS to ensure that the address is valid, not locked, and the MSC is ready to modify flash. Writing ERASEPAGE in MSC\_WRITEMD will execute the page erase operation. ERASE in MSC\_IF will be set when the page erase is complete. If ERASE in MSC\_IEN is set, the end of a page erase will also trigger an interrupt. Finally, clear WREN to disable flash operations.

In addition to a page erase, a mass erase will clear the entire contents of the main flash array. A mass erase can be initiated by the Secure Engine. User Data page contents are not included in a mass erase.

To perform a programming operation, set WREN and load the address to be programmed into the MSC\_ADDRB register. Next check INVADDR, LOCKED, WREADY, and WDATAREADY in MSC\_STATUS to ensure that the address is valid, not locked, the MSC is ready to modify flash, and the write data buffer is clear. Writing data to MSC\_WDATA will begin the programming operation. If a burst write is being performed, the next data word can be programmed to MSC\_WDATA as soon as WDATAREADY is set. WRITE in MSC\_IF will be set when the programming operation is complete. If WRITE in MSC\_IEN is set, the end of the program operation will also trigger an interrupt. Finally, clear WREN to disable flash operations.

If data is written to the MSC\_WDATA register faster than it can be processed, WDATAOV in MSC\_IF will be set. If WDATAOV in MSC\_IEN is set an interrupt will also be fired.

The MSC\_ADDRB register only has to be written once when writing to sequential words. After each word is written, ADDRB is incremented automatically by 4. The INVADDR bit of the MSC\_STATUS register is set if the loaded address is outside the flash. The LOCKED bit of the MSC\_STATUS register is set if the page addressed is locked. Any attempts to erase or write to the page are ignored if INVADDR or the LOCKED bits of the MSC\_STATUS register are set.

Write and erase operations may be aborted by software. To abort an erase, set the ERASEABORT bit in the MSC\_WRITECMD register. To abort a write, set WRITEEND in MSC\_WRITECMD

For a DMA write, CLEARWDATA in MSC\_WRITECMD to assert a DMA request and transfer the first word. Alternately the first word may be programmed manually into MSC\_WDATA by code.

By default, if any interrupt occurs during an erase operation, the erase is aborted. This feature may be disabled by clearing IRQERA-SEABORT in MSC\_WRITECTRL. When an erase is aborted due to an interrupt, ERASEABORTED in MSC\_STAUTS is set by hardware.

Software may observe the status of the MSC via the MSC\_STATUS register. When a flash operation is in progress, BUSY will be set. If a flash operation has been requested but not yet started, PENDING will be set. This may occur if a subsystem is performing MSC operations. When the write buffer underflows, TIMEOUT will be set. Buffer underflow is a normal part of the write procedure since it will occur once the last word has been written and no more data is available.

The flash memory is organized into 64-bit wide double-words. Each 64-bit double-word can be written only twice between erase cycles. The lower and upper 32-bit words may be written sequentially in any order, or one at a time. Each flash bit is 1 after erase. Writing a 0 will clear the bit. Writing a 1 will not change the bit value.

While it is possible to write twice to the lower or upper 32-bit word of the 64-bit double word, then the other 32-bit word cannot be used. In this case, it is permitted to write to either the lower or upper 32-bit word twice between each erase, so long as no bit is ever cleared more than once.

**Note:** The ERASEPAGE bit in WRITECMD and the WDATA register cannot safely be written from code in flash. It is recommended to place a small code section in RAM to set these bits and wait for the operation to complete. Also note that DMA transfers to or from any other address in flash while a write or erase operation is in progress will produce unpredictable results.

**Note:** During a write or erase, flash read accesses will be stalled, effectively halting code execution from flash. Code execution continues upon write/erase completion. Code residing in RAM or ICACHE may be executed during a write/erase operation.

#### 6.3.12.1 Low-Power Write

To limit maximum current, the programming operations can be slowed down. Set LPWRITE in MSC\_WRITECTRL to double the write time and halve the write current.

### 6.3.12.2 Flash Lock

The ability to program or erase individual flash pages may be disabled using the MSC\_PAGELOCKn registers. The bits in these registers may only be set to 1 by software on the device and are cleared when the device is reset. This means that once locked, a page may not be unlocked until a reset occurs. Users wishing to lock accesses to flash should implement code to write to the MSC\_PAGELOCKn registers immediately after a reset. Any page locked in this way cannot be written to or erased.

User Data can be locked by setting MSC\_MISCLOCKWORD.UDLOCK to 1. Mass erase is enabled out of reset, however if firmware sets MELOCKBIT in the MSC\_MISCLOCKWORD register, then mass erase can only be issued by the SE.

## 6.4 DEVINFO - Device Info Page

The Device Info Page holds factory programmed information about the device. It contains the following data:

- Calibration values for reconfiguring the device
- Unique ID's
- OPN identifiers (family, feature set, flash size, etc.)

#### 6.4.1 DEVINFO Register Map

The offset register address is relative to the registers base address.

| Offset | Name                           | Type | Description                                        |
|--------|--------------------------------|------|----------------------------------------------------|
| 0x000  | DEVINFO_INFO                   | R    | DI Information                                     |
| 0x004  | DEVINFO_PART                   | R    | Part Info                                          |
| 0x008  | DEVINFO_MEMINFO                | R    | Memory Info                                        |
| 0x00C  | DEVINFO_MSIZE                  | R    | Memory Size                                        |
| 0x010  | DEVINFO_PKGINFO                | R    | Misc Device Info                                   |
| 0x014  | DEVINFO_CUSTOMINFO             | R    | Custom Part Info                                   |
| 0x018  | DEVINFO_SWFIX                  | R    | SW Fix Register                                    |
| 0x01C  | DEVINFO_SWCAPA0                | R    | Software Restriction                               |
| 0x020  | DEVINFO_SWCAPA1                | R    | Software Restriction                               |
| 0x028  | DEVINFO_EXTINFO                | R    | External Component Info                            |
| 0x040  | DEVINFO_EUI48L                 | R    | EUI 48 Low                                         |
| 0x044  | DEVINFO_EUI48H                 | R    | EUI 48 High                                        |
| 0x048  | DEVINFO_EUI64L                 | R    | EUI64 Low                                          |
| 0x04C  | DEVINFO_EUI64H                 | R    | EUI64 High                                         |
| 0x050  | DEVINFO_CALTEMP                | R    | Calibration Temperature                            |
| 0x054  | DEVINFO_EMUTEMP                | R    | EMU Temp                                           |
| 0x058  | DEVINFO_HFRCODPLL CALn         | R    | HFRCODPLL Calibration                              |
| 0x0A0  | DEVINFO_HFRCOEM23CALn          | R    | HFRCOEM23 Calibration                              |
| 0x130  | DEVINFO_MODULENAME0            | R    | Module Name Information                            |
| 0x134  | DEVINFO_MODULENAME1            | R    | Module Name Information                            |
| 0x138  | DEVINFO_MODULENAME2            | R    | Module Name Information                            |
| 0x13C  | DEVINFO_MODULENAME3            | R    | Module Name Information                            |
| 0x140  | DEVINFO_MODULENAME4            | R    | Module Name Information                            |
| 0x144  | DEVINFO_MODULENAME5            | R    | Module Name Information                            |
| 0x148  | DEVINFO_MODULENAME6            | R    | Module Name Information                            |
| 0x14C  | DEVINFO_MODULEINFO             | R    | Module Information                                 |
| 0x150  | DEVINFO_MODXOCAL               | R    | Module External Oscillator Calibration Information |
| 0x180  | DEVINFO_IADC0GAIN0             | R    | IADC Gain Calibration                              |
| 0x184  | DEVINFO_IADC0GAIN1             | R    | IADC Gain Calibration                              |
| 0x188  | DEVINFO_IADC0OFFSETCAL0        | R    | IADC Offset Calibration                            |
| 0x18C  | DEVINFO_IADC0NORMALOFF-SETCAL0 | R    | IADC Offset Calibration                            |
| 0x190  | DEVINFO_IADC0NORMALOFF-SETCAL1 | R    | IADC Offset Calibration                            |
| 0x194  | DEVINFO_IADC0HISPDOFF-SETCAL0  | R    | IADC Offset Calibration                            |

| Offset | Name                          | Type | Description             |
|--------|-------------------------------|------|-------------------------|
| 0x198  | DEVINFO_IADC0HISPDOFF-SETCAL1 | R    | IADC Offset Calibration |
| 0x1FC  | DEVINFO_LEGACY                | R    | Legacy Device Info      |
| 0x25C  | DEVINFO_RTHERM                | R    | Thermistor Calibration  |
| 0x264  | DEVINFO_FENOTCHCAL            | R    | FENOTCH Calibration     |

## 6.4.2 DEVINFO Register Description

### 6.4.2.1 DEVINFO\_INFO - DI Information

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|
|        | 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 |
| Reset  | 0xB          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |
| Name   | DEVINFOREV   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | CRC |   |

| Bit   | Name       | Reset | Access | Description                                                                         |
|-------|------------|-------|--------|-------------------------------------------------------------------------------------|
| 31:24 | DEVINFOREV | 0xB   | R      | <b>DI Page Version</b><br>DEVINFO layout revision as unsigned integer (initially 1) |
| 23:16 | PRODREV    | 0x0   | R      | <b>Production Revision</b><br>Production revision as unsigned integer               |
| 15:0  | CRC        | 0x0   | R      | <b>CRC</b><br>CRC of DI-page (CRC-16-CCITT)                                         |

## 6.4.2.2 DEVINFO\_PART - Part Info

| Offset | Bit Position |    |        |    |     |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |   |   |   |     |
|--------|--------------|----|--------|----|-----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------|---|---|---|-----|
| 0x004  | 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 |     |
| Reset  |              |    |        |    | 0x0 |    |    |    |    |    |    |    | 0x0       |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |   |   |   | 0x0 |
| Access |              |    |        |    | R   |    |    |    |    |    |    |    | R         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           | R |   |   |     |
| Name   |              |    | FAMILY |    |     |    |    |    |    |    |    |    | FAMILYNUM |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | DEVICENUM |   |   |   |     |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 29:24 | FAMILY    | 0x0   | R      | <b>Device Family</b><br><br>Encoded portion of the Device Family                                                                                                                  |
|       | Value     | Mode  |        | Description                                                                                                                                                                       |
|       | 0         | FG    |        | Flex Gecko                                                                                                                                                                        |
|       | 1         | MG    |        | Mighty Gecko                                                                                                                                                                      |
|       | 2         | BG    |        | Blue Gecko                                                                                                                                                                        |
| 23:22 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 21:16 | FAMILYNUM | 0x0   | R      | <b>Device Family</b><br><br>Numeric portion of the Device Family                                                                                                                  |
| 15:0  | DEVICENUM | 0x0   | R      | <b>Device Number</b><br><br>Device Number. The device number is one letter and 3 digits. NUMBER = (alpha-'A')*1000 + numeric. 0 = A000; 1123 = B123                               |

**6.4.2.3 DEVINFO\_MEMINFO - Memory Info**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |    |    |   |   |               |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|----|---|---|---------------|---|---|---|---|---|---|---|
| 0x008  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    | 0x0        |    |    |    |    |    |    |    |    |    |   |   | 0x0           |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    | R          |    |    |    |    |    |    |    |    |    |   |   | R             |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | UDPAGESIZE |    |    |    |    |    |    |    |    |    |   |   | FLASHPAGESIZE |   |   |   |   |   |   |   |
| DILEN  |              |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |    |    |   |   |               |   |   |   |   |   |   |   |

| Bit   | Name          | Reset | Access | Description                                                                                                                                               |
|-------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | DILEN         | 0x0   | R      | <b>Length of DI Page</b><br><br>Length of DI area (number of 32-bit words included in CRC)                                                                |
| 15:8  | UDPAGESIZE    | 0x0   | R      | <b>User Data Page Size</b><br><br>User Data page size                                                                                                     |
| 7:0   | FLASHPAGESIZE | 0x0   | R      | <b>Flash Page Size</b><br><br>Flash page size in bytes coded as $2^{(\text{MEMINFO.PAGESIZE} + 10)} \& 0xFF$ . For example, the value of 0xFF = 512 bytes |

**6.4.2.4 DEVINFO\_MSIZE - Memory Size**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |       |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|---|---|-------|---|---|---|---|---|---|---|
| 0x00C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    | 0x0  |    |    |    |    |    |    |    |    |    |   |   | 0x0   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    | R    |    |    |    |    |    |    |    |    |    |   |   | R     |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | SRAM |    |    |    |    |    |    |    |    |    |   |   | FLASH |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                    |  |  |  |  |  |  |  |  |  |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|----------|-------|--------|--------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:27 | Reserved |       |        |                                                                                |  |  |  |  |  |  |  |  |  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26:16 | SRAM     | 0x0   | R      | <b>Sram Size</b><br><br>Ram size, kbyte count as unsigned integer (eg 16)      |  |  |  |  |  |  |  |  |  |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:0  | FLASH    | 0x0   | R      | <b>Flash Size</b><br><br>Flash size, kbyte count as unsigned integer (eg. 128) |  |  |  |  |  |  |  |  |  |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 6.4.2.5 DEVINFO\_PKGINFO - Misc Device Info

| Offset | Bit Position |    |    |    |    |    |    |    |          |    |    |    |         |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----------|----|----|----|---------|----|----|----|----|----|----|----|-----------|----|---|---|---|---|---|---|---|---|---|---|
| 0x010  | 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 |
| Reset  |              |    |    |    |    |    |    |    | 0x0      |    |    |    | 0x0     |    |    |    |    |    |    |    | 0x0       |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    | R        |    |    |    | R       |    |    |    |    |    |    |    | R         |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    | PINCOUNT |    |    |    | PKGTYPE |    |    |    |    |    |    |    | TEMPGRADE |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name      | Reset    | Access | Description                                                                                                                                                                       |
|-------|-----------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved  |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:16 | PINCOUNT  | 0x0      | R      | <b>Pin Count</b><br><br>Device pin count as unsigned integer (eg. 48)                                                                                                             |
| 15:8  | PKGTYPE   | 0x0      | R      | <b>Package Type</b><br><br>Package identifier as character                                                                                                                        |
|       | Value     | Mode     |        | Description                                                                                                                                                                       |
|       | 74        | WLCSP    |        | WLCSP package                                                                                                                                                                     |
|       | 76        | BGA      |        | BGA package                                                                                                                                                                       |
|       | 77        | QFN      |        | QFN package                                                                                                                                                                       |
|       | 81        | QFP      |        | QFP package                                                                                                                                                                       |
| 7:0   | TEMPGRADE | 0x0      | R      | <b>Temperature Grade</b><br><br>Temperature Grade of product as unsigned integer enumeration                                                                                      |
|       | Value     | Mode     |        | Description                                                                                                                                                                       |
|       | 0         | N40TO85  |        | -40 to 85 degC                                                                                                                                                                    |
|       | 1         | N40TO125 |        | -40 to 125 degC                                                                                                                                                                   |
|       | 2         | N40TO105 |        | -40 to 105 degC                                                                                                                                                                   |
|       | 3         | N0TO70   |        | 0 to 70 degC                                                                                                                                                                      |

**6.4.2.6 DEVINFO\_CUSTOMINFO - Custom Part Info**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x014         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | PARTNO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset                                                                                                                                                                             | Access | Description        |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| 31:16 | PARTNO   | 0x0                                                                                                                                                                               | R      | <b>Part Number</b> |
|       |          | Custom part identifier as unsigned integer (eg. 903). 65535 for standard product                                                                                                  |        |                    |
| 15:0  | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                    |

**6.4.2.7 DEVINFO\_SWFIX - SW Fix Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x018         | 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 |
| <b>Reset</b>  | 0xFFFFFFFF   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | RSV          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Reset                   | Access | Description     |
|------|------|-------------------------|--------|-----------------|
| 31:0 | RSV  | 0xFFFFFFFF FF           | R      | <b>Reserved</b> |
|      |      | Reserved for future use |        |                 |

## 6.4.2.8 DEVINFO\_SWCAPA0 - Software Restriction

| Offset        | Bit Position |       |    |    |     |    |    |    |         |    |    |    |    |    |         |    |    |    |    |    |    |    |       |   |   |        |   |
|---------------|--------------|-------|----|----|-----|----|----|----|---------|----|----|----|----|----|---------|----|----|----|----|----|----|----|-------|---|---|--------|---|
| 0x01C         | 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      |   |
| <b>Reset</b>  |              |       |    |    | 0x0 |    |    |    | 0x0     |    |    |    |    |    | 0x0     |    |    |    |    |    |    |    | 0x0   |   |   |        |   |
| <b>Access</b> |              |       |    |    | R   |    |    |    | R       |    |    |    |    |    | R       |    |    |    |    |    |    |    | R     |   |   |        |   |
| <b>Name</b>   |              | ZWAVE |    |    | SRI |    |    |    | CONNECT | R  |    |    |    |    | BTSMART | R  |    |    |    |    |    |    | RF4CE |   |   | THREAD |   |
|               |              |       |    |    |     |    |    |    |         |    |    |    |    |    |         |    |    |    |    |    |    |    |       |   |   | ZIGBEE | R |

| Bit   | Name                           | Reset                                                                                                                                                                             | Access | Description                            |
|-------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------|
| 31:27 | <b>Reserved</b>                | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                        |
| 26:24 | ZWAVE                          | 0x0                                                                                                                                                                               | R      | <b>Z-Wave Capability</b>               |
|       | Z-Wave Stack Capability        |                                                                                                                                                                                   |        |                                        |
|       | Value                          | Mode                                                                                                                                                                              |        | Description                            |
|       | 0                              | LEVEL0                                                                                                                                                                            |        | Z-Wave stack capability not available  |
|       | 1                              | LEVEL1                                                                                                                                                                            |        | Z-Wave Gateway                         |
|       | 2                              | LEVEL2                                                                                                                                                                            |        | Z-Wave End Device                      |
|       | 3                              | LEVEL3                                                                                                                                                                            |        | Z-Wave Sensor                          |
|       | 4                              | LEVEL4                                                                                                                                                                            |        | Z-Wave Lighting                        |
| 23:22 | <b>Reserved</b>                | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                        |
| 21:20 | SRI                            | 0x0                                                                                                                                                                               | R      | <b>RAIL Capability</b>                 |
|       | RAIL capability not available  |                                                                                                                                                                                   |        |                                        |
|       | Value                          | Mode                                                                                                                                                                              |        | Description                            |
|       | 0                              | LEVEL0                                                                                                                                                                            |        | RAIL capability not available          |
|       | 1                              | LEVEL1                                                                                                                                                                            |        | RAIL enabled                           |
|       | 2                              | LEVEL2                                                                                                                                                                            |        | N/A                                    |
|       | 3                              | LEVEL3                                                                                                                                                                            |        | N/A                                    |
| 19:18 | <b>Reserved</b>                | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                        |
| 17:16 | CONNECT                        | 0x0                                                                                                                                                                               | R      | <b>Connect Capability</b>              |
|       | Connect stack capability level |                                                                                                                                                                                   |        |                                        |
|       | Value                          | Mode                                                                                                                                                                              |        | Description                            |
|       | 0                              | LEVEL0                                                                                                                                                                            |        | Connect stack capability not available |
|       | 1                              | LEVEL1                                                                                                                                                                            |        | Connect enabled                        |
|       | 2                              | LEVEL2                                                                                                                                                                            |        | N/A                                    |
|       | 3                              | LEVEL3                                                                                                                                                                            |        | N/A                                    |

| Bit   | Name     | Reset  | Access | Description                                                                                                                                                                       |
|-------|----------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | Reserved |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13:12 | BTSMART  | 0x0    | R      | <b>Bluetooth Smart Capability</b>                                                                                                                                                 |
|       |          |        |        | Bluetooth SMART stack capability level                                                                                                                                            |
|       | Value    | Mode   |        | Description                                                                                                                                                                       |
|       | 0        | LEVEL0 |        | Bluetooth SMART stack capability not available                                                                                                                                    |
|       | 1        | LEVEL1 |        | Bluetooth SMART enabled                                                                                                                                                           |
|       | 2        | LEVEL2 |        | N/A                                                                                                                                                                               |
|       | 3        | LEVEL3 |        | N/A                                                                                                                                                                               |
| 11:10 | Reserved |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | RF4CE    | 0x0    | R      | <b>RF4CE Capability</b>                                                                                                                                                           |
|       |          |        |        | RF4CE stack capability level                                                                                                                                                      |
|       | Value    | Mode   |        | Description                                                                                                                                                                       |
|       | 0        | LEVEL0 |        | Thread stack capability not available                                                                                                                                             |
|       | 1        | LEVEL1 |        | Thread stack enabled                                                                                                                                                              |
|       | 2        | LEVEL2 |        | N/A                                                                                                                                                                               |
|       | 3        | LEVEL3 |        | N/A                                                                                                                                                                               |
| 7:6   | Reserved |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:4   | THREAD   | 0x0    | R      | <b>Thread Capability</b>                                                                                                                                                          |
|       |          |        |        | Thread stack capability level                                                                                                                                                     |
|       | Value    | Mode   |        | Description                                                                                                                                                                       |
|       | 0        | LEVEL0 |        | RF4CE stack capability not available                                                                                                                                              |
|       | 1        | LEVEL1 |        | RF4CE stack enabled                                                                                                                                                               |
|       | 2        | LEVEL2 |        | N/A                                                                                                                                                                               |
|       | 3        | LEVEL3 |        | N/A                                                                                                                                                                               |
| 3:2   | Reserved |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | ZIGBEE   | 0x0    | R      | <b>Zigbee Capability</b>                                                                                                                                                          |
|       |          |        |        | ZigBee stack capability level                                                                                                                                                     |
|       | Value    | Mode   |        | Description                                                                                                                                                                       |
|       | 0        | LEVEL0 |        | ZigBee stack capability not available                                                                                                                                             |
|       | 1        | LEVEL1 |        | GreenPower only                                                                                                                                                                   |
|       | 2        | LEVEL2 |        | ZigBee and GreenPower                                                                                                                                                             |
|       | 3        | LEVEL3 |        | ZigBee Only                                                                                                                                                                       |

## 6.4.2.9 DEVINFO\_SWCAPA1 - Software Restriction

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |      |      |       |         |         |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|------|------|-------|---------|---------|---|
| 0x020  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     | R    | XOUT | GWEN  | NCPEN   | RFMCUEN |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | R       | R    | R    | R     | R       |         |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | FENOTCH | XOUT | GWEN | NCPEN | RFMCUEN |         |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                       |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 4    | FENOTCH  | 0x0   | R      | <b>FENOTCH</b><br><br>FENOTCH feature available                                                                                                                   |
| 3    | XOUT     | 0x0   | R      | <b>XOUT</b><br><br>XOUT feature available                                                                                                                         |
| 2    | GWEN     | 0x0   | R      | <b>Gateway</b><br><br>Gateway enabled part                                                                                                                        |
| 1    | NCPEN    | 0x0   | R      | <b>NCP</b><br><br>Network co-processor enabled part. NCP only if RFMCUEN = 0                                                                                      |
| 0    | RFMCUEN  | 0x0   | R      | <b>RF-MCU</b><br><br>RF-MCU enabled part. RF-MCU only if NCPEN = 0                                                                                                |

## 6.4.2.10 DEVINFO\_EXTINFO - External Component Info

| Offset | Bit Position |    |    |    |    |    |    |    |     |    |    |    |            |    |    |    |    |    |    |    |      |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|-----|----|----|----|------------|----|----|----|----|----|----|----|------|----|---|---|---|---|---|---|---|---|---|---|
| 0x028  | 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 |
| Reset  |              |    |    |    |    |    |    |    | 0x0 |    |    |    | 0x0        |    |    |    |    |    |    |    | 0x0  |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    | R   |    |    |    | R          |    |    |    |    |    |    |    | R    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    | REV |    |    |    | CONNECTION |    |    |    |    |    |    |    | TYPE |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name                                      | Reset | Access | Description                                                                                                                                                       |
|-------|-------------------------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved                                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 23:16 | REV                                       | 0x0   | R      | <b>Revision</b>                                                                                                                                                   |
|       | MCM Revision                              |       |        |                                                                                                                                                                   |
| 15:8  | CONNECTION                                | 0x0   | R      | <b>Connection</b>                                                                                                                                                 |
|       | Connection protocol to external interface |       |        |                                                                                                                                                                   |
|       | Value                                     | Mode  |        | Description                                                                                                                                                       |
|       | 0                                         | SPI   |        | SPI control interface                                                                                                                                             |
|       | 255                                       | NONE  |        | No interface                                                                                                                                                      |
| 7:0   | TYPE                                      | 0x0   | R      | <b>Type</b>                                                                                                                                                       |
|       | External Component                        |       |        |                                                                                                                                                                   |
|       | Value                                     | Mode  |        | Description                                                                                                                                                       |
|       | 255                                       | NONE  |        |                                                                                                                                                                   |

**6.4.2.11 DEVINFO\_EUI48L - EUI 48 Low**

| Offset | Bit Position |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|--------|--------------|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| 0x040  | 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 |  |  |  |  |  |
| Reset  |              |    |    |    | 0x0 | 0x0 |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    | 0x0 |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| Access | R            |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    | R        |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| Name   | OUI48L       |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    | UNIQUEID |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |

| Bit   | Name     | Reset | Access | Description                                                            |
|-------|----------|-------|--------|------------------------------------------------------------------------|
| 31:24 | OUI48L   | 0x0   | R      | <b>OUI48L</b><br>Lower Octet of EUI48 Organizational Unique Identifier |
| 23:0  | UNIQUEID | 0x0   | R      | <b>Unique ID</b><br>Unique identifier                                  |

**6.4.2.12 DEVINFO\_EUI48H - EUI 48 High**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x044  | 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 |
| Reset  | 0xFFFF       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | RESERVED     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OUI48H |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset  | Access | Description                                    |
|-------|----------|--------|--------|------------------------------------------------|
| 31:16 | RESERVED | 0xFFFF | R      | <b>RESERVED</b><br>Reserved                    |
| 15:0  | OUI48H   | 0x0    | R      | <b>OUI48H</b><br>Upper two Octets of EUI48 OUI |

#### **6.4.2.13 DEVINFO\_EUI64L - EUI64 Low**

| Bit                                      | Name    | Reset | Access | Description    |
|------------------------------------------|---------|-------|--------|----------------|
| 31:0                                     | UNIQUEL | 0x0   | R      | <b>UNIQUEL</b> |
| Lower 32 bits of EUI64 Unique Identifier |         |       |        |                |

#### **6.4.2.14 DEVINFO\_EUI64H - EUI64 High**

| Bit  | Name    | Reset | Access | Description                                               |
|------|---------|-------|--------|-----------------------------------------------------------|
| 31:8 | OUI64   | 0x0   | R      | <b>OUI64</b><br>24-bit OUI identifier                     |
| 7:0  | UNIQUEH | 0x0   | R      | <b>UNIQUEH</b><br>Upper 8 bits of EUI64 unique identifier |

**6.4.2.15 DEVINFO\_CALTEMP - Calibration Temperature**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------|
| 0x050         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |      |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0  |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | R    |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | TEMP |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | TEMP     | 0x0   | R      | <b>Cal Temp</b><br><br>Calibration temperature as an unsigned int in DegC. (0x19 = 25DegC)                                                                                        |

**6.4.2.16 DEVINFO\_EMUTEMP - EMU Temp**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |  |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------|--|
| 0x054         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |  |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0         |  |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | R           |  |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | EMUTEMPROOM |  |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 10:2  | EMUTEMPROOM | 0x0   | R      | <b>Emu Room Temperature</b><br><br>EMU_TEMP temperature reading at room (calibration) temperature.                                                                                |
| 1:0   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 6.4.2.17 DEVINFO\_HFRCODPLLCaln - HFRCODPLL Calibration

| Offset | Bit Position |        |        |         |           |       |            |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|--------|--------|---------|-----------|-------|------------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x058  | 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 |
| Reset  |              | 0x0    |        |         | 0x0       |       |            | 0x0    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            | R      | R      | R       | R         | R     | R          | R      | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R | R | R | R | R | R | R | R |   |   |
| Name   | IREFTC       | CMPSEL | CLKDIV | CMPBIAS | FREQRANGE | LDOHP | FINETUNING | TUNING |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name       | Reset                                                                                                                                                                             | Access | Description                       |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------|
| 31:28 | IREFTC     | 0x0                                                                                                                                                                               | R      | Tempco Trim                       |
| 27:26 | CMPSEL     | 0x0                                                                                                                                                                               | R      | Comparator Load Select            |
| 25:24 | CLKDIV     | 0x0                                                                                                                                                                               | R      | Locally Divide HFRCO Clock Output |
| 23:21 | CMPBIAS    | 0x0                                                                                                                                                                               | R      | Comparator Bias Current           |
| 20:16 | FREQRANGE  | 0x0                                                                                                                                                                               | R      | Frequency Range                   |
| 15    | LDOHP      | 0x0                                                                                                                                                                               | R      | LDO High Power Mode               |
| 14    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                   |
| 13:8  | FINETUNING | 0x0                                                                                                                                                                               | R      | Fine Tuning Value                 |
| 7     | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                   |
| 6:0   | TUNING     | 0x0                                                                                                                                                                               | R      | Tuning Value                      |

## 6.4.2.18 DEVINFO\_HFRCOEM23CALn - HFRCOEM23 Calibration

| Offset | Bit Position |        |        |         |           |       |            |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|--------|--------|---------|-----------|-------|------------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0A0  | 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 |
| Reset  |              | 0x0    |        |         | 0x0       |       |            | 0x0    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            | R      | R      | R       | R         | R     | R          | R      | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R | R | R | R | R | R | R | R |   |   |
| Name   | IREFTC       | CMPSEL | CLKDIV | CMPBIAS | FREQRANGE | LDOHP | FINETUNING | TUNING |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name       | Reset                                                                                                                                                                             | Access | Description                       |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------|
| 31:28 | IREFTC     | 0x0                                                                                                                                                                               | R      | Tempco Trim                       |
| 27:26 | CMPSEL     | 0x0                                                                                                                                                                               | R      | Comparator Load Select            |
| 25:24 | CLKDIV     | 0x0                                                                                                                                                                               | R      | Locally Divide HFRCO Clock Output |
| 23:21 | CMPBIAS    | 0x0                                                                                                                                                                               | R      | Comparator Bias Current           |
| 20:16 | FREQRANGE  | 0x0                                                                                                                                                                               | R      | Frequency Range                   |
| 15    | LDOHP      | 0x0                                                                                                                                                                               | R      | LDO High Power Mode               |
| 14    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                   |
| 13:8  | FINETUNING | 0x0                                                                                                                                                                               | R      | Fine Tuning Value                 |
| 7     | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                   |
| 6:0   | TUNING     | 0x0                                                                                                                                                                               | R      | Tuning Value                      |

**6.4.2.19 DEVINFO\_MODULENAME0 - Module Name Information**

| Offset | Bit Position |    |    |    |          |    |    |    |    |          |    |    |    |    |          |    |    |    |    |          |    |    |   |   |      |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----------|----|----|----|----|----------|----|----|----|----|----------|----|----|----|----|----------|----|----|---|---|------|---|---|---|---|---|---|---|
| 0x130  | 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 |
| Reset  |              |    |    |    | 0xFF     |    |    |    |    | 0xFF     |    |    |    |    | 0xFF     |    |    |    |    | 0xFF     |    |    |   |   | 0xFF |   |   |   |   |   |   |   |
| Access |              |    |    |    | R        |    |    |    |    | R        |    |    |    |    | R        |    |    |    |    | R        |    |    |   |   | R    |   |   |   |   |   |   |   |
| Name   |              |    |    |    | MODCHAR4 |    |    |    |    | MODCHAR3 |    |    |    |    | MODCHAR2 |    |    |    |    | MODCHAR1 |    |    |   |   |      |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                          |
|-------|----------|-------|--------|--------------------------------------------------------------------------------------|
| 31:24 | MODCHAR4 | 0xFF  | R      | Fourth character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 23:16 | MODCHAR3 | 0xFF  | R      | Third character of Module Name, 0xFF = unwritten, 0x00 = character not used in name  |
| 15:8  | MODCHAR2 | 0xFF  | R      | Second character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 7:0   | MODCHAR1 | 0xFF  | R      | First character of Module Name, 0xFF = unwritten, 0x00 = character not used in name  |

**6.4.2.20 DEVINFO\_MODULENAME1 - Module Name Information**

| Offset | Bit Position |    |    |    |          |    |    |    |    |          |    |    |    |    |          |    |    |    |    |          |    |    |   |   |      |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----------|----|----|----|----|----------|----|----|----|----|----------|----|----|----|----|----------|----|----|---|---|------|---|---|---|---|---|---|---|
| 0x134  | 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 |
| Reset  |              |    |    |    | 0xFF     |    |    |    |    | 0xFF     |    |    |    |    | 0xFF     |    |    |    |    | 0xFF     |    |    |   |   | 0xFF |   |   |   |   |   |   |   |
| Access |              |    |    |    | R        |    |    |    |    | R        |    |    |    |    | R        |    |    |    |    | R        |    |    |   |   | R    |   |   |   |   |   |   |   |
| Name   |              |    |    |    | MODCHAR8 |    |    |    |    | MODCHAR7 |    |    |    |    | MODCHAR6 |    |    |    |    | MODCHAR5 |    |    |   |   |      |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                   |
|-------|----------|-------|--------|-------------------------------------------------------------------------------|
| 31:24 | MODCHAR8 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 23:16 | MODCHAR7 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 15:8  | MODCHAR6 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 7:0   | MODCHAR5 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |

## 6.4.2.21 DEVINFO\_MODULENAME2 - Module Name Information

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |          |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----------|---|---|---|
| 0x138  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0xFF     |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | R        |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | MODCHAR9 |   |   |   |

| Bit   | Name      | Reset | Access | Description                                                                   |
|-------|-----------|-------|--------|-------------------------------------------------------------------------------|
| 31:24 | MODCHAR12 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 23:16 | MODCHAR11 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 15:8  | MODCHAR10 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 7:0   | MODCHAR9  | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |

## 6.4.2.22 DEVINFO\_MODULENAME3 - Module Name Information

| Offset | Bit Position |    |    |    |           |    |    |    |    |           |    |    |    |    |    |    |    |           |    |    |    |    |   |   |   |           |   |   |   |   |   |   |
|--------|--------------|----|----|----|-----------|----|----|----|----|-----------|----|----|----|----|----|----|----|-----------|----|----|----|----|---|---|---|-----------|---|---|---|---|---|---|
| 0x13C  | 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 |
| Reset  |              |    |    |    | 0xFF      |    |    |    |    | 0xFF      |    |    |    |    |    |    |    | 0xFF      |    |    |    |    |   |   |   | 0xFF      |   |   |   |   |   |   |
| Access |              |    |    |    | R         |    |    |    |    | R         |    |    |    |    |    |    |    | R         |    |    |    |    |   |   |   | R         |   |   |   |   |   |   |
| Name   |              |    |    |    | MODCHAR16 |    |    |    |    | MODCHAR15 |    |    |    |    |    |    |    | MODCHAR14 |    |    |    |    |   |   |   | MODCHAR13 |   |   |   |   |   |   |

| Bit   | Name      | Reset | Access | Description                                                                   |
|-------|-----------|-------|--------|-------------------------------------------------------------------------------|
| 31:24 | MODCHAR16 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 23:16 | MODCHAR15 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 15:8  | MODCHAR14 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 7:0   | MODCHAR13 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |

## 6.4.2.23 DEVINFO\_MODULENAME4 - Module Name Information

| Offset | Bit Position |           |    |      |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |           |   |   |
|--------|--------------|-----------|----|------|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|----|-----------|----|---|---|---|---|---|---|---|-----------|---|---|
| 0x140  | 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 |
| Reset  |              |           |    | 0xFF |    |    |    |    |    |    |    | 0xFF      |    |    |    |    |    |    |    |    | 0xFF      |    |   |   |   |   |   |   |   |           |   |   |
| Access |              | R         |    |      |    |    |    |    |    |    |    | R         |    |    |    |    |    |    |    |    | R         |    |   |   |   |   |   |   |   | R         |   |   |
| Name   |              | MODCHAR20 |    |      |    |    |    |    |    |    |    | MODCHAR19 |    |    |    |    |    |    |    |    | MODCHAR18 | R  |   |   |   |   |   |   |   | MODCHAR17 | R |   |

| Bit   | Name      | Reset | Access | Description                                                                   |
|-------|-----------|-------|--------|-------------------------------------------------------------------------------|
| 31:24 | MODCHAR20 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 23:16 | MODCHAR19 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 15:8  | MODCHAR18 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 7:0   | MODCHAR17 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |

**6.4.2.24 DEVINFO\_MODULENAME5 - Module Name Information**

| Offset | Bit Position |    |    |    |           |    |    |    |    |           |    |    |    |    |    |    |    |           |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|-----------|----|----|----|----|-----------|----|----|----|----|----|----|----|-----------|----|----|----|----|---|---|---|-----------|---|---|---|---|---|---|--|
| 0x144  | 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 |  |
| Reset  |              |    |    |    | 0xFF      |    |    |    |    | 0xFF      |    |    |    |    |    |    |    | 0xFF      |    |    |    |    |   |   |   | 0xFF      |   |   |   |   |   |   |  |
| Access |              |    |    |    | R         |    |    |    |    | R         |    |    |    |    |    |    |    | R         |    |    |    |    |   |   |   | R         |   |   |   |   |   |   |  |
| Name   |              |    |    |    | MODCHAR24 |    |    |    |    | MODCHAR23 |    |    |    |    |    |    |    | MODCHAR22 |    |    |    |    |   |   |   | MODCHAR21 |   |   |   |   |   |   |  |

| Bit   | Name      | Reset | Access | Description                                                                   |
|-------|-----------|-------|--------|-------------------------------------------------------------------------------|
| 31:24 | MODCHAR24 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 23:16 | MODCHAR23 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 15:8  | MODCHAR22 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |
| 7:0   | MODCHAR21 | 0xFF  | R      | Character of Module Name, 0xFF = unwritten, 0x00 = character not used in name |

**6.4.2.25 DEVINFO\_MODULENAME6 - Module Name Information**

| Offset | Bit Position |    |    |    |        |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|--------|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|---|---|-----------|---|---|---|---|---|---|---|
| 0x148  | 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 |
| Reset  |              |    |    |    | 0xFFFF |    |    |    |    |    |    |    |    |    |    |    | 0xFF      |    |    |    |    |    |   |   | 0xFF      |   |   |   |   |   |   |   |
| Access |              |    |    |    | R      |    |    |    |    |    |    |    |    |    |    |    | R         |    |    |    |    |    |   |   | R         |   |   |   |   |   |   |   |
| Name   |              |    |    |    | RSV    |    |    |    |    |    |    |    |    |    |    |    | MODCHAR26 |    |    |    |    |    |   |   | MODCHAR25 |   |   |   |   |   |   |   |

| Bit   | Name      | Reset  | Access | Description                                                                                 |
|-------|-----------|--------|--------|---------------------------------------------------------------------------------------------|
| 31:16 | RSV       | 0xFFFF | R      | Reserved for future use                                                                     |
| 15:8  | MODCHAR26 | 0xFF   | R      | Last possible character of module name, 0xFF = unwritten, 0x00 = character not used in name |
| 7:0   | MODCHAR25 | 0xFF   | R      | 0xFF = unwritten, 0x00 = character not used in name                                         |

#### **6.4.2.26 DEVINFO\_MODULEINFO - Module Information**

| Bit   | Name         | Reset       | Access | Description                                                                                                                                                                                                           |       |      |             |   |         |  |   |           |  |
|-------|--------------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|---------|--|---|-----------|--|
| 31    | EXTVALID     | 0x1         | R      | EXTINFO entry used                                                                                                                                                                                                    |       |      |             |   |         |  |   |           |  |
|       |              |             |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>EXTUSED</td><td></td></tr> <tr> <td>1</td><td>EXTUNUSED</td><td></td></tr> </tbody> </table> | Value | Mode | Description | 0 | EXTUSED |  | 1 | EXTUNUSED |  |
| Value | Mode         | Description |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 0     | EXTUSED      |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 1     | EXTUNUSED    |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 30    | PHYLIMITED   | 0x1         | R      | PHY Limited                                                                                                                                                                                                           |       |      |             |   |         |  |   |           |  |
|       |              |             |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>LIMITED</td><td></td></tr> <tr> <td>1</td><td>UNLIMITED</td><td></td></tr> </tbody> </table> | Value | Mode | Description | 0 | LIMITED |  | 1 | UNLIMITED |  |
| Value | Mode         | Description |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 0     | LIMITED      |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 1     | UNLIMITED    |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 29    | PADCDC       | 0x1         | R      | PAVDD Connection                                                                                                                                                                                                      |       |      |             |   |         |  |   |           |  |
|       |              |             |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>VDCDC</td><td></td></tr> <tr> <td>1</td><td>OTHER</td><td></td></tr> </tbody> </table>       | Value | Mode | Description | 0 | VDCDC   |  | 1 | OTHER     |  |
| Value | Mode         | Description |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 0     | VDCDC        |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 1     | OTHER        |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 28:20 | MODNUMBERMSB | 0x1FF       | R      | Counter allowing unique identification of module per lookup when combined with MODNUMBER                                                                                                                              |       |      |             |   |         |  |   |           |  |
| 19    | HFXOCALVAL   | 0x1         | R      | HFXO Factory Calibrated                                                                                                                                                                                               |       |      |             |   |         |  |   |           |  |
|       |              |             |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>VALID</td><td></td></tr> <tr> <td>1</td><td>NOTVALID</td><td></td></tr> </tbody> </table>    | Value | Mode | Description | 0 | VALID   |  | 1 | NOTVALID  |  |
| Value | Mode         | Description |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 0     | VALID        |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 1     | NOTVALID     |             |        |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |
| 18    | LFXOCALVAL   | 0x1         | R      |                                                                                                                                                                                                                       |       |      |             |   |         |  |   |           |  |

| Bit                     | Name      | Reset     | Access | Description                                                                                  |
|-------------------------|-----------|-----------|--------|----------------------------------------------------------------------------------------------|
| LFXO Factory Calibrated |           |           |        |                                                                                              |
|                         | Value     | Mode      |        | Description                                                                                  |
|                         | 0         | VALID     |        |                                                                                              |
|                         | 1         | NOTVALID  |        |                                                                                              |
| 17                      | EXPRESS   | 0x1       | R      | Blue Gecko Express                                                                           |
|                         |           |           |        |                                                                                              |
|                         | Value     | Mode      |        | Description                                                                                  |
|                         | 0         | SUPPORTED |        |                                                                                              |
|                         | 1         | NONE      |        |                                                                                              |
| 16                      | LFXO      | 0x1       | R      | Module has LFXO                                                                              |
|                         |           |           |        |                                                                                              |
|                         | Value     | Mode      |        | Description                                                                                  |
|                         | 0         | NONE      |        |                                                                                              |
|                         | 1         | PRESENT   |        |                                                                                              |
| 15                      | TYPE      | 0x1       | R      | Module Type                                                                                  |
|                         |           |           |        |                                                                                              |
|                         | Value     | Mode      |        | Description                                                                                  |
|                         | 0         | PCB       |        |                                                                                              |
|                         | 1         | SIP       |        |                                                                                              |
| 14:8                    | MODNUMBER | 0x7F      | R      | Counter allowing unique identification of module per lookup when combined with MODNUMBER MSB |
|                         |           |           |        |                                                                                              |
| 7:5                     | ANTENNA   | 0x7       | R      | Module Antenna Type                                                                          |
|                         |           |           |        |                                                                                              |
|                         | Value     | Mode      |        | Description                                                                                  |
|                         | 0         | BUILTIN   |        | None                                                                                         |
|                         | 1         | CONNECTOR |        |                                                                                              |
|                         | 2         | RFPAD     |        |                                                                                              |
|                         | 3         | INVERTEDF |        |                                                                                              |
| 4:0                     | HWREV     | 0x1F      | R      | Module Hardware Revision. Starting from 0                                                    |
|                         |           |           |        |                                                                                              |

**6.4.2.27 DEVINFO\_MODXOCAL - Module External Oscillator Calibration Information**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------------|
| Reset  | 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 |  |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LFXOCAPTUNE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | HFXOCTUNEXOANA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | HFXOCTUNEXIANA |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 22:16 | LFXOCAPTUNE    | 0x7F  | R      | LFXO Cap Tuning                                                                                                                                                                   |
| 15:8  | HFXOCTUNEXOANA | 0xFF  | R      | Tuning capacitance on XO                                                                                                                                                          |
| 7:0   | HFXOCTUNEXIANA | 0xFF  | R      | Tuning capacitance on XI                                                                                                                                                          |

**6.4.2.28 DEVINFO\_IADC0GAIN0 - IADC Gain Calibration**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---|
| Reset  | 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 |   |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GAINCANA2 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   | GAINCANA1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | R |

| Bit   | Name      | Reset | Access | Description              |
|-------|-----------|-------|--------|--------------------------|
| 31:16 | GAINCANA2 | 0x0   | R      | Input Gain = 2x          |
| 15:0  | GAINCANA1 | 0x0   | R      | Input Gain = 1x and 0.5x |

**6.4.2.29 DEVINFO\_IADC0GAIN1 - IADC Gain Calibration**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| Reset  | 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 |  |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0       | R  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | GAINCANA4    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GAINCANA3 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name      | Reset | Access | Description     |
|-------|-----------|-------|--------|-----------------|
| 31:16 | GAINCANA4 | 0x0   | R      | Input Gain = 4x |
| 15:0  | GAINCANA3 | 0x0   | R      | Input Gain = 3x |
|       |           |       |        |                 |

**6.4.2.30 DEVINFO\_IADC0OFFSETCAL0 - IADC Offset Calibration**

| Offset | Bit Position    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| Reset  | 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 |  |
| Access | R               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0           | R  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | OFFSETANA1HIACC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | OFFSETANABASE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|        |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name            | Reset | Access | Description                       |
|-------|-----------------|-------|--------|-----------------------------------|
| 31:16 | OFFSETANA1HIACC | 0x0   | R      | High-accuracy OSR adjustment term |
| 15:0  | OFFSETANABASE   | 0x0   | R      | Base analog offset term           |

**6.4.2.31 DEVINFO\_IADC0NORMALOFFSETCAL0 - IADC Offset Calibration**

| Offset | Bit Position   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                |
|--------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|----------------|
| 0x18C  | 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 |  |  |  |  |  |                |
| Reset  | 0x0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                |
| Access | R              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                |
| Name   | OFFSETANA2NORM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  | OFFSETANA1NORM |

| Bit   | Name           | Reset | Access | Description                                         |
|-------|----------------|-------|--------|-----------------------------------------------------|
| 31:16 | OFFSETANA2NORM | 0x0   | R      | Normal mode offset gain adjustment term             |
| 15:0  | OFFSETANA1NORM | 0x0   | R      | Normal mode analog offset term at OSR=2x, gain = 1x |
|       |                |       |        |                                                     |

**6.4.2.32 DEVINFO\_IADC0NORMALOFFSETCAL1 - IADC Offset Calibration**

| Offset | Bit Position   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                |
|--------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|----------------|
| 0x190  | 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 |  |  |  |  |  |                |
| Reset  | 0x0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                |
| Access | R              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                |
| Name   | OFFSETANA3NORM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  | OFFSETANA1NORM |

| Bit   | Name           | Reset                                                                                                                                                                      | Access | Description                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:16 | Reserved       | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:0  | OFFSETANA3NORM | 0x0                                                                                                                                                                        | R      | Normal mode offset term for OSR>=4x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**6.4.2.33 DEVINFO\_IADC0HISPDOFFSETCAL0 - IADC Offset Calibration**

| Offset | Bit Position    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                 |
|--------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|-----------------|
| 0x194  | 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 |  |  |  |  |  |                 |
| Reset  | 0x0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                 |
| Access | R               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                 |
| Name   | OFFSETANA2HISPD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  | OFFSETANA1HISPD |

| Bit   | Name            | Reset | Access | Description                                             |
|-------|-----------------|-------|--------|---------------------------------------------------------|
| 31:16 | OFFSETANA2HISPD | 0x0   | R      | High speed mode offset gain adjustment term             |
| 15:0  | OFFSETANA1HISPD | 0x0   | R      | High speed mode analog offset term at OSR=2x, gain = 1x |

**6.4.2.34 DEVINFO\_IADC0HISPDOFFSETCAL1 - IADC Offset Calibration**

| Offset | Bit Position    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                 |
|--------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|-----------------|
| 0x198  | 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 |  |  |  |  |  |                 |
| Reset  | 0x0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                 |
| Access | R               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |                 |
| Name   | OFFSETANA3HISPD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  | OFFSETANA1HISPD |

| Bit   | Name            | Reset                                                                                                                                                                      | Access | Description                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:16 | Reserved        | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:0  | OFFSETANA3HISPD | 0x0                                                                                                                                                                        | R      | High-speed mode offset term for OSR>=4x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 6.4.2.35 DEVINFO\_LEGACY - Legacy Device Info

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x1FC  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    | 0x80         |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    | R            |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | DEVICEFAMILY |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name          | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:16 | DEVICEFAMILY  | 0x80  | R      | <b>Device Family</b>                                                                                                                                                              |
|       | Device Family |       |        |                                                                                                                                                                                   |
| Value | Mode          |       |        | Description                                                                                                                                                                       |
| 16    | EFR32MG1P     |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 1                                                                                                                                |
| 17    | EFR32MG1B     |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 1                                                                                                                                |
| 18    | EFR32MG1V     |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 1                                                                                                                                |
| 19    | EFR32BG1P     |       |        | EFR32 Blue Gecko Family Series 1 Device Config 1                                                                                                                                  |
| 20    | EFR32BG1B     |       |        | EFR32 Blue Gecko Family Series 1 Device Config 1                                                                                                                                  |
| 21    | EFR32BG1V     |       |        | EFR32 Blue Gecko Family Series 1 Device Config 1                                                                                                                                  |
| 25    | EFR32FG1P     |       |        | EFR32 Flex Gecko Family Series 1 Device Config 1                                                                                                                                  |
| 26    | EFR32FG1B     |       |        | EFR32 Flex Gecko Family Series 1 Device Config 1                                                                                                                                  |
| 27    | EFR32FG1V     |       |        | EFR32 Flex Gecko Family Series 1 Device Config 1                                                                                                                                  |
| 28    | EFR32MG12P    |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 2                                                                                                                                |
| 29    | EFR32MG12B    |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 2                                                                                                                                |
| 30    | EFR32MG12V    |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 2                                                                                                                                |
| 31    | EFR32BG12P    |       |        | EFR32 Blue Gecko Family Series 1 Device Config 2                                                                                                                                  |
| 32    | EFR32BG12B    |       |        | EFR32 Blue Gecko Family Series 1 Device Config 2                                                                                                                                  |
| 33    | EFR32BG12V    |       |        | EFR32 Blue Gecko Family Series 1 Device Config 2                                                                                                                                  |
| 37    | EFR32FG12P    |       |        | EFR32 Flex Gecko Family Series 1 Device Config 2                                                                                                                                  |
| 38    | EFR32FG12B    |       |        | EFR32 Flex Gecko Family Series 1 Device Config 2                                                                                                                                  |
| 39    | EFR32FG12V    |       |        | EFR32 Flex Gecko Family Series 1 Device Config 2                                                                                                                                  |
| 40    | EFR32MG13P    |       |        | EFR32 Mighty Gecko Family Series 13 Device Config 3                                                                                                                               |
| 41    | EFR32MG13B    |       |        | EFR32 Mighty Gecko Family Series 13 Device Config 3                                                                                                                               |
| 42    | EFR32MG13V    |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 3                                                                                                                                |
| 43    | EFR32BG13P    |       |        | EFR32 Blue Gecko Family Series 1 Device Config 3                                                                                                                                  |

| Bit  | Name       | Reset | Access | Description                                                                                                                                                                       |
|------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 44   | EFR32BG13B |       |        | EFR32 Blue Gecko Family Series 1 Device Config 3                                                                                                                                  |
| 45   | EFR32BG13V |       |        | EFR32 Blue Gecko Family Series 1 Device Config 3                                                                                                                                  |
| 49   | EFR32FG13P |       |        | EFR32 Flex Gecko Family Series 1 Device Config 3                                                                                                                                  |
| 50   | EFR32FG13B |       |        | EFR32 Flex Gecko Family Series 1 Device Config 3                                                                                                                                  |
| 51   | EFR32FG13V |       |        | EFR32 Flex Gecko Family Series 1 Device Config 3                                                                                                                                  |
| 52   | EFR32MG14P |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 4                                                                                                                                |
| 53   | EFR32MG14B |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 4                                                                                                                                |
| 54   | EFR32MG14V |       |        | EFR32 Mighty Gecko Family Series 1 Device Config 4                                                                                                                                |
| 55   | EFR32BG14P |       |        | EFR32 Blue Gecko Family Series 1 Device Config 4                                                                                                                                  |
| 56   | EFR32BG14B |       |        | EFR32 Blue Gecko Family Series 1 Device Config 4                                                                                                                                  |
| 57   | EFR32BG14V |       |        | EFR32 Blue Gecko Family Series 1 Device Config 4                                                                                                                                  |
| 61   | EFR32FG14P |       |        | EFR32 Flex Gecko Family Series 1 Device Config 4                                                                                                                                  |
| 62   | EFR32FG14B |       |        | EFR32 Flex Gecko Family Series 1 Device Config 4                                                                                                                                  |
| 63   | EFR32FG14V |       |        | EFR32 Flex Gecko Family Series 1 Device Config 4                                                                                                                                  |
| 71   | EFM32G     |       |        | EFM32 Gecko Device Family                                                                                                                                                         |
| 72   | EFM32GG    |       |        | EFM32 Giant Gecko Device Family                                                                                                                                                   |
| 73   | EFM32TG    |       |        | EFM32 Tiny Gecko Device Family                                                                                                                                                    |
| 74   | EFM32LG    |       |        | EFM32 Leopard Gecko Device Family                                                                                                                                                 |
| 75   | EFM32WG    |       |        | EFM32 Wonder Gecko Device Family                                                                                                                                                  |
| 76   | EFM32ZG    |       |        | EFM32 Zero Gecko Device Family                                                                                                                                                    |
| 77   | EFM32HG    |       |        | EFM32 Happy Gecko Device Family                                                                                                                                                   |
| 81   | EFM32PG1B  |       |        | EFM32 Pearl Gecko Device Family Series 1 Device Config 1                                                                                                                          |
| 83   | EFM32JG1B  |       |        | EFM32 Jade Gecko Device Family Series 1 Device Config 1                                                                                                                           |
| 85   | EFM32PG12B |       |        | EFM32 Pearl Gecko Device Family Series 1 Device Config 2                                                                                                                          |
| 87   | EFM32JG12B |       |        | EFM32 Jade Gecko Device Family Series 1 Device Config 2                                                                                                                           |
| 89   | EFM32PG13B |       |        | EFM32 Pearl Gecko Device Family Series 1 Device Config 3                                                                                                                          |
| 91   | EFM32JG13B |       |        | EFM32 Jade Gecko Device Family Series 1 Device Config 3                                                                                                                           |
| 100  | EFM32GG11B |       |        | EFM32 Giant Gecko Device Family Series 1 Device Config 1                                                                                                                          |
| 103  | EFM32TG11B |       |        | EFM32 Giant Gecko Device Family Series 1 Device Config 1                                                                                                                          |
| 120  | EZR32LG    |       |        | EZR32 Leopard Gecko Device Family                                                                                                                                                 |
| 121  | EZR32WG    |       |        | EZR32 Wonder Gecko Device Family                                                                                                                                                  |
| 122  | EZR32HG    |       |        | EZR32 Happy Gecko Device Family                                                                                                                                                   |
| 128  | SERIES2V0  |       |        | DI page is encoded with the series 2 layout. Check alternate location.                                                                                                            |
| 15:0 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**6.4.2.36 DEVINFO\_RTHERM - Thermistor Calibration**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| 0x25C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0    |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R      |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RTHERM |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | RTHERM   | 0x0   | R      | Calibrated Thermistor Resistor                                                                                                                                                    |

**6.4.2.37 DEVINFO\_FENOTCHCAL - FENOTCH Calibration**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------------|---|---|---|---|---|---|---|
| 0x264         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0xF            |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R              |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | FENOTCHCAPFINE |   |   |   |   |   |   |   |

| Bit  | Name           | Reset | Access | Description                                                                                                                                                                       |
|------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:4  | FENOTCHCAPFINE | 0xF   | R      | <b>Cap Fine</b><br>FENOTCH Cap Fine Trim                                                                                                                                          |
| 3:0  | FENOTCHCAPCRSE | 0xF   | R      | <b>Cap Coarse</b><br>FENOTCH Cap Coarse Trim                                                                                                                                      |

## 6.5 ICACHE - Instruction Cache

The ICACHE provides fast access to recently executed instructions, improving both speed and power consumption of code execution. The instruction cache is enabled by default, but can be disabled by setting CACHEDIS in ICACHE\_CTRL. When enabled, the instruction cache typically reduces the number of flash reads significantly, thus saving energy. In most cases, a cache hit-rate of more than 70 % is achievable. When a 32-bit instruction fetch hits in the cache, the data is returned to the processor in one clock cycle, bypassing the flash access wait-states. The cache content is retained in EM2 and EM3.

The instruction cache is connected directly to the CODE bus on the ARM core and functions as a memory access filter between the processor and the memory system, as illustrated in [Figure 6.1 Instruction Cache Block Diagram on page 90](#). The cache consists of an access filter, lookup logic, SRAM, and three performance counters. The access filter checks if a transfer is an instruction fetch located in a cacheable region. If it is the cache lookup logic and SRAM is enabled. Otherwise, the cache is bypassed and the access is forwarded to the memory system. If lookup is enabled data is either returned from the cache (hit) or fetch from the memory system and cached (miss).



**Figure 6.1. Instruction Cache Block Diagram**

Note that while all access to code spaces use the CODE bus only instruction fetches are cached. Data accesses to the CODE region are passed through the ICACHE.

### 6.5.1 Cache Operation

It is highly recommended to keep the cache enabled. To improve cache-efficiency, sections of code with very low cache hit rate should not be cached. This is achieved by placing these code sections in non-cacheable MPU regions and setting USEMPU in ICACHE\_CTRL. When USEMPU is set, instruction fetches to non-cacheable MPU regions will not be looked up or saved in cache. This feature may also be used to avoid instructions from low-power memory taking up space from more power-hungry memory. For more information on the MPU see the ARM Cortex®-M33 MPU documentation.

The optional loop-cache is optimized to store smaller code-loops efficiently. The loop-cache is enabled when LPLEVEL in ICACHE\_LPMODE is set to ADVANCED or MINACTIVITY. The difference between the two settings is that when MINACTIVITY is selected loop-cache outputs may be gated off to reduce power at the cost of more wait-states due to loop-cache misses. Having LPLEVEL set to BASIC disables the loop-cache functionality completely. NESTFACTOR in ICACHE\_LPMODE is used to decide when to stick with the currently detected loop rather than start tracking a new loop. Optimal value will depend on the actual code running, meaning that this setting may be tuned for optimal performance.

By default, the instruction cache is automatically invalidated when the contents of the flash are changed (i.e. written or erased). In many cases, however, the application only makes changes to data in the flash, not code. In this case, the automatic invalidate feature can be disabled by setting AUTOFLUSHDIS in ICACHE\_CTRL. The cache can also be manually invalidated by writing 1 to FLUSH in ICACHE\_CMD.

In the event that a parity error in the cache is detected, the RAMERROR flag will be set in ICACHE\_IF. The data is automatically reloaded when this occurs so no action is required by software. This flag is informational only and can be used to detect the rate of corruption events. If RAMERROR in ICACHE\_IEN is set, an interrupt will be triggered.

The cache is automatically flushed whenever a bus fault occurs. If this occurs during performance counting the counts will be effected.

### 6.5.2 Performance Measurement

To measure the hit-rate of a code-section, the built-in performance counters can be used. Before the section, start the performance counters by setting STARTPC in ICACHE\_CMD register. This starts the performance counters, counting from 0. At the end of the section, stop the performance counters by setting STOPPC in ICACHE\_CMD. The number of cache hits and cache misses for that section can then be read from PCHITS and PCMISSSES. The cache hit-ratio can be calculated as PCHITS / (PCHITS + PCMISSSES). PCAHITS contains the loopcache hits only. Any hits in PCAHITS are also counted in PCHITS. The loopcache hit-ratio can be calculated as PCAHITS / (PCHITS + PCMISSSES). When PCHITS/PCAHCITS/PCMISSSES overflow, the HITOF/AHITOF/MISOF interrupt flags are set respectively. These flags must be cleared by software. The range of the performance counters can be extended by increasing a counter in the interrupt routine. The performance counters only count when a cache lookup is performed. Access to non-cacheable regions, data fetches, and access made while the ICACHE is disabled do not increment PCMISSSES.

Software may check if the performance counters are running using PCRUNNING in ICACHE\_STATUS.

### 6.5.3 ICACHE Register Map

The offset register address is relative to the registers base address.

| Offset | Name                 | Type        | Description                       |
|--------|----------------------|-------------|-----------------------------------|
| 0x000  | ICACHE_IPVERSION     | R           | IP Version                        |
| 0x004  | ICACHE_CTRL          | RW          | Control Register                  |
| 0x008  | ICACHE_PCHITS        | RH          | Performance Counter Hits          |
| 0x00C  | ICACHE_PCMISSES      | RH          | Performance Counter Misses        |
| 0x010  | ICACHE_PCAHITS       | RH          | Performance Counter Advanced Hits |
| 0x014  | ICACHE_STATUS        | RH          | Status Register                   |
| 0x018  | ICACHE_CMD           | W           | Command Register                  |
| 0x01C  | ICACHE_LPMODE        | RW          | Low Power Mode                    |
| 0x020  | ICACHE_IF            | RWH INTFLAG | Interrupt Flag                    |
| 0x024  | ICACHE_IEN           | RW          | Interrupt Enable                  |
| 0x1000 | ICACHE_IPVERSION_SET | R           | IP Version                        |
| 0x1004 | ICACHE_CTRL_SET      | RW          | Control Register                  |
| 0x1008 | ICACHE_PCHITS_SET    | RH          | Performance Counter Hits          |
| 0x100C | ICACHE_PCMISSES_SET  | RH          | Performance Counter Misses        |
| 0x1010 | ICACHE_PCAHITS_SET   | RH          | Performance Counter Advanced Hits |
| 0x1014 | ICACHE_STATUS_SET    | RH          | Status Register                   |
| 0x1018 | ICACHE_CMD_SET       | W           | Command Register                  |
| 0x101C | ICACHE_LPMODE_SET    | RW          | Low Power Mode                    |
| 0x1020 | ICACHE_IF_SET        | RWH INTFLAG | Interrupt Flag                    |
| 0x1024 | ICACHE_IEN_SET       | RW          | Interrupt Enable                  |
| 0x2000 | ICACHE_IPVERSION_CLR | R           | IP Version                        |
| 0x2004 | ICACHE_CTRL_CLR      | RW          | Control Register                  |
| 0x2008 | ICACHE_PCHITS_CLR    | RH          | Performance Counter Hits          |
| 0x200C | ICACHE_PCMISSES_CLR  | RH          | Performance Counter Misses        |
| 0x2010 | ICACHE_PCAHITS_CLR   | RH          | Performance Counter Advanced Hits |
| 0x2014 | ICACHE_STATUS_CLR    | RH          | Status Register                   |
| 0x2018 | ICACHE_CMD_CLR       | W           | Command Register                  |
| 0x201C | ICACHE_LPMODE_CLR    | RW          | Low Power Mode                    |
| 0x2020 | ICACHE_IF_CLR        | RWH INTFLAG | Interrupt Flag                    |
| 0x2024 | ICACHE_IEN_CLR       | RW          | Interrupt Enable                  |
| 0x3000 | ICACHE_IPVERSION_TGL | R           | IP Version                        |
| 0x3004 | ICACHE_CTRL_TGL      | RW          | Control Register                  |
| 0x3008 | ICACHE_PCHITS_TGL    | RH          | Performance Counter Hits          |
| 0x300C | ICACHE_PCMISSES_TGL  | RH          | Performance Counter Misses        |
| 0x3010 | ICACHE_PCAHITS_TGL   | RH          | Performance Counter Advanced Hits |

| Offset | Name               | Type        | Description      |
|--------|--------------------|-------------|------------------|
| 0x3014 | ICACHE_STATUS_TGL  | RH          | Status Register  |
| 0x3018 | ICACHE_CMD_TGL     | W           | Command Register |
| 0x301C | ICACHE_LP MODE_TGL | RW          | Low Power Mode   |
| 0x3020 | ICACHE_IF_TGL      | RWH INTFLAG | Interrupt Flag   |
| 0x3024 | ICACHE_IEN_TGL     | RW          | Interrupt Enable |

#### 6.5.4 ICACHE Register Description

##### 6.5.4.1 ICACHE\_IPVERSION - IP Version

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                               |
|------|-----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | IPVERSION | 0x0   | R      | <b>IP version ID</b><br><br>The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |

**6.5.4.2 ICACHE\_CTRL - Control Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |     |   |  |  |    |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|-----|---|--|--|----|-----|---|
| 0x004         | 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   |     |   |  |  |    |     |   |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0 | 2   |   |  |  |    |     |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW  | 0x0 | 1 |  |  |    |     |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |     |   |  |  | RW | 0x0 | 0 |

| Bit  | Name            | Reset                                                           | Access | Description                                                                                                                                                                       |
|------|-----------------|-----------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | <i>Reserved</i> |                                                                 |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2    | AUTOFLUSHDIS    | 0x0                                                             | RW     | <b>Automatic Flushing Disable</b>                                                                                                                                                 |
|      |                 | Disables automatic flushing based on Internal Flash write/erase |        |                                                                                                                                                                                   |
| 1    | USEMPU          | 0x0                                                             | RW     | <b>Use MPU</b>                                                                                                                                                                    |
|      |                 | Use MPU to select non/cacheable regions                         |        |                                                                                                                                                                                   |
| 0    | CACHEDIS        | 0x0                                                             | RW     | <b>Cache Disable</b>                                                                                                                                                              |
|      |                 | Disables caching for all regions                                |        |                                                                                                                                                                                   |

**6.5.4.3 ICACHE\_PCHITS - Performance Counter Hits**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------|---|---|---|
| 0x008         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0    |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | R      |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | PCHITS |   |   |   |

| Bit  | Name   | Reset             | Access | Description                     |
|------|--------|-------------------|--------|---------------------------------|
| 31:0 | PCHITS | 0x0               | R      | <b>Performance Counter Hits</b> |
|      |        | Hit counter value |        |                                 |

**6.5.4.4 ICACHE\_PCMISSES - Performance Counter Misses**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x00C  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | PCMISSES     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name               | Reset | Access | Description                       |
|------|--------------------|-------|--------|-----------------------------------|
| 31:0 | PCMISSES           | 0x0   | R      | <b>Performance Counter Misses</b> |
|      | Miss counter value |       |        |                                   |

**6.5.4.5 ICACHE\_PCAHITS - Performance Counter Advanced Hits**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x010  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | PCAHTS       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name                                                                                                  | Reset | Access | Description                              |
|------|-------------------------------------------------------------------------------------------------------|-------|--------|------------------------------------------|
| 31:0 | PCAHTS                                                                                                | 0x0   | R      | <b>Performance Counter Advanced Hits</b> |
|      | Hit counter value for hits due to Advanced Buffering mode. These hits are also represented in PCHITS. |       |        |                                          |

**6.5.4.6 ICACHE\_STATUS - Status Register**

| Offset    | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|-----------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 0x014     | 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 |  |  |  |
| Reset     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Access    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| PCRUNNING |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                       |
|------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | PCRUNNING | 0x0   | R      | <b>PC Running</b><br><br>Performance Counters are running                                                                                                                         |

**6.5.4.7 ICACHE\_CMD - Command Register**

| Offset  | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|---------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x018   | 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 |  |  |
| Reset   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Access  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Name    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| STOPPC  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| STARTPC |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| FLUSH   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2    | STOPPC   | 0x0   | W(nB)  | <b>Stop Performance Counters</b><br><br>Stops the Performance Counters                                                                                                            |
| 1    | STARTPC  | 0x0   | W(nB)  | <b>Start Performance Counters</b><br><br>Starts the Performance Counters                                                                                                          |
| 0    | FLUSH    | 0x0   | W(nB)  | <b>Flush</b><br><br>Clears Cached Data                                                                                                                                            |

## 6.5.4.8 ICACHE\_LPMODE - Low Power Mode

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |         |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|---------|--|
| 0x01C  | 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 |  |  |         |  |
| Reset  | 0x2          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |         |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |         |  |
| Name   | NESTFACTOR   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  | LPLEVEL |  |

| Bit   | Name        | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Description                                                                                                                                                                                                                                                          |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8  | Reserved    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                    |
| 7:4   | NESTFACTOR  | 0x2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW     | <b>Low Power Nest Factor</b><br><br>Parameter used in the advanced buffering mode to control its estimation when a branch access is likely to be accessed in the near future. In general, a higher number will improve performance in code with deeply nested loops. |
| 3:2   | Reserved    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                    |
| 1:0   | LPLEVEL     | 0x3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW     | <b>Low Power Level</b><br><br>Controls the low-power level of the cache. In general, the default setting is best for most applications.                                                                                                                              |
| Value | Mode        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |                                                                                                                                                                                                                                                                      |
| 0     | BASIC       | Base instruction cache functionality                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |                                                                                                                                                                                                                                                                      |
| 1     | ADVANCED    | Advanced buffering mode, where the cache uses the fetch pattern to predict highly accessed data and store it in low-energy memory                                                                                                                                                                                                                                                                                                                                                                                                                                     |        |                                                                                                                                                                                                                                                                      |
| 3     | MINACTIVITY | Minimum activity mode, which allows the cache to minimize activity in logic that it predicts has a low probability being used. This mode can introduce wait-states into the instruction fetch stream when the cache exits one of its low-activity states. The number of wait-states introduced is small, but users running with 0-wait-state memory and wishing to reduce the variability that the cache might introduce with additional wait-states may wish to lower the cache low-power level. Note, this mode includes the advanced buffering mode functionality. |        |                                                                                                                                                                                                                                                                      |

## 6.5.4.9 ICACHE\_IF - Interrupt Flag

| Offset   | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |        |        |       |     |     |   |   |
|----------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|--------|-------|-----|-----|---|---|
| 0x020    | 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 |
| Reset    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0    | 0x0    | 0x0   | 0x0 | 0x0 |   |   |
| Access   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW     | RW     | RW    | RW  | RW  |   |   |
| Name     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | AHITOF | MISSOF | HITOF |     |     |   |   |
| RAMERROR |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |        |        |       |     |     |   |   |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                                                        |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------|
| 31:9 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                    |
| 8    | RAMERROR | 0x0                                                                                                                                                                               | RW     | <b>RAM error Interrupt Flag</b><br><br>RAM parity error detected                                   |
| 7:3  | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                    |
| 2    | AHITOF   | 0x0                                                                                                                                                                               | RW     | <b>Advanced Hit Overflow Interrupt Flag</b><br><br>Advanced hit performance counter has overflowed |
| 1    | MISSOF   | 0x0                                                                                                                                                                               | RW     | <b>Miss Overflow Interrupt Flag</b><br><br>Miss performance counter has overflowed                 |
| 0    | HITOF    | 0x0                                                                                                                                                                               | RW     | <b>Hit Overflow Interrupt Flag</b><br><br>Hit performance counter has overflowed                   |

**6.5.4.10 ICACHE\_IEN - Interrupt Enable**

| Offset   | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |        |       |   |   |
|----------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------|--------|-------|---|---|
| 0x024    | 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 |
| Reset    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0    | 0x0    | 0x0   |   |   |
| Access   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW     | RW     | RW    |   |   |
| Name     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | AHITOF | MISSOF | HITOF |   |   |
| RAMERROR |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |        |       |   |   |

| Bit  | Name     | Reset                                                                                                                                                                      | Access | Description                                                                  |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------|
| 31:9 | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                              |
| 8    | RAMERROR | 0x0                                                                                                                                                                        | RW     | <b>RAM error Interrupt Enable</b><br><br>Enable RAMERROR interrupt           |
| 7:3  | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                              |
| 2    | AHITOF   | 0x0                                                                                                                                                                        | RW     | <b>Advanced Hit Overflow Interrupt Enable</b><br><br>Enable AHITOF interrupt |
| 1    | MISSOF   | 0x0                                                                                                                                                                        | RW     | <b>Miss Overflow Interrupt Enable</b><br><br>Enable MISSOF interrupt         |
| 0    | HITOF    | 0x0                                                                                                                                                                        | RW     | <b>Hit Overflow Interrupt Enable</b><br><br>Enable HITOF interrupt           |

**6.6 SYSCFG - System Configuration**

The SYSCFG block is used to configure SRAM. It also contains some interrupt flags for software use. The system has the following major SRAM blocks:

- DMEM0 - Primary system data memory (RAM)
- FRCRAM - Frame Rate Controller SRAM
- SEQRAM - Sequencer SRAM
- DEMODRAM - Demodulator SRAM

**6.6.1 RAM Retention**

DMEM0 is broken into 16 KB banks. By default all banks are retained in EM2/EM3. Sleep mode current can be significantly reduced by fully powering down banks that do not need to be retained. To select the amount of RAM to be powered down in EM2/EM3, set RAM-RETNCTRL in SYSCFG\_DMEM0RETNCTRL to the desired value.

FRCRAM and SEQRAM may be powered down in EM2/EM3 if not required. To disable retention, set FRCRAMRETNCTRL or SEQ-RAMRETNCTRL in SYSCFG\_RADIORAMRETNCTRL.

### 6.6.2 ECC

DMEM0, FRCRAM, and SEQRAM support one bit correction and two bit detection ECC.

To enable error detection for FRCRAM and SEQRAM, set FRCRAMECCCHKEN and SEQRAMECCCHKEN in SYSCFG\_RADIO-ECCCTRL. To enable auto-correction of one bit errors in FRCRAM and SEQRAM, set FRCRAMECCEWEN and SEQRAMECCEWEN in SYSCFG\_RADIOECCCTRL. When ECC error events in FRCRAM and SEQRAM are detected, the corresponding flags in SYSCFG\_IF are set. When a flag is set, an interrupt will be triggered if the corresponding interrupt enable bit is set in SYSCFG\_IEN. When an error occurs, the address of the detected error is written to SYSCFG\_FRCRAMECCADDR or SYSCF\_SEQRAMECCERR depending on the source of the error.

To enable error detection for DMEM0, set ECCEN in MPAHBRAM\_CTRL. To enable auto-correction of one bit errors in DMEM0, set ECCWEN in MPAHBRAM\_CTRL.

When ECC error events in DMEM0 are detected, the corresponding bits in MPAHBRAM\_IF are set. Errors arising from a specific port 'x' will be indicated by the AHBxERR1B or AHBxERR2B flags. When a flag is set, an interrupt will be triggered if the corresponding interrupt enable bit is set in MPAHBRAM\_IEN. When an error occurs, the address of the detected error is written to MPAHBRAM\_ECCERRADDRx for the respective port 'x'. The address registers are sticky and will not be loaded with a new address until they are cleared through MPAHBRAM\_CMD.CLEARRECCADDRx. If multiple ECC errors occur without ECCERRADDRn being cleared, the Px bit in MPAHBRAM\_ECCMERRIND will be set. These status bits are also sticky, and are cleared with MPAHBRAM\_CMD.CLEAREC-CADDRx.

Upon a two bit ECC error in DMEM, MPAHBRAM can also issue a bus fault. To enable this, set the ECCERRFAULTEN bit in MPAHBRAM\_CTRL.

The recommended procedure for initializing ECC RAM is to first enable ECC, then write zeros to all locations. This will clear the RAM and initialize the syndrome. If the ECC RAM is not written as described, then any reads to uninitialized RAM locations will result in an ECC error.

**Note:** The RAM ECC feature must be enabled to achieve good long term reliability. The long term reliability of the RAM is only specified with ECC enabled.

### 6.6.3 Software Interrupts

The SYSCFG block also provides some software interrupts that can be used to communicate between software tasks. To trigger a software interrupt set the corresponding bit in SYSCFG\_IF.

### 6.6.4 Bus faults

By default, two bit ECC errors and reads to unmapped addresses trigger a BusFault. These bus fault sources can be disabled by clearing RAMECCERRFAULTEN and ADDRFAULTEN in SYSCFG\_CTRL.

### 6.6.5 SYSCFG Register Map

The offset register address is relative to the registers base address.

| Offset | Name                         | Type        | Description                      |
|--------|------------------------------|-------------|----------------------------------|
| 0x004  | SYSCFG_IPVERSION             | R           | IP Version ID                    |
| 0x008  | SYSCFG_IF                    | RWH INTFLAG | Interrupt Flag                   |
| 0x00C  | SYSCFG_IEN                   | RW          | Interrupt Enable                 |
| 0x014  | SYSCFG_CHIPREVHW             | RWH         | Chip Revision, Hard-Wired        |
| 0x018  | SYSCFG_CHIPREV               | RW          | Part Family and Revision Values  |
| 0x024  | SYSCFG_CFGSYSTIC             | RW          | SysTick Clock Source             |
| 0x200  | SYSCFG_CTRL                  | RW          | Control                          |
| 0x208  | SYSCFG_DMEM0RETNCTRL         | RW          | DMEM0 Retention Control          |
| 0x30C  | SYSCFG_RAMBIASCONF           | RW          | RAM Bias Configuration           |
| 0x400  | SYSCFG_RADIORAM-RETNCTRL     | RW          | RADIO RAM Retention Control      |
| 0x408  | SYSCFG_RADIOECCCTRL          | RW          | RADIO RAM ECC Control Register   |
| 0x410  | SYSCFG_SEQRAMECCADDR         | RH          | SEQRAM ECC Address               |
| 0x414  | SYSCFG_FRCRAMECCADDR         | RH          | FRCRAM ECC Address               |
| 0x418  | SYSCFG_ICACHERAM-RETNCTRL    | RW          | HOST ICACHERAM Retention Control |
| 0x41C  | SYSCFG_DMEM0PORTMAP-SEL      | RW          | DMEM0 Port Remap Selection       |
| 0x600  | SYSCFG_ROOTDATA0             | RW          | Data Register 0                  |
| 0x604  | SYSCFG_ROOTDATA1             | RW          | Data Register 1                  |
| 0x608  | SYSCFG_ROOTLOCKSTATUS        | RH          | Lock Status                      |
| 0x60C  | SYSCFG_ROOTSESWVER-SION      | RW          | SE SW Version                    |
| 0x1004 | SYSCFG_IPVERSION_SET         | R           | IP Version ID                    |
| 0x1008 | SYSCFG_IF_SET                | RWH INTFLAG | Interrupt Flag                   |
| 0x100C | SYSCFG_IEN_SET               | RW          | Interrupt Enable                 |
| 0x1014 | SYSCFG_CHIPREVHW_SET         | RWH         | Chip Revision, Hard-Wired        |
| 0x1018 | SYSCFG_CHIPREV_SET           | RW          | Part Family and Revision Values  |
| 0x1024 | SYSCFG_CFGSYSTIC_SET         | RW          | SysTick Clock Source             |
| 0x1200 | SYSCFG_CTRL_SET              | RW          | Control                          |
| 0x1208 | SYSCFG_DMEM0RETNCTRL_S-ET    | RW          | DMEM0 Retention Control          |
| 0x130C | SYSCFG_RAMBIASCONF_SET       | RW          | RAM Bias Configuration           |
| 0x1400 | SYSCFG_RADIORAM-RETNCTRL_SET | RW          | RADIO RAM Retention Control      |
| 0x1408 | SYSCFG_RADIO-ECCCTRL_SET     | RW          | RADIO RAM ECC Control Register   |

| Offset | Name                                          | Type        | Description                      |
|--------|-----------------------------------------------|-------------|----------------------------------|
| 0x1410 | <a href="#">SYSCFG_SEQRAMEC-CADDR_SET</a>     | RH          | SEQRAM ECC Address               |
| 0x1414 | <a href="#">SYSCFG_FRCRAMEC-CADDR_SET</a>     | RH          | FRCRAM ECC Address               |
| 0x1418 | <a href="#">SYSCFG_ICACHERAM-RETNCTRL_SET</a> | RW          | HOST ICACHERAM Retention Control |
| 0x141C | <a href="#">SYSCFG_DMEM0PORTMAP-SEL_SET</a>   | RW          | DMEM0 Port Remap Selection       |
| 0x1600 | <a href="#">SYSCFG_ROOTDATA0_SET</a>          | RW          | Data Register 0                  |
| 0x1604 | <a href="#">SYSCFG_ROOTDATA1_SET</a>          | RW          | Data Register 1                  |
| 0x1608 | <a href="#">SYSCFG_ROOTLOCKSTA-TUS_SET</a>    | RH          | Lock Status                      |
| 0x160C | <a href="#">SYSCFG_ROOTSESWVER-SION_SET</a>   | RW          | SE SW Version                    |
| 0x2004 | <a href="#">SYSCFG_IPVERSION_CLR</a>          | R           | IP Version ID                    |
| 0x2008 | <a href="#">SYSCFG_IF_CLR</a>                 | RWH INTFLAG | Interrupt Flag                   |
| 0x200C | <a href="#">SYSCFG_IEN_CLR</a>                | RW          | Interrupt Enable                 |
| 0x2014 | <a href="#">SYSCFG_CHIPREVHW_CLR</a>          | RWH         | Chip Revision, Hard-Wired        |
| 0x2018 | <a href="#">SYSCFG_CHIPREV_CLR</a>            | RW          | Part Family and Revision Values  |
| 0x2024 | <a href="#">SYSCFG_CFGSYSTIC_CLR</a>          | RW          | SysTick Clock Source             |
| 0x2200 | <a href="#">SYSCFG_CTRL_CLR</a>               | RW          | Control                          |
| 0x2208 | <a href="#">SYSCFG_DMEM0RETNCTRL_CLR</a>      | RW          | DMEM0 Retention Control          |
| 0x230C | <a href="#">SYSCFG_RAMBIASCONF_CLR</a>        | RW          | RAM Bias Configuration           |
| 0x2400 | <a href="#">SYSCFG_RADIORAM-RETNCTRL_CLR</a>  | RW          | RADIO RAM Retention Control      |
| 0x2408 | <a href="#">SYSCFG_RADIO-ECCCTRL_CLR</a>      | RW          | RADIO RAM ECC Control Register   |
| 0x2410 | <a href="#">SYSCFG_SEQRAMEC-CADDR_CLR</a>     | RH          | SEQRAM ECC Address               |
| 0x2414 | <a href="#">SYSCFG_FRCRAMEC-CADDR_CLR</a>     | RH          | FRCRAM ECC Address               |
| 0x2418 | <a href="#">SYSCFG_ICACHERAM-RETNCTRL_CLR</a> | RW          | HOST ICACHERAM Retention Control |
| 0x241C | <a href="#">SYSCFG_DMEM0PORTMAP-SEL_CLR</a>   | RW          | DMEM0 Port Remap Selection       |
| 0x2600 | <a href="#">SYSCFG_ROOTDATA0_CLR</a>          | RW          | Data Register 0                  |
| 0x2604 | <a href="#">SYSCFG_ROOTDATA1_CLR</a>          | RW          | Data Register 1                  |
| 0x2608 | <a href="#">SYSCFG_ROOTLOCKSTA-TUS_CLR</a>    | RH          | Lock Status                      |
| 0x260C | <a href="#">SYSCFG_ROOTSESWVER-SION_CLR</a>   | RW          | SE SW Version                    |
| 0x3004 | <a href="#">SYSCFG_IPVERSION_TGL</a>          | R           | IP Version ID                    |

| Offset | Name                                          | Type        | Description                      |
|--------|-----------------------------------------------|-------------|----------------------------------|
| 0x3008 | <a href="#">SYSCFG_IF_TGL</a>                 | RWH INTFLAG | Interrupt Flag                   |
| 0x300C | <a href="#">SYSCFG_IEN_TGL</a>                | RW          | Interrupt Enable                 |
| 0x3014 | <a href="#">SYSCFG_CHIPREVHW_TGL</a>          | RWH         | Chip Revision, Hard-Wired        |
| 0x3018 | <a href="#">SYSCFG_CHIPREV_TGL</a>            | RW          | Part Family and Revision Values  |
| 0x3024 | <a href="#">SYSCFG_CFGSYSTIC_TGL</a>          | RW          | SysTick Clock Source             |
| 0x3200 | <a href="#">SYSCFG_CTRL_TGL</a>               | RW          | Control                          |
| 0x3208 | <a href="#">SYSCFG_DMEM0RETNCTRL_TGL</a>      | RW          | DMEM0 Retention Control          |
| 0x330C | <a href="#">SYSCFG_RAMBIASCONF_TGL</a>        | RW          | RAM Bias Configuration           |
| 0x3400 | <a href="#">SYSCFG_RADIORAM-RETNCTRL_TGL</a>  | RW          | RADIO RAM Retention Control      |
| 0x3408 | <a href="#">SYSCFG_RADIO-ECCCTRL_TGL</a>      | RW          | RADIO RAM ECC Control Register   |
| 0x3410 | <a href="#">SYSCFG_SEQRAMEC-CADDR_TGL</a>     | RH          | SEQRAM ECC Address               |
| 0x3414 | <a href="#">SYSCFG_FRCRAMEC-CADDR_TGL</a>     | RH          | FRCRAM ECC Address               |
| 0x3418 | <a href="#">SYSCFG_ICACHERAM-RETNCTRL_TGL</a> | RW          | HOST ICACHERAM Retention Control |
| 0x341C | <a href="#">SYSCFG_DMEM0PORTMAP-SEL_TGL</a>   | RW          | DMEM0 Port Remap Selection       |
| 0x3600 | <a href="#">SYSCFG_ROOTDATA0_TGL</a>          | RW          | Data Register 0                  |
| 0x3604 | <a href="#">SYSCFG_ROOTDATA1_TGL</a>          | RW          | Data Register 1                  |
| 0x3608 | <a href="#">SYSCFG_ROOTLOCKSTATUS_TGL</a>     | RH          | Lock Status                      |
| 0x360C | <a href="#">SYSCFG_ROOTSESWVERSION_TGL</a>    | RW          | SE SW Version                    |

## 6.6.6 SYSCFG Register Description

### 6.6.6.1 SYSCFG\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 0x004  | 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 |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x3 |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | R  |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    | IPVERSION |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bit  | Name      | Reset | Access | Description                                            |
|------|-----------|-------|--------|--------------------------------------------------------|
| 31:0 | IPVERSION | 0x3   | R      | <b>New BitField</b><br><br>ID indicating version of IP |

## 6.6.6.2 SYSCFG\_IF - Interrupt Flag

| Offset | Bit Position |             |             |             |                |                |       |       |       |       |       |       |     |     |     |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|-------------|-------------|-------------|----------------|----------------|-------|-------|-------|-------|-------|-------|-----|-----|-----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x008  | 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 |
| Reset  |              |             |             |             |                |                |       |       |       |       |       |       |     |     |     |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |             | RW          | RW          | RW             | RW             | RW    | RW    |       |       |       |       |     |     |     |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | FRCRAMERR2B  | FRCRAMERR1B | SEQRAMERR2B | SEQRAMERR1B | SRW2HOSTBUSERR | HOST2SRWBUSERR | FPIXC | FPIDC | FPOFC | FPUFC | FPDZC | FPIOC | SW3 | SW2 | SW1 | SW0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 29    | FRCRAMERR2B    | 0x0   | RW     | <b>FRCRAM Error 2-bit Interrupt Flag</b><br><br>FRCRAM 2-bit ECC Error Interrupt flag.                                                                                            |
| 28    | FRCRAMERR1B    | 0x0   | RW     | <b>FRCRAM Error 1-bit Interrupt Flag</b><br><br>FRCRAM 1-bit ECC Error Interrupt flag.                                                                                            |
| 27:26 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 25    | SEQRAMERR2B    | 0x0   | RW     | <b>SEQRAM Error 2-bit Interrupt Flag</b><br><br>SEQRAM 2-bit ECC Error Interrupt flag.                                                                                            |
| 24    | SEQRAMERR1B    | 0x0   | RW     | <b>SEQRAM Error 1-bit Interrupt Flag</b><br><br>SEQRAM 1-bit ECC Error Interrupt flag.                                                                                            |
| 23:18 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17    | SRW2HOSTBUSERR | 0x0   | RW     | <b>SRW2HOSTBUSERRIF Interrupt Flag</b><br><br>AHB SRW to AHB HOST Bus Error Interrupt Flag                                                                                        |
| 16    | HOST2SRWBUSERR | 0x0   | RW     | <b>HOST2SRWBUSERRIF Interrupt Flag</b><br><br>AHB Host to AHB SRW Bus Error Interrupt Flag                                                                                        |
| 15:14 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13    | FPIXC          | 0x0   | RW     | <b>FPU Inexact interrupt flag</b><br><br>Set upon FPU inexact exception                                                                                                           |
| 12    | FPIDC          | 0x0   | RW     | <b>FPU Input denormal interrupt flag</b><br><br>Set upon FPU input denormal exception                                                                                             |
| 11    | FPOFC          | 0x0   | RW     | <b>FPU Overflow interrupt flag</b><br><br>Set upon FPU overflow exception                                                                                                         |
| 10    | FPUFC          | 0x0   | RW     | <b>FPU Underflow interrupt flag</b>                                                                                                                                               |

| Bit | Name     | Reset | Access | Description                                                                                                                                                                       |
|-----|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          |       |        | Set upon FPU underflow exception                                                                                                                                                  |
| 9   | FPDZC    | 0x0   | RW     | <b>FPU Divide by zero interrupt flag</b>                                                                                                                                          |
|     |          |       |        | Set upon FPU divide by zero operation                                                                                                                                             |
| 8   | FPIOC    | 0x0   | RW     | <b>FPU Invalid Operation interrupt flag</b>                                                                                                                                       |
|     |          |       |        | Set upon FPU invalid operation                                                                                                                                                    |
| 7:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3   | SW3      | 0x0   | RW     | <b>Software Interrupt Flag</b>                                                                                                                                                    |
|     |          |       |        | Software interrupts                                                                                                                                                               |
| 2   | SW2      | 0x0   | RW     | <b>Software Interrupt Flag</b>                                                                                                                                                    |
|     |          |       |        | Software interrupts                                                                                                                                                               |
| 1   | SW1      | 0x0   | RW     | <b>Software Interrupt Flag</b>                                                                                                                                                    |
|     |          |       |        | Software interrupts                                                                                                                                                               |
| 0   | SW0      | 0x0   | RW     | <b>Software Interrupt Flag</b>                                                                                                                                                    |
|     |          |       |        | Software interrupts                                                                                                                                                               |

## 6.6.6.3 SYSCFG\_IEN - Interrupt Enable

| Offset | Bit Position |             |             |             |                |                |       |       |       |       |       |       |     |     |     |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|-------------|-------------|-------------|----------------|----------------|-------|-------|-------|-------|-------|-------|-----|-----|-----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00C  | 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 |
| Reset  |              |             |             |             |                |                |       |       |       |       |       |       |     |     |     |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |             | RW          | RW          |                |                |       |       |       |       |       |       |     |     |     |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | FRCRAMERR2B  | FRCRAMERR1B | SEQRAMERR2B | SEQRAMERR1B | SRW2HOSTBUSERR | HOST2SRWBUSERR | FPIXC | FPIDC | FPOFC | FPUFC | FPDZC | FPIOC | SW3 | SW2 | SW1 | SW0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 29    | FRCRAMERR2B    | 0x0   | RW     | <b>FRCRAM Error 2-bit Interrupt Enable</b>                                                                                                                                        |
|       |                |       |        | Set to enable the FRCRAM2ERR2BIF Interrupt                                                                                                                                        |
| 28    | FRCRAMERR1B    | 0x0   | RW     | <b>FRCRAM Error 1-bit Interrupt Enable</b>                                                                                                                                        |
|       |                |       |        | Set to enable the FRCRAM2ERR1BIF Interrupt                                                                                                                                        |
| 27:26 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 25    | SEQRAMERR2B    | 0x0   | RW     | <b>SEQRAM Error 2-bit Interrupt Enable</b>                                                                                                                                        |
|       |                |       |        | Set to enable the SEQRAM2ERR2BIF Interrupt                                                                                                                                        |
| 24    | SEQRAMERR1B    | 0x0   | RW     | <b>SEQRAM Error 1-bit Interrupt Enable</b>                                                                                                                                        |
|       |                |       |        | Set to enable the SEQRAM2ERR1BIF Interrupt                                                                                                                                        |
| 23:18 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17    | SRW2HOSTBUSERR | 0x0   | RW     | <b>SRW2HOSTUSERRIEN Interrupt Enable</b>                                                                                                                                          |
|       |                |       |        | Set to enable the SRW2HOSTBUSERR Interrupt                                                                                                                                        |
| 16    | HOST2SRWBUSERR | 0x0   | RW     | <b>HOST2SRWBUSERRIEN Interrupt Enable</b>                                                                                                                                         |
|       |                |       |        | Set to enable the HOST2SRWBUSERR Interrupt                                                                                                                                        |
| 15:14 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13    | FPIXC          | 0x0   | RW     | <b>FPU Inexact Interrupt Enable</b>                                                                                                                                               |
|       |                |       |        | Set to enable the FPIXCIF Interrupt                                                                                                                                               |
| 12    | FPIDC          | 0x0   | RW     | <b>FPU Input denormal Interrupt Enable</b>                                                                                                                                        |
|       |                |       |        | Set to enable the FPIDCFIF Interrupt                                                                                                                                              |
| 11    | FPOFC          | 0x0   | RW     | <b>FPU Overflow Interrupt Enable</b>                                                                                                                                              |
|       |                |       |        | Set to enable the FPOFCIF Interrupt                                                                                                                                               |
| 10    | FPUFC          | 0x0   | RW     | <b>FPU Underflow Interrupt Enable</b>                                                                                                                                             |

| Bit                                   | Name     | Reset                                                                                                                                                                             | Access | Description                                   |
|---------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------|
| Set to enable the FPUFCIF Interrupt   |          |                                                                                                                                                                                   |        |                                               |
| 9                                     | FPDZC    | 0x0                                                                                                                                                                               | RW     | <b>FPU Divide by zero Interrupt Enable</b>    |
| Set to enable the FPDZCIF Interrupt   |          |                                                                                                                                                                                   |        |                                               |
| 8                                     | FPIOC    | 0x0                                                                                                                                                                               | RW     | <b>FPU Invalid Operation Interrupt Enable</b> |
| Set to enable the FPIOCIF Interrupt   |          |                                                                                                                                                                                   |        |                                               |
| 7:4                                   | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                               |
| 3                                     | SW3      | 0x0                                                                                                                                                                               | RW     | <b>Software Interrupt Enable</b>              |
| Set to enable the Software Interrupts |          |                                                                                                                                                                                   |        |                                               |
| 2                                     | SW2      | 0x0                                                                                                                                                                               | RW     | <b>Software Interrupt Enable</b>              |
| Set to enable the Software Interrupts |          |                                                                                                                                                                                   |        |                                               |
| 1                                     | SW1      | 0x0                                                                                                                                                                               | RW     | <b>Software Interrupt Enable</b>              |
| Set to enable the Software Interrupts |          |                                                                                                                                                                                   |        |                                               |
| 0                                     | SW0      | 0x0                                                                                                                                                                               | RW     | <b>Software Interrupt Enable</b>              |
| Set to enable the Software Interrupts |          |                                                                                                                                                                                   |        |                                               |

#### 6.6.6.4 SYSCFG\_CHIPREVHW - Chip Revision, Hard-Wired

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |       |     |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------|-----|---|---|
| 0x014  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |       | 0x1 |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW    |     |   |   |
| Name   | MINOR        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | MAJOR |     |   |   |

| Bit                                        | Name     | Reset                                                                                                                                                                             | Access | Description                                |
|--------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------|
| 31:20                                      | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                            |
| Hardwired Chip Revision Minor signal value |          |                                                                                                                                                                                   |        |                                            |
| 19:12                                      | MINOR    | 0x0                                                                                                                                                                               | RW     | <b>Hardwired Chip Revision Minor value</b> |
| Hardwired Chip Family signal value         |          |                                                                                                                                                                                   |        |                                            |
| 11:6                                       | FAMILY   | 0x3C                                                                                                                                                                              | RW     | <b>Hardwired Chip Family value</b>         |
| Hardwired Chip Revision Major signal value |          |                                                                                                                                                                                   |        |                                            |
| 5:0                                        | MAJOR    | 0x1                                                                                                                                                                               | RW     | <b>Hardwired Chip Revision Major value</b> |
| Hardwired Chip Revision Major signal value |          |                                                                                                                                                                                   |        |                                            |

**6.6.6.5 SYSCFG\_CHIPREV - Part Family and Revision Values**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |        |    |    |    |   |   |       |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|--------|----|----|----|---|---|-------|---|---|---|---|---|---|---|
| 0x018  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    | 0x0   |    |    |    |    |    | 0x0    |    |    |    |   |   | 0x0   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    | RW    |    |    |    |    |    | RW     |    |    |    |   |   | RW    |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | MINOR |    |    |    |    |    | FAMILY |    |    |    |   |   | MAJOR |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                       |
|-------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 19:12 | MINOR    | 0x0   | RW     | <b>Chip Revision Minor value</b><br><br>Chip Revision Minor value                                                                                                 |
| 11:6  | FAMILY   | 0x0   | RW     | <b>Chip Family value</b><br><br>Chip Family value                                                                                                                 |
|       | Value    | Mode  |        | Description                                                                                                                                                       |
|       | 60       | MG24  |        | Product is in MG24 family                                                                                                                                         |
|       | 61       | BG24  |        | Product is in BG24 family                                                                                                                                         |
| 5:0   | MAJOR    | 0x0   | RW     | <b>Chip Revision Major value</b><br><br>Chip Revision Major value                                                                                                 |

**6.6.6.6 SYSCFG\_CFGSYSTIC - SysTick Clock Source**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |                |    |    |    |    |    |     |    |    |    |   |   |     |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----------------|----|----|----|----|----|-----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 0x024  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    | 0x0            |    |    |    |    |    | 0x0 |    |    |    |   |   | 0x0 |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    | RW             |    |    |    |    |    | RW  |    |    |    |   |   | RW  |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | SYSTICEXTCLKEN |    |    |    |    |    | 0x0 |    |    |    |   |   | 0x0 |   |   |   |   |   |   |   |

| Bit  | Name           | Reset | Access | Description                                                                                                                                                       |
|------|----------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 0    | SYSTICEXTCLKEN | 0x0   | RW     | <b>SysTick External Clock Enable</b><br><br>Set 1 to use an external clock as the M33 SysTick.                                                                    |

## 6.6.6.7 SYSCFG\_CTRL - Control

| Offset           | Bit Position |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |
|------------------|--------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--|
| 0x200            | 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 | 4 | 3 | 2 | 0 |  |
| Reset            |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |
| Access           |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |
| Name             |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |
| RAMECCERRFAULTEN | RW           | 0x1 | 5  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |
| CLKDISFAULTEN    | RW           | 0x1 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |
| ADDRFAULTEN      | RW           | 0x1 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |

| Bit  | Name             | Reset | Access | Description                                                                                                                                                         |
|------|------------------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>   |
| 5    | RAMECCERRFAULTEN | 0x1   | RW     | <b>Two bit ECC error bus fault response ena</b><br><br>When this bit is set, busfaults are generated if 2-bit ECC error occurs.                                     |
| 4:2  | Reserved         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>   |
| 1    | CLKDISFAULTEN    | 0x1   | RW     | <b>Disabled Clkbus Bus Fault Enable</b><br><br>When this bit is set, busfaults are generated on accesses to peripherals with disabled bus clock                     |
| 0    | ADDRFAULTEN      | 0x1   | RW     | <b>Invalid Address Bus Fault Response Enabl</b><br><br>When this bit is set, busfaults are generated on accesses to unmapped parts of system and code address space |

## 6.6.6.8 SYSCFG\_DMEM0RETNCTRL - DMEM0 Retention Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|---|---|---|---|---|---|
| 0x208  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0         |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW          |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RAMRETNCTRL |   |   |   |   |   |   |

| Bit   | Name                                                                    | Reset     | Access | Description                                                                                                                                                       |
|-------|-------------------------------------------------------------------------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | Reserved                                                                |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 14:0  | RAMRETNCTRL                                                             | 0x0       | RW     | <b>DMEM0 blockset retention control</b>                                                                                                                           |
|       | DMEM0 RAM blockset retention controls in EM23 with full access in EM01. |           |        |                                                                                                                                                                   |
|       | Value                                                                   | Mode      |        | Description                                                                                                                                                       |
|       | 0                                                                       | ALLON     |        | None of the RAM blocks powered down                                                                                                                               |
|       | 16384                                                                   | BLK15     |        | Power down RAM block 15 (address range 0x2003C000-0x20040000)                                                                                                     |
|       | 24576                                                                   | BLK14TO15 |        | Power down RAM blocks 14 and above (address range 0x20038000-0x20040000)                                                                                          |
|       | 28672                                                                   | BLK13TO15 |        | Power down RAM blocks 13 and above (address range 0x20034000-0x20040000)                                                                                          |
|       | 30720                                                                   | BLK12TO15 |        | Power down RAM blocks 12 and above (address range 0x20030000-0x20040000)                                                                                          |
|       | 31744                                                                   | BLK11TO15 |        | Power down RAM blocks 11 and above (address range 0x2002C000-0x20040000)                                                                                          |
|       | 32256                                                                   | BLK10TO15 |        | Power down RAM blocks 10 and above (address range 0x20028000-0x20040000)                                                                                          |
|       | 32512                                                                   | BLK9TO15  |        | Power down RAM blocks 9 and above (address range 0x20024000-0x20040000)                                                                                           |
|       | 32640                                                                   | BLK8TO15  |        | Power down RAM blocks 8 and above (address range 0x20020000-0x20040000)                                                                                           |
|       | 32704                                                                   | BLK7TO15  |        | Power down RAM blocks 7 and above (address range 0x2001C000-0x20040000)                                                                                           |
|       | 32736                                                                   | BLK6TO15  |        | Power down RAM blocks 6 and above (address range 0x20018000-0x20040000)                                                                                           |
|       | 32752                                                                   | BLK5TO15  |        | Power down RAM blocks 5 and above (address range 0x20014000-0x20040000)                                                                                           |
|       | 32760                                                                   | BLK4TO15  |        | Power down RAM blocks 4 and above (address range 0x20010000-0x20040000)                                                                                           |
|       | 32764                                                                   | BLK3TO15  |        | Power down RAM blocks 3 and above (address range 0x2000C000-0x20040000)                                                                                           |

| Bit | Name  | Reset    | Access | Description                                                             |
|-----|-------|----------|--------|-------------------------------------------------------------------------|
|     | 32766 | BLK2TO15 |        | Power down RAM blocks 2 and above (address range 0x20008000-0x20040000) |
|     | 32767 | BLK1TO15 |        | Power down RAM blocks 1 and above (address range 0x20004000-0x20040000) |

#### 6.6.6.9 SYSCFG\_RAMBIASCONF - RAM Bias Configuration

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RAMBIASCTRL | RW | 0x2 |  |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------|----|-----|--|--|
|               | 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  |     |  |  |
| 0x30C         |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |             |    |     |  |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |             |    |     |  |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |             |    |     |  |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |             |    |     |  |  |

| Bit                                                            | Name        | Reset  | Access                    | Description                                                                                                                                                                       |
|----------------------------------------------------------------|-------------|--------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4                                                           | Reserved    |        |                           | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0                                                            | RAMBIASCTRL | 0x2    | RW                        | <b>RAM Bias Control</b>                                                                                                                                                           |
| RAM blockset Bias control. Voltage Source Bias control setting |             |        |                           |                                                                                                                                                                                   |
| Value                                                          |             | Mode   | Description               |                                                                                                                                                                                   |
| 0                                                              |             | NO     | None                      |                                                                                                                                                                                   |
| 1                                                              |             | VSB100 | Voltage Source Bias 100mV |                                                                                                                                                                                   |
| 2                                                              |             | VSB200 | Voltage Source Bias 200mV |                                                                                                                                                                                   |
| 4                                                              |             | VSB300 | Voltage Source Bias 300mV |                                                                                                                                                                                   |
| 8                                                              |             | VSB400 | Voltage Source Bias 400mV |                                                                                                                                                                                   |

#### 6.6.6.10 SYSCFG\_RADIORAMRETNCTRL - RADIO RAM Retention Control

| Bit  | Name           | Reset  | Access | Description                                                                                                                                                                       |
|------|----------------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved       |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8    | FRCRAMRETNCTRL | 0x0    | RW     | <b>FRCRAM Retention Control</b>                                                                                                                                                   |
|      |                |        |        | FRC RAM power-down in EM23 with full access in EM01                                                                                                                               |
|      |                |        |        |                                                                                                                                                                                   |
|      | Value          | Mode   |        | Description                                                                                                                                                                       |
|      | 0              | ALLON  |        | FRCRAM not powered down                                                                                                                                                           |
|      | 1              | ALLOFF |        | Power down FRCRAM                                                                                                                                                                 |
|      |                |        |        |                                                                                                                                                                                   |
| 7:2  | Reserved       |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0  | SEQRAMRETNCTRL | 0x0    | RW     | <b>SEQRAM Retention Control</b>                                                                                                                                                   |
|      |                |        |        | SEQUENCER RAM power-down in EM23 with full access in EM01                                                                                                                         |
|      |                |        |        |                                                                                                                                                                                   |
|      | Value          | Mode   |        | Description                                                                                                                                                                       |
|      | 0              | ALLON  |        | SEQRAM not powered down                                                                                                                                                           |
|      | 1              | BLK0   |        | Power down SEQRAM block 0                                                                                                                                                         |
|      | 2              | BLK1   |        | Power down SEQRAM block 1                                                                                                                                                         |
|      | 3              | ALLOFF |        | Power down all SEQRAM blocks                                                                                                                                                      |

## 6.6.6.11 SYSCFG\_RADIOECCCTRL - RADIO RAM ECC Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |     |     |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|-----|-----|---|---|---|---|
| 0x408  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0           | 1   | 0   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW            | 0x0 | 0   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SEQRAMECCEWEN | RW  | 0x0 | 0 |   |   |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | FRCRAMECCEWEN | RW  | 0x0 | 0 |   |   |   |

| Bit   | Name          | Reset | Access | Description                                                                                                                                                       |
|-------|---------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9     | FRCRAMECCEWEN | 0x0   | RW     | <b>FRCRAM ECC Error Writeback Enable</b><br><br>FRC ECC Error Writeback Enable. When set, errors will be corrected when encountered.                              |
| 8     | FRCRAMECCEN   | 0x0   | RW     | <b>FRCRAM ECC Enable</b><br><br>FRCRAM ECC Enable.                                                                                                                |
| 7:2   | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 1     | SEQRAMECCEWEN | 0x0   | RW     | <b>SEQRAM ECC Error Writeback Enable</b><br><br>SEQRAM ECC Error Writeback Enable. When set, errors will be corrected when encountered.                           |
| 0     | SEQRAMECCEN   | 0x0   | RW     | <b>SEQRAM ECC Enable</b><br><br>SEQRAM ECC Enable.                                                                                                                |

**6.6.6.12 SYSCFG\_SEQRAMECCADDR - SEQRAM ECC Address**

| Offset | Bit Position  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x410  | 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 |
| Reset  | 0x0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | SEQRAMECCADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                     | Name          | Reset | Access | Description               |
|---------------------------------------------------------|---------------|-------|--------|---------------------------|
| 31:0                                                    | SEQRAMECCADDR | 0x0   | R      | <b>SEQRAM ECC Address</b> |
| Indicates Address of SEQRAM at which ECC error occurred |               |       |        |                           |

**6.6.6.13 SYSCFG\_FRCRAMECCADDR - FRCRAM ECC Address**

| Offset | Bit Position  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x414  | 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 |
| Reset  | 0x0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | FRCRAMECCADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                     | Name          | Reset | Access | Description                     |
|---------------------------------------------------------|---------------|-------|--------|---------------------------------|
| 31:0                                                    | FRCRAMECCADDR | 0x0   | R      | <b>FRCRAM ECC Error Address</b> |
| Indicates Address of FRCRAM at which ECC error occurred |               |       |        |                                 |

#### 6.6.6.14 SYSCFG\_ICACHERAMRETNCTRL - HOST ICACHERAM Retention Control

| Bit                                                          | Name        | Reset                                           | Access | Description                                                                                                                                                                       |  |  |
|--------------------------------------------------------------|-------------|-------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:1                                                         | Reserved    |                                                 |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |  |  |
| 0                                                            | RAMRETNCTRL | 0x0                                             | RW     | <b>ICACHERAM Retention control</b>                                                                                                                                                |  |  |
| Host ICACHE RAM power-down in EM23 with full access in EM01. |             |                                                 |        |                                                                                                                                                                                   |  |  |
| Value                                                        | Mode        | Description                                     |        |                                                                                                                                                                                   |  |  |
| 0                                                            | ALLON       | None of the Host ICACHE RAM blocks powered down |        |                                                                                                                                                                                   |  |  |
| 1                                                            | ALLOFF      | Power down all Host ICACHE RAM blocks           |        |                                                                                                                                                                                   |  |  |

## 6.6.6.15 SYSCFG\_DMEM0PORTMAPSEL - DMEM0 Port Remap Selection

| Offset             | Bit Position |     |    |                    |    |     |    |                    |    |     |    |                |    |     |    |                |     |     |
|--------------------|--------------|-----|----|--------------------|----|-----|----|--------------------|----|-----|----|----------------|----|-----|----|----------------|-----|-----|
| 0x41C              | 31           | 30  | 29 | 28                 | 27 | 26  | 25 | 24                 | 23 | 22  | 21 | 20             | 19 | 18  | 17 | 16             | 15  | 14  |
| Reset              |              |     |    |                    |    |     |    |                    |    |     |    |                |    |     |    | RW             | 0x1 |     |
| Access             |              |     |    |                    |    |     |    |                    |    |     |    |                |    |     |    | RW             | 0x1 |     |
| Name               |              |     |    |                    |    |     |    |                    |    |     |    |                |    |     |    | RW             | 0x1 |     |
| MVPAHBDATA2PORTSEL | RW           | 0x3 | 13 | MVPAHBDATA1PORTSEL | RW | 0x3 | 12 | MVPAHBDATA0PORTSEL | RW | 0x2 | 11 | SRWECA1PORTSEL | RW | 0x1 | 9  | SRWECA0PORTSEL | RW  | 0x0 |
| MVPAHBDATA2PORTSEL | RW           | 0x1 | 14 | MVPAHBDATA1PORTSEL | RW | 0x3 | 11 | MVPAHBDATA0PORTSEL | RW | 0x2 | 10 | AHBSRWPORTSEL  | RW | 0x0 | 5  | SRWAESPORTSEL  | RW  | 0x1 |
| SRWECA1PORTSEL     | RW           | 0x1 | 8  | SRWECA0PORTSEL     | RW | 0x0 | 6  | AHBSRWPORTSEL      | RW | 0x0 | 4  | SRWAESPORTSEL  | RW | 0x1 | 3  | LDMAPORTSEL    | RW  | 0x1 |
| SRWECA0PORTSEL     | RW           | 0x0 | 7  | AHBSRWPORTSEL      | RW | 0x0 | 5  | SRWAESPORTSEL      | RW | 0x1 | 2  | LDMAPORTSEL    | RW | 0x1 | 1  | LDMAPORTSEL    | RW  | 0x1 |
| SRWECA0PORTSEL     | RW           | 0x0 | 6  | AHBSRWPORTSEL      | RW | 0x0 | 4  | SRWAESPORTSEL      | RW | 0x1 | 0  | LDMAPORTSEL    | RW | 0x1 | 0  | LDMAPORTSEL    | RW  | 0x1 |

| Bit   | Name               | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved           |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:14 | MVPAHBDATA2PORTSEL | 0x1   | RW     | <b>MVPAHBDATA2 portmap selection</b><br>MVPWDMA address remap selection, default configured to MPAHBRAM1                                                          |
| 13:12 | MVPAHBDATA1PORTSEL | 0x3   | RW     | <b>MVPAHBDATA1 portmap selection</b><br>MVPRDMA1 address remap selection, default configured to MPAHBRAM3                                                         |
| 11:10 | MVPAHBDATA0PORTSEL | 0x2   | RW     | <b>MVPAHBDATA0 portmap selection</b><br>MVPRDMA0 address remap selection, default configured to MPAHBRAM2                                                         |
| 9:8   | SRWECA1PORTSEL     | 0x1   | RW     | <b>SRWECA1 portmap selection</b><br>SRWECA1 address remap selection, default configured to MPAHBRAM1                                                              |
| 7:6   | SRWECA0PORTSEL     | 0x0   | RW     | <b>SRWECA0 portmap selection</b><br>SRWECA0 address remap selection, default configured to MPAHBRAM0                                                              |
| 5:4   | AHBSRWPORTSEL      | 0x0   | RW     | <b>AHBSRW portmap selection</b><br>AHBSRW address remap selection, default configured to MPAHBRAM0                                                                |
| 3:2   | SRWAESPORTSEL      | 0x1   | RW     | <b>SRWAES portmap selection</b><br>SRWAES address remap selection, default configured to MPAHBRAM1                                                                |
| 1:0   | LDMAPORTSEL        | 0x1   | RW     | <b>LDMA portmap selection</b><br>LDMA address remap selection, default configured to MPAHBRAM1                                                                    |

**6.6.6.16 SYSCFG\_ROOTDATA0 - Data Register 0**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x600  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DATA         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                         | Name | Reset | Access | Description |
|-----------------------------------------------------------------------------|------|-------|--------|-------------|
| 31:0                                                                        | DATA | 0x0   | RW     | <b>Data</b> |
| Generic data space for user to pass to root, e.g., address of struct in mem |      |       |        |             |

**6.6.6.17 SYSCFG\_ROOTDATA1 - Data Register 1**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x604  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DATA         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                         | Name | Reset | Access | Description |
|-----------------------------------------------------------------------------|------|-------|--------|-------------|
| 31:0                                                                        | DATA | 0x0   | RW     | <b>Data</b> |
| Generic data space for user to pass to root, e.g., address of struct in mem |      |       |        |             |

## 6.6.6.18 SYSCFG\_ROOTLOCKSTATUS - Lock Status

| Offset         | Bit Position  |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----------------|---------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| Reset          | 0x0           | 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 |  |  |  |
| Access         | R             |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name           | EFUSEUNLOCKED |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| RADIONIDBGLOCK | R             | 0x1 | 22 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| RADIOIDBGLOCK  | R             | 0x1 | 21 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| USERSPNIDLOCK  | R             | 0x1 | 20 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| USERSPIDLOCK   | R             | 0x1 | 19 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| USERNIDLOCK    | R             | 0x1 | 18 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| USERDBGLOCK    | R             | 0x1 | 17 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| USERDBGAPLOCK  | R             | 0x1 | 16 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| ROOTDBGLOCK    | R             | 0x1 | 8  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| MFRLOCK        | R             | 0x1 | 2  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| REGLOCK        | R             | 0x1 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| BUSLOCK        | R             | 0x1 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | EFUSEUNLOCKED  | 0x0   | R      | <b>E-Fuse Unlocked</b><br><br>E-Fuse Unlocked when 1; Locked when 0.                                                                                                              |
| 30:23 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 22    | RADIONIDBGLOCK | 0x1   | R      | <b>Radio Non-invasive Debug Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                       |
| 21    | RADIOIDBGLOCK  | 0x1   | R      | <b>Radio Invasive Debug Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                           |
| 20    | USERSPNIDLOCK  | 0x1   | R      | <b>User Secure Non-invasive Debug Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                 |
| 19    | USERSPIDLOCK   | 0x1   | R      | <b>User Secure Invasive Debug Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                     |
| 18    | USERNIDLOCK    | 0x1   | R      | <b>User Non-invasive Debug Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                        |
| 17    | USERDBGLOCK    | 0x1   | R      | <b>User Invasive Debug Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                            |
| 16    | USERDBGAPLOCK  | 0x1   | R      | <b>User Debug Access Port Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                         |
| 15:9  | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8     | ROOTDBGLOCK    | 0x1   | R      | <b>Root Debug Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                                     |
| 7:3   | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2     | MFRLOCK        | 0x1   | R      | <b>Manufacture Lock</b><br><br>Locked when 1; unlocked when 0.                                                                                                                    |
| 1     | REGLOCK        | 0x1   | R      | <b>Register Lock</b>                                                                                                                                                              |

| Bit                             | Name    | Reset | Access | Description     |
|---------------------------------|---------|-------|--------|-----------------|
| Locked when 1; unlocked when 0. |         |       |        |                 |
| 0                               | BUSLOCK | 0x1   | R      | <b>Bus Lock</b> |
| Locked when 1; unlocked when 0. |         |       |        |                 |

#### **6.6.6.19 SYSCFG\_ROOTSESWVERSION - SE SW Version**

| Bit                                                               | Name      | Reset | Access | Description       |
|-------------------------------------------------------------------|-----------|-------|--------|-------------------|
| 31:0                                                              | SWVERSION | 0x0   | RW     | <b>SW Version</b> |
| Location for SE to write the Firmware version and host to read it |           |       |        |                   |

### 6.6.7 MPAHBRAM Register Map

The offset register address is relative to the registers base address.

| Offset | Name                      | Type        | Description                   |
|--------|---------------------------|-------------|-------------------------------|
| 0x000  | MPAHBRAM_IPVERSION        | R           | IP Version ID                 |
| 0x004  | MPAHBRAM_CMD              | W           | Command Register              |
| 0x008  | MPAHBRAM_CTRL             | RW          | Control Register              |
| 0x00C  | MPAHBRAM_ECCERRADDR0      | RH          | ECC Error Address 0           |
| 0x010  | MPAHBRAM_ECCERRADDR1      | RH          | ECC Error Address 1           |
| 0x014  | MPAHBRAM_ECCERRADDR2      | RH          | ECC Error Address 2           |
| 0x018  | MPAHBRAM_ECCERRADDR3      | RH          | ECC Error Address 3           |
| 0x01C  | MPAHBRAM_ECCMERRIND       | RH          | Multiple ECC Error Indication |
| 0x020  | MPAHBRAM_IF               | RWH INTFLAG | Interrupt Flags               |
| 0x024  | MPAHBRAM_IEN              | RW          | Interrupt Enable              |
| 0x1000 | MPAHBRAM_IPVERSION_SET    | R           | IP Version ID                 |
| 0x1004 | MPAHBRAM_CMD_SET          | W           | Command Register              |
| 0x1008 | MPAHBRAM_CTRL_SET         | RW          | Control Register              |
| 0x100C | MPAHBRAM_ECCER-RADDR0_SET | RH          | ECC Error Address 0           |
| 0x1010 | MPAHBRAM_ECCER-RADDR1_SET | RH          | ECC Error Address 1           |
| 0x1014 | MPAHBRAM_ECCER-RADDR2_SET | RH          | ECC Error Address 2           |
| 0x1018 | MPAHBRAM_ECCER-RADDR3_SET | RH          | ECC Error Address 3           |
| 0x101C | MPAHBRAM_ECCMER-RIND_SET  | RH          | Multiple ECC Error Indication |
| 0x1020 | MPAHBRAM_IF_SET           | RWH INTFLAG | Interrupt Flags               |
| 0x1024 | MPAHBRAM_IEN_SET          | RW          | Interrupt Enable              |
| 0x2000 | MPAHBRAM_IPVERSION_CLR    | R           | IP Version ID                 |
| 0x2004 | MPAHBRAM_CMD_CLR          | W           | Command Register              |
| 0x2008 | MPAHBRAM_CTRL_CLR         | RW          | Control Register              |
| 0x200C | MPAHBRAM_ECCER-RADDR0_CLR | RH          | ECC Error Address 0           |
| 0x2010 | MPAHBRAM_ECCER-RADDR1_CLR | RH          | ECC Error Address 1           |
| 0x2014 | MPAHBRAM_ECCER-RADDR2_CLR | RH          | ECC Error Address 2           |
| 0x2018 | MPAHBRAM_ECCER-RADDR3_CLR | RH          | ECC Error Address 3           |
| 0x201C | MPAHBRAM_ECCMER-RIND_CLR  | RH          | Multiple ECC Error Indication |
| 0x2020 | MPAHBRAM_IF_CLR           | RWH INTFLAG | Interrupt Flags               |

| Offset | Name                      | Type        | Description                   |
|--------|---------------------------|-------------|-------------------------------|
| 0x2024 | MPAHBRAM_IEN_CLR          | RW          | Interrupt Enable              |
| 0x3000 | MPAHBRAM_IPVERSION_TGL    | R           | IP Version ID                 |
| 0x3004 | MPAHBRAM_CMD_TGL          | W           | Command Register              |
| 0x3008 | MPAHBRAM_CTRL_TGL         | RW          | Control Register              |
| 0x300C | MPAHBRAM_ECCER-RADDR0_TGL | RH          | ECC Error Address 0           |
| 0x3010 | MPAHBRAM_ECCER-RADDR1_TGL | RH          | ECC Error Address 1           |
| 0x3014 | MPAHBRAM_ECCER-RADDR2_TGL | RH          | ECC Error Address 2           |
| 0x3018 | MPAHBRAM_ECCER-RADDR3_TGL | RH          | ECC Error Address 3           |
| 0x301C | MPAHBRAM_ECCMER-RIND_TGL  | RH          | Multiple ECC Error Indication |
| 0x3020 | MPAHBRAM_IF_TGL           | RWH INTFLAG | Interrupt Flags               |
| 0x3024 | MPAHBRAM_IEN_TGL          | RW          | Interrupt Enable              |

## 6.6.8 MPAHBRAM Register Description

### 6.6.8.1 MPAHBRAM\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |           |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|-----------|
|        | 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 |           |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x2 |   |   |           |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     | R |   |           |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   | IPVERSION |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                       |
|------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0  | IPVERSION | 0x2   | R      | New BitField                                                                                                                                                                      |

## 6.6.8.2 MPAHBRAM\_CMD - Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--|--|--|
| 0x004  | 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 |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |  |

| Bit  | Name          | Reset | Access | Description                                                                                                                                                       |
|------|---------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3    | CLEARECCADDR3 | 0x0   | W(nB)  | <b>Clear ECCERRADDR3</b><br><br>Write 1 to clear ECCERRADDR3 and ECCMERRIND.P3.                                                                                   |
| 2    | CLEARECCADDR2 | 0x0   | W(nB)  | <b>Clear ECCERRADDR2</b><br><br>Write 1 to clear ECCERRADDR2 and ECCMERRIND.P2.                                                                                   |
| 1    | CLEARECCADDR1 | 0x0   | W(nB)  | <b>Clear ECCERRADDR1</b><br><br>Write 1 to clear ECCERRADDR1 and ECCMERRIND.P1.                                                                                   |
| 0    | CLEARECCADDR0 | 0x0   | W(nB)  | <b>Clear ECCERRADDR0</b><br><br>Write 1 to clear ECCERRADDR0 and ECCMERRIND.P0.                                                                                   |

## 6.6.8.3 MPAHBRAM\_CTRL - Control Register

| Offset     | Bit Position |     |    |             |    |     |    |                 |    |     |    |               |    |     |    |        |    |     |    |       |    |     |   |   |
|------------|--------------|-----|----|-------------|----|-----|----|-----------------|----|-----|----|---------------|----|-----|----|--------|----|-----|----|-------|----|-----|---|---|
| 0x008      | 31           | 30  | 29 | 28          | 27 | 26  | 25 | 24              | 23 | 22  | 21 | 20            | 19 | 18  | 17 | 16     | 15 | 14  | 13 | 12    | 11 | 10  | 9 | 8 |
| Reset      |              |     |    |             |    |     |    |                 |    |     |    |               |    |     |    |        |    |     |    |       |    |     |   |   |
| Access     |              |     |    |             |    |     |    |                 |    |     |    |               |    |     |    |        |    |     |    |       |    |     |   |   |
| Name       |              |     |    |             |    |     |    |                 |    |     |    |               |    |     |    |        |    |     |    |       |    |     |   |   |
| WAITSTATES | RW           | 0x0 | 7  | ADDRFAULTEN | RW | 0x1 | 6  | AHBPORTPRIORITY | RW | 0x0 | 4  | ECCERRFAULTEN | RW | 0x0 | 2  | ECCWEN | RW | 0x0 | 1  | ECCEN | RW | 0x0 | 0 |   |

| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Name            | Reset                             | Access | Description                                                                                                                                                       |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|------|-----------------------------------|---|-------|---------------------------------|---|-------|---------------------------------|---|-------|---------------------------------|---|-------|---------------------------------|
| 31:8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reserved        |                                   |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | WAITSTATES      | 0x0                               | RW     | <b>RAM read wait states</b><br><br>Configure the number of wait states upon RAM read access. Must be set to 1 if the clock frequency is above N MHz.              |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ADDRFAULTEN     | 0x1                               | RW     | <b>Address fault bus fault enable</b><br><br>Enable bus fault upon address fault                                                                                  |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 5:3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | AHBPORTPRIORITY | 0x0                               | RW     | <b>AHB port arbitration priority</b>                                                                                                                              |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| <hr/>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |                                   |        |                                                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| <table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>NONE</td> <td>No AHB port have raised priority.</td> </tr> <tr> <td>1</td> <td>PORT0</td> <td>AHB port 0 has raised priority.</td> </tr> <tr> <td>2</td> <td>PORT1</td> <td>AHB port 1 has raised priority.</td> </tr> <tr> <td>3</td> <td>PORT2</td> <td>AHB port 2 has raised priority.</td> </tr> <tr> <td>4</td> <td>PORT3</td> <td>AHB port 3 has raised priority.</td> </tr> </tbody> </table> |                 |                                   |        |                                                                                                                                                                   | Value | Mode | Description | 0 | NONE | No AHB port have raised priority. | 1 | PORT0 | AHB port 0 has raised priority. | 2 | PORT1 | AHB port 1 has raised priority. | 3 | PORT2 | AHB port 2 has raised priority. | 4 | PORT3 | AHB port 3 has raised priority. |
| Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Mode            | Description                       |        |                                                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | NONE            | No AHB port have raised priority. |        |                                                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PORT0           | AHB port 0 has raised priority.   |        |                                                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PORT1           | AHB port 1 has raised priority.   |        |                                                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PORT2           | AHB port 2 has raised priority.   |        |                                                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PORT3           | AHB port 3 has raised priority.   |        |                                                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ECCERRFAULTEN   | 0x0                               | RW     | <b>ECC Error bus fault enable</b><br><br>Enable bus fault upon 2 bit ECC error                                                                                    |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ECCWEN          | 0x0                               | RW     | <b>Enable ECC syndrome writes</b>                                                                                                                                 |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ECCEN           | 0x0                               | RW     | <b>Enable ECC functionality</b>                                                                                                                                   |       |      |             |   |      |                                   |   |       |                                 |   |       |                                 |   |       |                                 |   |       |                                 |

**6.6.8.4 MPAHBRAM\_ECCERRADDR0 - ECC Error Address 0**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00C         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | ADDR         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                         | Name | Reset | Access | Description              |
|-----------------------------------------------------------------------------|------|-------|--------|--------------------------|
| 31:0                                                                        | ADDR | 0x0   | R      | <b>ECC Error Address</b> |
| Last captured ECC error address on AHB port 0. Cleared by CMD.CLEARECCADDR0 |      |       |        |                          |

**6.6.8.5 MPAHBRAM\_ECCERRADDR1 - ECC Error Address 1**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x010         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | ADDR         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                         | Name | Reset | Access | Description              |
|-----------------------------------------------------------------------------|------|-------|--------|--------------------------|
| 31:0                                                                        | ADDR | 0x0   | R      | <b>ECC Error Address</b> |
| Last captured ECC error address on AHB port 1. Cleared by CMD.CLEARECCADDR1 |      |       |        |                          |

**6.6.8.6 MPAHBRAM\_ECCERRADDR2 - ECC Error Address 2**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x014         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | ADDR         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                         | Name | Reset | Access | Description              |
|-----------------------------------------------------------------------------|------|-------|--------|--------------------------|
| 31:0                                                                        | ADDR | 0x0   | R      | <b>ECC Error Address</b> |
| Last captured ECC error address on AHB port 2. Cleared by CMD.CLEARECCADDR2 |      |       |        |                          |

**6.6.8.7 MPAHBRAM\_ECCERRADDR3 - ECC Error Address 3**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x018         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | ADDR         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                         | Name | Reset | Access | Description              |
|-----------------------------------------------------------------------------|------|-------|--------|--------------------------|
| 31:0                                                                        | ADDR | 0x0   | R      | <b>ECC Error Address</b> |
| Last captured ECC error address on AHB port 3. Cleared by CMD.CLEARECCADDR3 |      |       |        |                          |

**6.6.8.8 MPAHBRAM\_ECCMERRIND - Multiple ECC Error Indication**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x01C         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | P3 P2 P1 P0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                        | Name     | Reset                                                                                                                                                                      | Access | Description                              |
|----------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------|
| 31:4                                                                       | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                          |
|                                                                            |          |                                                                                                                                                                            |        |                                          |
| 3                                                                          | P3       | 0x0                                                                                                                                                                        | R      | <b>Multiple ECC errors on AHB port 2</b> |
| Multiple ECC error indication on AHB port 3. Cleared by CMD.CLEARECCADDR3. |          |                                                                                                                                                                            |        |                                          |
| 2                                                                          | P2       | 0x0                                                                                                                                                                        | R      | <b>Multiple ECC errors on AHB port 2</b> |
| Multiple ECC error indication on AHB port 2. Cleared by CMD.CLEARECCADDR2. |          |                                                                                                                                                                            |        |                                          |
| 1                                                                          | P1       | 0x0                                                                                                                                                                        | R      | <b>Multiple ECC errors on AHB port 1</b> |
| Multiple ECC error indication on AHB port 1. Cleared by CMD.CLEARECCADDR1. |          |                                                                                                                                                                            |        |                                          |
| 0                                                                          | P0       | 0x0                                                                                                                                                                        | R      | <b>Multiple ECC errors on AHB port 0</b> |
| Multiple ECC error indication on AHB port 0. Cleared by CMD.CLEARECCADDR0. |          |                                                                                                                                                                            |        |                                          |

## 6.6.8.9 MPAHBRAM\_IF - Interrupt Flags

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |     |    |           |    |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|-----|----|-----------|----|-----|---|
| 0x020         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15        | 14 | 13  | 12 | 11        | 10 | 9   | 8 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |     |    |           |    |     |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |     |    |           |    |     |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AHB3ERR2B | RW | 0x0 | 7  | AHB2ERR2B | RW | 0x0 | 6 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AHB1ERR2B | RW | 0x0 | 5  | AHB0ERR2B | RW | 0x0 | 4 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AHB3ERR1B | RW | 0x0 | 3  | AHB2ERR1B | RW | 0x0 | 2 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AHB1ERR1B | RW | 0x0 | 1  | AHB0ERR1B | RW | 0x0 | 0 |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7    | AHB3ERR2B       | 0x0   | RW     | <b>AHB3 2-bit ECC Error Interrupt Flag</b>                                                                                                                                        |
| 6    | AHB2ERR2B       | 0x0   | RW     | <b>AHB2 2-bit ECC Error Interrupt Flag</b>                                                                                                                                        |
| 5    | AHB1ERR2B       | 0x0   | RW     | <b>AHB1 2-bit ECC Error Interrupt Flag</b>                                                                                                                                        |
| 4    | AHB0ERR2B       | 0x0   | RW     | <b>AHB0 2-bit ECC Error Interrupt Flag</b>                                                                                                                                        |
| 3    | AHB3ERR1B       | 0x0   | RW     | <b>AHB3 1-bit ECC Error Interrupt Flag</b>                                                                                                                                        |
| 2    | AHB2ERR1B       | 0x0   | RW     | <b>AHB2 1-bit ECC Error Interrupt Flag</b>                                                                                                                                        |
| 1    | AHB1ERR1B       | 0x0   | RW     | <b>AHB1 1-bit ECC Error Interrupt Flag</b>                                                                                                                                        |
| 0    | AHB0ERR1B       | 0x0   | RW     | <b>AHB0 1-bit ECC Error Interrupt Flag</b>                                                                                                                                        |

## 6.6.8.10 MPAHBRAM\_IEN - Interrupt Enable

| Offset | Bit Position |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |           |    |  |  |  |
|--------|--------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----|--|--|--|
| Reset  | 31           | 30        | 29        | 28        | 27        | 26        | 25        | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        | 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |           |           |           |           |    |  |  |  |
| Access | RW           | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW |  |  |  |
| Name   | AHB3ERR2B    | AHB2ERR2B | AHB1ERR2B | AHB0ERR2B | AHB3ERR1B | AHB2ERR1B | AHB1ERR1B | AHB0ERR1B | AHB3ERR2B | AHB2ERR2B | AHB1ERR2B | AHB0ERR2B | AHB3ERR1B | AHB2ERR1B | AHB1ERR1B | AHB0ERR1B | AHB3ERR2B | AHB2ERR2B | AHB1ERR2B | AHB0ERR2B | AHB3ERR1B | AHB2ERR1B | AHB1ERR1B | AHB0ERR1B | AHB3ERR2B | AHB2ERR2B | AHB1ERR2B | AHB0ERR2B |    |  |  |  |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                       |
|------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7    | AHB3ERR2B | 0x0   | RW     | <b>AHB3 2-bit ECC Error Interrupt Enable</b>                                                                                                                                      |
| 6    | AHB2ERR2B | 0x0   | RW     | <b>AHB2 2-bit ECC Error Interrupt Enable</b>                                                                                                                                      |
| 5    | AHB1ERR2B | 0x0   | RW     | <b>AHB1 2-bit ECC Error Interrupt Enable</b>                                                                                                                                      |
| 4    | AHB0ERR2B | 0x0   | RW     | <b>AHB0 2-bit ECC Error Interrupt Enable</b>                                                                                                                                      |
| 3    | AHB3ERR1B | 0x0   | RW     | <b>AHB3 1-bit ECC Error Interrupt Enable</b>                                                                                                                                      |
| 2    | AHB2ERR1B | 0x0   | RW     | <b>AHB2 1-bit ECC Error Interrupt Enable</b>                                                                                                                                      |
| 1    | AHB1ERR1B | 0x0   | RW     | <b>AHB1 1-bit ECC Error Interrupt Enable</b>                                                                                                                                      |
| 0    | AHB0ERR1B | 0x0   | RW     | <b>AHB0 1-bit ECC Error Interrupt Enable</b>                                                                                                                                      |

## 6.7 MSC Register Map

The offset register address is relative to the registers base address.

| Offset | Name                 | Type | Description                             |
|--------|----------------------|------|-----------------------------------------|
| 0x000  | MSC_IPVERSION        | R    | IP Version ID                           |
| 0x004  | MSC_READCTRL         | RW   | Read Control Register                   |
| 0x008  | MSC_RDATACTRL        | RW   | Read Data Control Register              |
| 0x00C  | MSC_WRITECTRL        | RW   | Write Control Register                  |
| 0x010  | MSC_WRITECMD         | W    | Write Command Register                  |
| 0x014  | MSC_ADDRB            | RWH  | Page Erase/Write Address Buffer         |
| 0x018  | MSC_WDATA            | RWH  | Write Data Register                     |
| 0x01C  | MSC_STATUS           | RH   | Status Register                         |
| 0x020  | MSC_IF               | RWH  | Interrupt Flag Register                 |
| 0x024  | MSC_IEN              | RW   | Interrupt Enable Register               |
| 0x034  | MSC_USERDATASIZE     | R    | User Data Region Size Register          |
| 0x038  | MSC_CMD              | W    | Command Register                        |
| 0x03C  | MSC_LOCK             | W    | Configuration Lock Register             |
| 0x040  | MSC_MISCLKWORD       | RW   | Mass Erase and User Data Page Lock Word |
| 0x050  | MSC_PWRCTRL          | RW   | Power Control Register                  |
| 0x120  | MSC_PAGELOCK0        | RW   | Main Space Page 0-31 Lock Word          |
| 0x124  | MSC_PAGELOCK1        | RW   | Main Space Page 32-63 Lock Word         |
| 0x128  | MSC_PAGELOCK2        | RW   | Main Space Page 64-95 Lock Word         |
| 0x12C  | MSC_PAGELOCK3        | RW   | Main Space Page 96-127 Lock Word        |
| 0x130  | MSC_PAGELOCK4        | RW   | Main Space Page 128-159 Lock Word       |
| 0x134  | MSC_PAGELOCK5        | RW   | Main Space Page 160-191 Lock Word       |
| 0x1000 | MSC_IPVERSION_SET    | R    | IP Version ID                           |
| 0x1004 | MSC_READCTRL_SET     | RW   | Read Control Register                   |
| 0x1008 | MSC_RDATACTRL_SET    | RW   | Read Data Control Register              |
| 0x100C | MSC_WRITECTRL_SET    | RW   | Write Control Register                  |
| 0x1010 | MSC_WRITECMD_SET     | W    | Write Command Register                  |
| 0x1014 | MSC_ADDRB_SET        | RWH  | Page Erase/Write Address Buffer         |
| 0x1018 | MSC_WDATA_SET        | RWH  | Write Data Register                     |
| 0x101C | MSC_STATUS_SET       | RH   | Status Register                         |
| 0x1020 | MSC_IF_SET           | RWH  | Interrupt Flag Register                 |
| 0x1024 | MSC_IEN_SET          | RW   | Interrupt Enable Register               |
| 0x1034 | MSC_USERDATASIZE_SET | R    | User Data Region Size Register          |
| 0x1038 | MSC_CMD_SET          | W    | Command Register                        |
| 0x103C | MSC_LOCK_SET         | W    | Configuration Lock Register             |
| 0x1040 | MSC_MISCLKWORD_SET   | RW   | Mass Erase and User Data Page Lock Word |

| Offset | Name                                 | Type | Description                             |
|--------|--------------------------------------|------|-----------------------------------------|
| 0x1050 | <a href="#">MSC_PWRCTRL_SET</a>      | RW   | Power Control Register                  |
| 0x1120 | <a href="#">MSC_PAGELOCK0_SET</a>    | RW   | Main Space Page 0-31 Lock Word          |
| 0x1124 | <a href="#">MSC_PAGELOCK1_SET</a>    | RW   | Main Space Page 32-63 Lock Word         |
| 0x1128 | <a href="#">MSC_PAGELOCK2_SET</a>    | RW   | Main Space Page 64-95 Lock Word         |
| 0x112C | <a href="#">MSC_PAGELOCK3_SET</a>    | RW   | Main Space Page 96-127 Lock Word        |
| 0x1130 | <a href="#">MSC_PAGELOCK4_SET</a>    | RW   | Main Space Page 128-159 Lock Word       |
| 0x1134 | <a href="#">MSC_PAGELOCK5_SET</a>    | RW   | Main Space Page 160-191 Lock Word       |
| 0x2000 | <a href="#">MSC_IPVERSION_CLR</a>    | R    | IP Version ID                           |
| 0x2004 | <a href="#">MSC_READCTRL_CLR</a>     | RW   | Read Control Register                   |
| 0x2008 | <a href="#">MSC_RDATACTRL_CLR</a>    | RW   | Read Data Control Register              |
| 0x200C | <a href="#">MSC_WRITECTRL_CLR</a>    | RW   | Write Control Register                  |
| 0x2010 | <a href="#">MSC_WRITECMD_CLR</a>     | W    | Write Command Register                  |
| 0x2014 | <a href="#">MSC_ADDRB_CLR</a>        | RWH  | Page Erase/Write Address Buffer         |
| 0x2018 | <a href="#">MSC_WDATA_CLR</a>        | RWH  | Write Data Register                     |
| 0x201C | <a href="#">MSC_STATUS_CLR</a>       | RH   | Status Register                         |
| 0x2020 | <a href="#">MSC_IF_CLR</a>           | RWH  | Interrupt Flag Register                 |
| 0x2024 | <a href="#">MSC_IEN_CLR</a>          | RW   | Interrupt Enable Register               |
| 0x2034 | <a href="#">MSC_USERDATASIZE_CLR</a> | R    | User Data Region Size Register          |
| 0x2038 | <a href="#">MSC_CMD_CLR</a>          | W    | Command Register                        |
| 0x203C | <a href="#">MSC_LOCK_CLR</a>         | W    | Configuration Lock Register             |
| 0x2040 | <a href="#">MSC_MISCLOCKWORD_CLR</a> | RW   | Mass Erase and User Data Page Lock Word |
| 0x2050 | <a href="#">MSC_PWRCTRL_CLR</a>      | RW   | Power Control Register                  |
| 0x2120 | <a href="#">MSC_PAGELOCK0_CLR</a>    | RW   | Main Space Page 0-31 Lock Word          |
| 0x2124 | <a href="#">MSC_PAGELOCK1_CLR</a>    | RW   | Main Space Page 32-63 Lock Word         |
| 0x2128 | <a href="#">MSC_PAGELOCK2_CLR</a>    | RW   | Main Space Page 64-95 Lock Word         |
| 0x212C | <a href="#">MSC_PAGELOCK3_CLR</a>    | RW   | Main Space Page 96-127 Lock Word        |
| 0x2130 | <a href="#">MSC_PAGELOCK4_CLR</a>    | RW   | Main Space Page 128-159 Lock Word       |
| 0x2134 | <a href="#">MSC_PAGELOCK5_CLR</a>    | RW   | Main Space Page 160-191 Lock Word       |
| 0x3000 | <a href="#">MSC_IPVERSION_TGL</a>    | R    | IP Version ID                           |
| 0x3004 | <a href="#">MSC_READCTRL_TGL</a>     | RW   | Read Control Register                   |
| 0x3008 | <a href="#">MSC_RDATACTRL_TGL</a>    | RW   | Read Data Control Register              |
| 0x300C | <a href="#">MSC_WRITECTRL_TGL</a>    | RW   | Write Control Register                  |
| 0x3010 | <a href="#">MSC_WRITECMD_TGL</a>     | W    | Write Command Register                  |
| 0x3014 | <a href="#">MSC_ADDRB_TGL</a>        | RWH  | Page Erase/Write Address Buffer         |
| 0x3018 | <a href="#">MSC_WDATA_TGL</a>        | RWH  | Write Data Register                     |
| 0x301C | <a href="#">MSC_STATUS_TGL</a>       | RH   | Status Register                         |
| 0x3020 | <a href="#">MSC_IF_TGL</a>           | RWH  | Interrupt Flag Register                 |

| Offset | Name                                 | Type | Description                             |
|--------|--------------------------------------|------|-----------------------------------------|
| 0x3024 | <a href="#">MSC_IEN_TGL</a>          | RW   | Interrupt Enable Register               |
| 0x3034 | <a href="#">MSC_USERDATASIZE_TGL</a> | R    | User Data Region Size Register          |
| 0x3038 | <a href="#">MSC_CMD_TGL</a>          | W    | Command Register                        |
| 0x303C | <a href="#">MSC_LOCK_TGL</a>         | W    | Configuration Lock Register             |
| 0x3040 | <a href="#">MSC_MISCLOCKWORD_TGL</a> | RW   | Mass Erase and User Data Page Lock Word |
| 0x3050 | <a href="#">MSC_PWRCTRL_TGL</a>      | RW   | Power Control Register                  |
| 0x3120 | <a href="#">MSC_PAGELOCK0_TGL</a>    | RW   | Main Space Page 0-31 Lock Word          |
| 0x3124 | <a href="#">MSC_PAGELOCK1_TGL</a>    | RW   | Main Space Page 32-63 Lock Word         |
| 0x3128 | <a href="#">MSC_PAGELOCK2_TGL</a>    | RW   | Main Space Page 64-95 Lock Word         |
| 0x312C | <a href="#">MSC_PAGELOCK3_TGL</a>    | RW   | Main Space Page 96-127 Lock Word        |
| 0x3130 | <a href="#">MSC_PAGELOCK4_TGL</a>    | RW   | Main Space Page 128-159 Lock Word       |
| 0x3134 | <a href="#">MSC_PAGELOCK5_TGL</a>    | RW   | Main Space Page 160-191 Lock Word       |

## 6.8 MSC Register Description

### 6.8.1 MSC\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x3          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name          | Reset | Access | Description   |
|------|---------------|-------|--------|---------------|
| 31:0 | IPVERSION     | 0x3   | R      | IP Version ID |
|      | IP Version ID |       |        |               |

## 6.8.2 MSC\_READCTRL - Read Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x004  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    | 0x2  |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    | RW   |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    | MODE |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                            |
| 21:20 | MODE     | 0x2   | RW     | <b>Read Mode</b>                                                                                                                                                                                                                                                                                                                                                                             |
|       |          |       |        | When changing to a higher frequency, this register must be set to a large number of wait states before the core clock is switched to the higher frequency. When changing to a lower frequency, this register should be set to a lower number of wait states after the frequency transition has been completed. The maximum frequency for each wait state setting is listed in the datasheet. |
|       |          |       |        |                                                                                                                                                                                                                                                                                                                                                                                              |
| Value | Mode     |       |        | Description                                                                                                                                                                                                                                                                                                                                                                                  |
| 0     | WS0      |       |        | Zero wait-states inserted in fetch or read transfers                                                                                                                                                                                                                                                                                                                                         |
| 1     | WS1      |       |        | One wait-state inserted for each fetch or read transfer. See Flash Wait-States table for details                                                                                                                                                                                                                                                                                             |
| 2     | WS2      |       |        | Two wait-states inserted for each fetch or read transfer. See Flash Wait-States table for details                                                                                                                                                                                                                                                                                            |
| 3     | WS3      |       |        | Three wait-states inserted for each fetch or read transfer. See Flash Wait-States table for details                                                                                                                                                                                                                                                                                          |
|       |          |       |        |                                                                                                                                                                                                                                                                                                                                                                                              |
| 19:0  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                            |

## 6.8.3 MSC\_RDATACTRL - Read Data Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------|---|---|---|---|---|---|
| 0x008  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0       |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW        |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DOUTBUFEN |   |   |   |   |   |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | AFDIS     |   |   |   |   |   |   |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | DOUTBUFEN | 0x1   | RW     | <b>Flash dout pipeline buffer enable</b><br><br>Flag to enable or bypass flash data output buffer                                                                                 |
| 11:2  | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1     | AFDIS     | 0x0   | RW     | <b>Automatic Invalidate Disable</b><br><br>When this bit is set the cache is not automatically invalidated when a write or page erase is performed.                               |
| 0     | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 6.8.4 MSC\_WRITECTRL - Write Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |         |     |   |   |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---------|-----|---|---|-----|---|
| 0x00C  | 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 |   |     |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |         |     |   |   |     |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW      | 0x0 | 1 | 2 | 0x0 | 0 |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    | RANGECOUNT |    |    |    |    |    |    |    |   |   |   |   |   |   |   | LPWRITE | 0x0 | 1 | 2 | 0x0 | 0 |

| Bit   | Name          | Reset | Access | Description                                                                                                                                                                                            |
|-------|---------------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                      |
| 25:16 | RANGECOUNT    | 0x0   | RW     | <b>EraseRange Count</b><br><br>Apply only with EraseRange command. Define number of pages to be erased.                                                                                                |
| 15:4  | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                      |
| 3     | LPWRITE       | 0x0   | RW     | <b>Low-Power Write</b><br><br>When set, write times might double while reducing current consumption                                                                                                    |
| 2     | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                      |
| 1     | IRQERASEABORT | 0x0   | RW     | <b>Abort Page Erase on Interrupt</b><br><br>When this bit is set to 1, any Cortex-M33 interrupt aborts any current page erase operation. Executing that interrupt vector from Flash will halt the CPU. |
| 0     | WREN          | 0x0   | RW     | <b>Enable Write/Erase Controller</b><br><br>When this bit is set, the MSC write and erase functionality is enabled                                                                                     |

## 6.8.5 MSC\_WRITECMD - Write Command Register

| Offset     | Bit Position |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------------|--------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 0x010      | 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 |  |  |  |  |
| Reset      |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Access     |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Name       |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| CLEARWDATA | W            | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| ERASEMAIN0 | W            | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| ERASEABORT | W            | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| ERASERANGE | W            | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| WRITEEND   | W            | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| ERASEPAGE  | W            | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                                                      |
|-------|------------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                |
| 12    | CLEARWDATA | 0x0   | W      | <b>Clear WDATA state</b><br><br>Will set WDATAREADY and DMA request. Should only be used when no write is active.                                                                                |
| 11:9  | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                |
| 8     | ERASEMAIN0 | 0x0   | W      | <b>Mass erase region 0</b><br><br>Initiate mass erase of flash memory. If MELOCKBIT in MSC_MISCLKWORD is set, user firmware cannot initiate mass erase, and only the SE may initiate mass erase. |
| 7:6   | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                |
| 5     | ERASEABORT | 0x0   | W      | <b>Abort erase sequence</b><br><br>Writing to this bit will abort an ongoing erase sequence.                                                                                                     |
| 4     | ERASERANGE | 0x0   | W      | <b>Erase range of pages</b><br><br>Erase a range of user defined pages started from the MSC_ADDRB register. The WREN bit in the MSC_WRITECTRL register must be set in order to use this command. |
| 3     | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                |
| 2     | WRITEEND   | 0x0   | W      | <b>End Write Mode</b><br><br>Write 1 to abort a write command.                                                                                                                                   |
| 1     | ERASEPAGE  | 0x0   | W      | <b>Erase Page</b><br><br>Erase any user defined page selected by the MSC_ADDRB register. The WREN bit in the MSC_WRITECTRL register must be set in order to use this command.                    |
| 0     | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                |

**6.8.6 MSC\_ADDRB - Page Erase/Write Address Buffer**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x014  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | ADDRB        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                   | Name  | Reset | Access | Description                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|--------|-------------------------------------------|
| 31:0                                                                                                                                                  | ADDRB | 0x0   | RW     | <b>Page Erase or Write Address Buffer</b> |
| This register holds the system address for the erase or write operation. Address should be word aligned address. The MSB bit is not ignored for ADDRB |       |       |        |                                           |

**6.8.7 MSC\_WDATA - Write Data Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x018  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DATAW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                        | Name  | Reset | Access | Description       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|--------|-------------------|
| 31:0                                                                                                                                                                       | DATAW | 0x0   | RW     | <b>Write Data</b> |
| The data to be written to the address in MSC_ADDRB. This register must be written when the WDATAREADY bit of MSC_STATUS is set. This register does not support write mask. |       |       |        |                   |

#### **6.8.8 MSC\_STATUS - Status Register**

| Bit   | Name                | Reset    | Access | Description                                                                                                                                                                          |
|-------|---------------------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | PWRUPCKBDFAIL-COUNT | 0x0      | R      | <b>Flash power up checkerboard pattern check</b>                                                                                                                                     |
|       |                     |          |        | This field tells how many times checkboard pattern check fail occurred after a reset sequence.                                                                                       |
| 27    | WREADY              | 0x1      | R      | <b>Flash Write Ready</b>                                                                                                                                                             |
|       |                     |          |        | When this bit is set, flash has completed the power up sequence and is ready for write/erase commands.                                                                               |
| 26:25 | Reserved            |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>    |
| 24    | PWRON               | 0x0      | R      | <b>Flash power on status</b>                                                                                                                                                         |
|       |                     |          |        | When this bit is set, flash is powered on. If zero, flash is powered off and reads from flash return indeterminate data.                                                             |
| 23:17 | Reserved            |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>    |
| 16    | REGLOCK             | 0x0      | R      | <b>Register Lock Status</b>                                                                                                                                                          |
|       |                     |          |        | Indicates the current status of register lock                                                                                                                                        |
|       | Value               | Mode     |        | Description                                                                                                                                                                          |
|       | 0                   | UNLOCKED |        |                                                                                                                                                                                      |
|       | 1                   | LOCKED   |        |                                                                                                                                                                                      |
| 15:8  | Reserved            |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>    |
| 7     | RANGEPARTIAL        | 0x0      | R      | <b>EraseRange with skipped locked pages</b>                                                                                                                                          |
| 6     | TIMEOUT             | 0x0      | R      | <b>Write Command Timeout</b>                                                                                                                                                         |
|       |                     |          |        | When this bit is set, it indicates that the last write command has completed due to a write buffer timeout. This bit is cleared automatically when a new write command is initiated. |
| 5     | PENDING             | 0x0      | R      | <b>Write Command In Queue</b>                                                                                                                                                        |
|       |                     |          |        | When this bit is set, a flash operation has been requested but not yet started. New commands are ignored when PENDING is set.                                                        |
| 4     | ERASEABORTED        | 0x0      | R      | <b>Erase Operation Aborted</b>                                                                                                                                                       |

| Bit | Name       | Reset | Access | Description                                                                                                                                                                                                           |
|-----|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |            |       |        | When MSC_WRITECTRL_IRQERASEABORT = 1, this bit is set because an interrupt has aborted the erase operation in progress.                                                                                               |
| 3   | WDATAREADY | 0x1   | R      | <b>WDATA Write Ready</b>                                                                                                                                                                                              |
|     |            |       |        | When this bit is set, the content of MSC_WDATA is read by MSC Flash Write Controller and the register may be updated with the next 32-bit word to be written to flash. This bit is cleared when writing to MSC_WDATA. |
| 2   | INVADDR    | 0x0   | R      | <b>Invalid Write Address or Erase Page</b>                                                                                                                                                                            |
|     |            |       |        | When this bit is set, software has attempted to load an invalid (unmapped) address into the MSC_ADDRB register.                                                                                                       |
| 1   | LOCKED     | 0x0   | R      | <b>Access Locked</b>                                                                                                                                                                                                  |
|     |            |       |        | When set, the last erase or write was aborted due to erase/write access constraints.                                                                                                                                  |
| 0   | BUSY       | 0x0   | R      | <b>Erase/Write Busy</b>                                                                                                                                                                                               |
|     |            |       |        | When set, an erase or write operation is in progress and new commands are ignored.                                                                                                                                    |

### 6.8.9 MSC\_IF - Interrupt Flag Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |        |        |         |       |       |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------|--------|---------|-------|-------|---|---|---|
| 0x020         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0    | 2      | 1       | 0     |       |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW     | RW     | RW      | RW    |       |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | PWRUFF | PWRUPF | WDATAOV | WRITE | ERASE |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                       |
|-------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9     | PWROFF   | 0x0   | RW     | <b>Flash Power Off Sequence Complete Flag</b>                                                                                                                     |
|       |          |       |        | Set after MSC_CMD.PWROFF received, flash powered off complete                                                                                                     |
| 8     | PWRUPF   | 0x0   | RW     | <b>Flash Power Up Sequence Complete Flag</b>                                                                                                                      |
|       |          |       |        | Set after MSC_CMD.PWRUP received, flash powered up complete and ready for read/write                                                                              |
| 7:3   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 2     | WDATAOV  | 0x0   | RW     | <b>Host write buffer overflow</b>                                                                                                                                 |
|       |          |       |        | If set, flash controller write buffer overflow detected                                                                                                           |
| 1     | WRITE    | 0x0   | RW     | <b>Host Write Done Interrupt Read Flag</b>                                                                                                                        |
|       |          |       |        | Set when a write is done                                                                                                                                          |
| 0     | ERASE    | 0x0   | RW     | <b>Host Erase Done Interrupt Read Flag</b>                                                                                                                        |
|       |          |       |        | Set when erase is done                                                                                                                                            |

## 6.8.10 MSC\_IEN - Interrupt Enable Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |        |         |       |       |         |       |       |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|--------|---------|-------|-------|---------|-------|-------|
| 0x024         | 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     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 0x0    | 0x0     | 0x0   | 0x0   | 0x0     |       |       |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW      | RW     | RW      | RW    | RW    | RW      |       |       |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | PWRROFF | PWRUPF | WDATAOV | WRITE | ERASE | WDATAOV | WRITE | ERASE |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9     | PWRROFF<br>interrupt enable | 0x0   | RW     | <b>Flash Power Off Seq done irq enable</b>                                                                                                                                        |
| 8     | PWRUPF<br>interrupt enable  | 0x0   | RW     | <b>Flash Power Up Seq done irq enable</b>                                                                                                                                         |
| 7:3   | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2     | WDATAOV<br>interrupt enable | 0x0   | RW     | <b>write data buffer overflow irq enable</b>                                                                                                                                      |
| 1     | WRITE<br>interrupt enable   | 0x0   | RW     | <b>Write Done Interrupt enable</b>                                                                                                                                                |
| 0     | ERASE<br>interrupt enable   | 0x0   | RW     | <b>Erase Done Interrupt enable</b>                                                                                                                                                |

**6.8.11 MSC\_USERDATASIZE - User Data Region Size Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------|---|
| 0x034         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x4          |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R            |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | USERDATASIZE |   |

| Bit  | Name         | Reset | Access | Description                                                                                                                                                                       |
|------|--------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:0  | USERDATASIZE | 0x4   | R      | <b>User Data Size</b><br><br>This field determines user data region size. SIZE = 256B * USERDATASIZE.                                                                             |

**6.8.12 MSC\_CMD - Command Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |       |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------|---|
| 0x038         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | PWRUP |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                                                                                         |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                   |
| 4    | PWROFF   | 0x0   | W      | <b>Flash power off/sleep command</b><br><br>Write to this bit to power down the Flash. User code should execute from RAM afterwards. Read from flash after flash being powered down will cause undetermined behavior. To power up, either set CMD.PWRUP bit or try read from flash. |
| 3:1  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                   |
| 0    | PWRUP    | 0x0   | W      | <b>Flash Power Up Command</b><br><br>Write to this bit to power up the Flash. IRQ PWRUPF will be fired when power up sequence completed.                                                                                                                                            |

**6.8.13 MSC\_LOCK - Configuration Lock Register**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---------|
| 0x03C         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0     |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | W       |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | LOCKKEY |

| Bit                                                                                                                                                                                                                    | Name     | Reset       | Access | Description                                                                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                                                                                                                                  | Reserved |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                                                                                                                                                                   | LOCKKEY  | 0x0         | W      | <b>Configuration Lock</b>                                                                                                                                                         |
| Write any other value than the unlock code to lock access to MSC_RDATACTRL, MSC_READCTRL, and MSC_WRITECTRL. Write the unlock code to enable access. When reading the register, bit 0 is set when the lock is enabled. |          |             |        |                                                                                                                                                                                   |
| Value                                                                                                                                                                                                                  | Mode     | Description |        |                                                                                                                                                                                   |
| 0                                                                                                                                                                                                                      | LOCK     |             |        |                                                                                                                                                                                   |
| 7025                                                                                                                                                                                                                   | UNLOCK   |             |        |                                                                                                                                                                                   |

**6.8.14 MSC\_MISCLOCKWORD - Mass Erase and User Data Page Lock Word**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x040         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit  | Name                                                                                                                         | Reset | Access | Description                                                                                                                                                                       |
|------|------------------------------------------------------------------------------------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved                                                                                                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | UDLOCKBIT                                                                                                                    | 0x1   | RW     | <b>User Data Lock</b>                                                                                                                                                             |
|      | Zero means host can write/erase to the user data area. Host is only allowed to write one. Root and debug can clear this bit. |       |        |                                                                                                                                                                                   |
| 3:1  | Reserved                                                                                                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | MELOCKBIT                                                                                                                    | 0x1   | RW     | <b>Mass Erase Lock</b>                                                                                                                                                            |
|      | Zero means host can mass erase the main space. Host is only allowed to write one. Root and debug can clear this bit.         |       |        |                                                                                                                                                                                   |

## 6.8.15 MSC\_PWRCTRL - Power Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |     |     |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------------|-----|-----|---|---|---|---|
| 0x050  | 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 |
| Reset  | 0x10         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0              | 4   | 3   | 2 | 1 | 0 |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW               | 0x1 | 1   | 0 | 0 |   |   |
| Name   | PWROFFDLY    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PWROFFENTRYAGAIN | RW  | 0x1 | 1 | 0 |   |   |

| Bit   | Name                   | Reset | Access | Description                                                                                                                                                                                                           |
|-------|------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved               |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                     |
| 23:16 | PWROFFDLY              | 0x10  | RW     | <b>Power down delay</b><br><br>Defines delay cycles before flash enters sleep mode. Works together with PWROFFENTRYAGAIN bit. The power off delay is 64 * PWROFFDLY bus clock cycles.                                 |
| 15:5  | Reserved               |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                     |
| 4     | PWROFFENTRYAGAIN       | 0x0   | RW     | <b>POWER down flash again in EM1/EM1p</b><br><br>If enabled, flash will enter sleep mode again when POWEROFFONEM1ENTRY/POWEROFFONEM1PENTRY is set and no flash activities occur for the time determined by PWROFFDLY. |
| 3:2   | Reserved               |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                     |
| 1     | PWROFFONEM1PEN-<br>TRY | 0x1   | RW     | <b>Power down Flash macro when enter EM1P</b><br><br>If enabled, flash will be in sleep mode when entering EM1P (radio-only sleep).                                                                                   |
| 0     | PWROFFONEM1EN-<br>TRY  | 0x0   | RW     | <b>Power down Flash macro when enter EM1</b><br><br>If enabled, flash will be in sleep mode when entering EM1.                                                                                                        |

**6.8.16 MSC\_PAGELOCK0 - Main Space Page 0-31 Lock Word**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x120  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | LOCKBIT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                                                                                                          | Name    | Reset | Access | Description          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|----------------------|
| 31:0                                                                                                                                                                                                                                                                                                         | LOCKBIT | 0x0   | RW     | <b>page lock bit</b> |
| Zero means the corresponding page is allowed to write/erase. change to one will prevent corresponding page from write/erase. bit[0] for main space page 0, and bit[1] for page 1... bit[31] for page 31. Reset to zero. Host is only allowed to write one. Root and Debug are allowed to clear this register |         |       |        |                      |

**6.8.17 MSC\_PAGELOCK1 - Main Space Page 32-63 Lock Word**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x124  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | LOCKBIT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                                                                                                            | Name    | Reset | Access | Description          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|----------------------|
| 31:0                                                                                                                                                                                                                                                                                                           | LOCKBIT | 0x0   | RW     | <b>page lock bit</b> |
| Zero means the corresponding page is allowed to write/erase. change to one will prevent corresponding page from write/erase. bit[0] for main space page 32, and bit[1] for page 33... bit[31] for page 63. Reset to zero. Host is only allowed to write one. Root and Debug are allowed to clear this register |         |       |        |                      |

**6.8.18 MSC\_PAGELOCK2 - Main Space Page 64-95 Lock Word**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x128  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | LOCKBIT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                                                                                                                                                                                                                                                                            | Name    | Reset | Access | Description          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|----------------------|
| 31:0                                                                                                                                                                                                                                                                                                           | LOCKBIT | 0x0   | RW     | <b>page lock bit</b> |
| Zero means the corresponding page is allowed to write/erase. change to one will prevent corresponding page from write/erase. bit[0] for main space page 64, and bit[1] for page 65... bit[31] for page 95. Reset to zero. Host is only allowed to write one. Root and Debug are allowed to clear this register |         |       |        |                      |

**6.8.19 MSC\_PAGELOCK3 - Main Space Page 96-127 Lock Word**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x12C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | LOCKBIT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                                                                                                             | Name    | Reset | Access | Description          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|----------------------|
| 31:0                                                                                                                                                                                                                                                                                                            | LOCKBIT | 0x0   | RW     | <b>page lock bit</b> |
| Zero means the corresponding page is allowed to write/erase. change to one will prevent corresponding page from write/erase. bit[0] for main space page 96, and bit[1] for page 97... bit[31] for page 127. Reset to zero. Host is only allowed to write one. Root and Debug are allowed to clear this register |         |       |        |                      |

**6.8.20 MSC\_PAGELOCK4 - Main Space Page 128-159 Lock Word**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x130  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | LOCKBIT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                                                                                                                                                                                                                                                                               | Name    | Reset | Access | Description          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|----------------------|
| 31:0                                                                                                                                                                                                                                                                                                              | LOCKBIT | 0x0   | RW     | <b>page lock bit</b> |
| Zero means the corresponding page is allowed to write/erase. change to one will prevent corresponding page from write/erase. bit[0] for main space page 128, and bit[1] for page 129... bit[31] for page 159. Reset to zero. Host is only allowed to write one. Root and Debug are allowed to clear this register |         |       |        |                      |

**6.8.21 MSC\_PAGELOCK5 - Main Space Page 160-191 Lock Word**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x134  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | LOCKBIT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                                                                                                                                                                                                                                                                               | Name    | Reset | Access | Description          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|----------------------|
| 31:0                                                                                                                                                                                                                                                                                                              | LOCKBIT | 0x0   | RW     | <b>page lock bit</b> |
| Zero means the corresponding page is allowed to write/erase. change to one will prevent corresponding page from write/erase. bit[0] for main space page 160, and bit[1] for page 161... bit[31] for page 191. Reset to zero. Host is only allowed to write one. Root and Debug are allowed to clear this register |         |       |        |                      |

## 7. DBG - Debug Interface



### Quick Facts

#### What?

The Debug Interface is used to program and debug EFR32xG24 devices.

#### Why?

The Debug Interface makes it easy to re-program and update the system in the field, and allows debugging with minimal I/O pin usage.

#### How?

The Cortex®-M33 supports advanced debugging features. EFR32xG24 devices can use a minimum of two port pins for debugging or programming. The internal and external state of the system can be examined with debug extensions supporting instruction or data access break and watch points.

### 7.1 Introduction

The EFR32xG24 devices include hardware debug support through a 2-pin serial-wire debug (SWD) interface or a 4-pin Joint Test Action Group (JTAG) interface, as well as an Embedded Trace Module (ETM) for data/instruction tracing. In addition, there is also a Serial Wire Viewer pin which can be used to output profiling information, data trace and software-generated messages.

For more technical information about the debug interface the reader is referred to:

- ARM Cortex®-M33 Technical Reference Manual
- ARM CoreSight Components Technical Reference Manual
- ARM Debug Interface v5 Architecture Specification
- IEEE Standard for Test Access Port and Boundary-Scan Architecture, IEEE 1149.1-2013

### 7.2 Features

- Debug Access Port Serial Wire JTAG (DAPSWJ)
  - Implements the ADIv5 debug interface
- ARM Trustzone
  - Enables secure debugging
- Breakpoint unit (BPU)
  - Implement up to 8 hardware breakpoints
- Data Watch point and Trace (DWT) unit
  - Implement up to 4 watch points, trigger resources and system profiling
- Instrumentation Trace Macrocell (ITM)
  - Application-driven trace source that supports printf style debugging
- Embedded Trace Macrocell v3.5 (ETM)
  - Real time instruction and data trace information of the processor
- Cross Trigger Interface (CTI)
  - Issues synchronous triggers based on system events
  - Can be used to generate IRQs or route to PRS signalling

## 7.3 Functional Description

There are debug and trace pins available on the device. Operation of these pins is described in the following sections.

### 7.3.1 Debug Pins

The following pins are the debug connections for the device:

- Serial Wire Clock Input and Test Clock Input (SWCLKTCK) (SWCLK) : This pin is enabled after power-up and has a built-in pull-down.
- Serial Wire Data Input/Output and Test Mode Select Input (SWDIOTMS) (SWDIO) : This pin is enabled after power-up and has a built-in pull-up.
- Test Data Output (TDO): This pin is assigned to JTAG functionality after power-up. However, it remains in high-Z state until the first valid JTAG command is received.
- Test Data Input (TDI): This pin is assigned to JTAG functionality after power-up. However, it remains in high-Z state until the first valid JTAG command is received. Once enabled, the pin has a built-in pull-up.
- Serial Wire Viewer (SWV): This pin is disabled after reset.

The debug pins have integrated pull devices that are enabled by default after a reset. Leaving them enabled may increase current consumption if the pins are connected to power or ground. The debug pins have enable bits in the GPIO\_DBGROUTEOPEN register; refer to the GPIO chapter for more details. Upon disabling the debug pins, debug contact with the device is lost once the DAPSWJ power request bits are deasserted. By default after a power cycle, the DAPSWJ is in JTAG mode. If during a debugging session the device is switched to SWD mode, a power cycle is needed to return to JTAG mode.

### 7.3.2 Embedded Trace Macrocell (ETM)

ETM makes it possible to non-intrusively trace both instruction and data from the processor in real time. Trace can be controlled through a set of triggering and filtering resources. The resources include 4 address comparators, 2 data value comparators, 2 counters, a context ID comparator and a sequencer. Before enabling the ETM, the CMU\_TRACECLKCTRL register must be configured to select the desired trace clock source. (See the CMU chapter for details.)

The trace can be exported through a set of trace pins, which include:

- Trace Clock (TRACECLK): Functions as a sample clock for the trace. This pin is disabled after reset.
- Trace Data 0-3 (TRACEDATA0, TRACEDATA1, TRACEDATA2, TRACEDATA3): The trace data pins provide the compressed trace stream. These pins are disabled after reset.

For information on how to configure the ETM, see the ARM Embedded Trace Macrocell Architecture Specification. The Trace Clock and Trace Data pins are enabled through a GPIO register. For more information on how to enable the ETM pins, refer to the GPIO chapter.

### 7.3.3 Debug and EM2/EM3

Debug connectivity in EM2 and EM3 is unavailable by default, to reduce current consumption. Debugging through EM2 and EM3 can be enabled by setting the EM2DBGGEN bit in the EMU\_CTRL register. Setting EM2DBGGEN ensures that power domain associated with the debug circuitry will remain active, but will result in a small amount of additional current in EM2 and EM3.

Leaving the debugger connected when issuing a WFI or WFE to enter EM2 or EM3 will make the system enter a special EM2 mode. This mode differs from regular EM2 and EM3 in that the high frequency clocks are still enabled, and certain core functionality is still powered in order to maintain debug functionality. Because of this, the current consumption in this mode is closer to EM1, and it is, therefore, important to deassert the power requests in the DAPSWJ and disconnect the debugger before undertaking current consumption measurements.

## 8. CMU - Clock Management Unit



### Quick Facts

#### What?

The CMU controls clock switching and distribution. EFR32xG24 supports several different oscillators with minimized power consumption and short start-up time. The CMU has HW support for calibration of RC oscillators.

#### Why?

Oscillators and clocks contribute significantly to the power consumption of the MCU. With the low power oscillators combined with the flexible clock control scheme, it is possible to minimize the energy consumption in any given application.

#### How?

The CMU switches different clock sources for various peripherals and sets the prescaler for the bus clocks. The short oscillator start-up times makes duty-cycling between active mode and the different low energy modes (EM2 DeepSleep, EM3 Stop, and EM4) very efficient. The calibration feature ensures high accuracy RC oscillators. Interrupts are available to avoid CPU polling of flags.

### 8.1 Introduction

The Clock Management Unit (CMU) is responsible for switching among various oscillator sources and provides clocks to the peripheral modules. Oscillators are automatically turned on and off based on demand from the peripherals to minimize power consumption.

### 8.2 Features

- Multiple clock sources available:
  - 38 MHz - 40 MHz High Frequency Crystal Oscillator (HFXO)
  - 1 MHz - 80 MHz High Frequency RC Oscillator (HFRCODPLL)
  - 1 MHz - 40 MHz Deep Sleep High Frequency RC Oscillator (HFRCOEM23)
  - 20 MHz Fast Startup RC Oscillator (FSRCO)
  - 1 MHz - 38 MHz External Clock from Input Pins (CLKIN0)
  - 32.768 kHz Low Frequency Crystal Oscillator (LFXO)
  - 32.768 kHz Low Frequency RC Oscillator (LFRCO) with Precision Mode
  - 1000 Hz Ultra Low Frequency RC Oscillator (ULFRCO)
- On-demand oscillator request.
- Low power oscillators.
- Fast start-up times.
- Cascaded prescalers for AHB Clocks (HCLK) and APB Clocks (PCLK).
- Clock gating on an individual basis to all peripherals based on module enable.
- Reset on an individual basis for Timer and IADC based on module enable.
- Selectable clocks can be output on external pins and/or PRS.
- Deep Sleep High Frequency RC oscillator (HFRCOEM23) or the Fast-start oscillator (FSRCO), which are asynchronous to the system clock, can be selected for IADC or VDAC0/1 operation in EM2.
- Hardware support for calibration of RC oscillators.

### 8.3 Functional Description

The CMU is comprised of several programmable clock trees, which connect oscillator resources to peripherals and buses. This section describes clock sources and peripherals available to the largest devices in the EFR32xG24 family. Please refer to the Configuration Summary in the Device Datasheet to see which core and peripheral modules, and therefore clock connections, are present in a specific device. Bus clock selection, including peripherals clocked directly from bus clocks, is shown in [Figure 8.1 Bus Clocks on page 149](#). Clock selection for peripherals with multiple high-frequency clock sources is shown in [Figure 8.2 High Frequency Peripheral Clocks on page 150](#). Clock selection for peripherals with multiple low-frequency clock sources is shown in [Figure 8.3 Low Frequency Peripheral Clocks on page 151](#). Clock selection for peripherals that can select from a high or low frequency clock source is shown in [Figure 8.4 Mixed Frequency Peripheral Clocks on page 152](#).



Figure 8.1. Bus Clocks



Figure 8.2. High Frequency Peripheral Clocks



#### Availability of oscillators and clocks in Energy Modes:

- Available in EM0/EM1
- Available in EM0/EM1/EM2
- Available in EM0/EM1/EM2/EM3
- Available in EM0/EM1/EM2/EM4
- Available in EM0/EM1/EM2/EM3/EM4



Figure 8.3. Low Frequency Peripheral Clocks

**Figure 8.4. Mixed Frequency Peripheral Clocks**

### 8.3.1 System Clocks

### 8.3.1.1 SYSCLK - Bus Clock

SYSCLK is the selected System Clock. HCLK is an optionally prescaled version of SYSCLK. PCLK is an optionally prescaled version of HCLK. The SYSCLK, and therefore HCLK and PCLK, can be driven by a high-frequency oscillator or be driven from a pin. The system boots using the FSRCO oscillator, and switches to HFRCODPLL before user firmware execution begins. To change the selected clock source, write to the CLKSEL bitfield in CMU\_SYSCLKCTRL. If an invalid option is programmed into CLKSEL, FSRCO will be selected. The SYSCLK is running in EM0 Active and EM1 Sleep and is automatically stopped in EM2 DeepSleep.

The prescaler setting can be changed dynamically and the new setting takes effect immediately. When switching to a higher frequency oscillator source, prescaler setting should be adjusted before clock selection to prevent over clocking. For the same reason, when switching to a lower frequency oscillator source, prescaler setting cannot be adjusted until the clock selection is made.

The HFXO clock is fed directly to the Radio Transceiver. The clock received by the Radio Transceiver is therefore not affected by the selected clock source for SYSCLK nor by any clock prescaler.

### 8.3.1.2 HCLK - AHB Clock

HCLK is a prescaled version of SYSCLK. This clock drives the AHB bus interface. HCLK can be prescaled by setting HCLKPRESC in CMU\_SYSCLKCTRL to DIV2 or DIV4. This prescales HCLK to all AHB bus clocks and is typically used to save energy in applications where the system is not required to run at the highest frequency. The setting can be changed dynamically and the new setting takes effect immediately. Some of the modules that are driven by this clock can be clock gated completely when not in use. This is done by clearing the module enable (EN) bit in the module's EN register.

### 8.3.1.3 PCLK - APB Clock

PCLK is a prescaled version of HCLK. This clock drives the APB bus interface. PCLK can be prescaled by setting PCLKPRESC in CMU\_SYSCLKCTRL to DIV2. This prescales PCLK to all APB bus clocks and is necessary to prevent PCLK from exceeding the maximum frequency when HCLK is operated at above 40 MHz. The setting can be changed dynamically and the new setting takes effect immediately. Some of the peripherals that are driven by this clock can be clock gated completely when not in use. This is done by clearing the module enable (EN) bit in the module's EN register.

### 8.3.1.4 LSPCLK - Low Speed APB Clock

LSPCLK is a prescaled version of PCLK. This clock drives the Low Speed APB bus interface. LSPCLK is always prescaled by two. This prescales LSPCLK to all Low Speed APB bus clocks. Some of the peripherals that are driven by this clock can be clock gated completely when not in use. This is done by clearing the module enable (EN) bit in the module's EN register.

### 8.3.1.5 RHCLK - AHB Radio Clock

The radio AHB clock (RHCLK) is a prescaled version of SYSCLK. The maximum frequency for RHCLK is 40 MHz. The RHCLKPRESC setting in CMU\_SYSCLKCTRL allows for SYSCLK to pass through (DIV1) or apply a divide-by-2 (DIV2) to the clock.

### 8.3.1.6 EM01GRPACLK - Energy Mode 01 Group A Clock

EM01GRPACLK is the selected clock for the Group A Peripherals operating in Energy Modes 0 or 1. These are typically high clock frequency peripheral modules. There are several selectable sources for EM01GRPACLK: HFXO, HFRCODPLL, HFRCOEM23, and FSRCO. In addition, the EM01GRPACLK can be disabled. The selection is configured using the CLKSEL field in CMU\_EM01GRPACLKCTRL.

Each High Frequency Peripheral that is clocked by EM01GRPACLK may have its own prescaler setting and enable bit. The prescaler settings, if available, can be found in the peripheral's control registers. The enable bit can be found in the module's EN register.

### 8.3.1.7 EM01GRPCCLK - Energy Mode 01 Group C Clock

EM01GRPCCLK is the selected clock for the Group C Peripherals operating in Energy Modes 0 or 1. These are typically high clock frequency peripheral modules. There are several selectable sources for EM01GRPCCLK: HFXO, HFRCODPLL, HFRCOEM23, FSRCO, HFRCODPLLRT, and HFXORT. In addition, the EM01GRPCCLK can be disabled. The selection is configured using the CLKSEL field in CMU\_EM01GRPCCLKCTRL.

Each High Frequency Peripheral that is clocked by EM01GRPCCLK may have its own prescaler setting and enable bit. The prescaler settings, if available, can be found in the peripheral's control registers. The enable bit can be found in the module's EN register.

### 8.3.1.8 EM23GRPACLK - Energy Mode 2 and 3 Group A Clock

EM23GRPACLK is the selected clock for the Group A Peripherals operating down to Energy Modes 2 or 3. These are typically low energy consumption peripheral modules. There are three selectable sources for EM23GRPACLK: LFRCO, LFXO and ULFRCO. In addition, the EM23GRPACLK can be disabled. The selection is configured using the CLKSEL field in CMU\_EM23GRPACLKCTRL.

Each Low Energy Peripheral that is clocked by EM23GRPACLK may have its own prescaler setting and enable bit. The prescaler settings, if available, can be found in the peripheral's control registers. The enable bit can be found in the module's EN register.

### 8.3.1.9 EM4GRPACLK - Energy Mode 4 Group A Clock

EM4GRPACLK is the selected clock for the Group A Peripherals operating down to Energy Mode 4. These are typically ultra low energy consumption peripheral modules. There are three selectable sources for EM4GRPACLK: LFRCO, LFXO and ULFRCO. In addition, the EM4GRPACLK can be disabled. The selection is configured using the CLKSEL field in CMU\_EM4GRPACLKCTRL.

**Note:** EM4GRPACLK is in a different power domain than EM23GRPACLK, which makes it available all the way down to EM4.

Each Low Energy Peripheral that is clocked by EM4GRPACLK may have its own prescaler setting and enable bit. The prescaler settings, if available, can be found in the peripheral's control registers. The enable bit can be found in the module's EN register.

### 8.3.1.10 Peripheral Bus Clock Enable

Peripherals each have an individual bus clock enable bit in the CMU\_CLKEN0 or CMU\_CLKEN1 registers. Disabling the bus clock to a peripheral can save energy, even when that peripheral is not active.

### 8.3.1.11 IADCCLK - IADC Clock

IADCCLK is the selected clock for the IADC. The IADCCLK source may be selected from EM01GRPACLK, HFRCOEM23, or FSRCO. In addition, the IADCCLK can be disabled. The selection is configured using the CLKSEL field in CMU\_IADCCLKCTRL.

**Note:** When using a Timer as the synchronous trigger for IADC conversion, EM01GRPACLK must be selected, because Timers run from EM01GRPACLK.

IADC has its own prescaler setting and enable bit. The prescaler settings can be found in the IADC's control registers. The enable bit can be found in the IADC's EN register.

Whichever clock source is selected as the IADC clock via the CLKSEL bitfield in the CMU\_IADCCLKCTRL register, this clock will become active automatically when needed. The IADC can automatically start and stop it.

### 8.3.1.12 VDACnCLK - VDACn Clock

VDACnCLK is the selected clock for VDACn. The VDACnCLK source may be selected from EM01GRPACLK, EM23GRPACLK, HFRCOEM23, or FSRCO. In addition, the VDACnCLK can be disabled. The selection is configured using the CLKSEL field in CMU\_VDACnCLKCTRL.

**Note:** When using a Timer as the synchronous trigger for VDACn conversion, EM01GRPACLK must be selected, because Timers run from EM01GRPACLK.

VDACn has its own prescaler setting and enable bit. The prescaler settings can be found in the VDAC's control registers. The enable bit can be found in the VDAC's EN register.

Whichever clock source is selected as the VDACn clock via the CLKSEL bitfield in the CMU\_VDACnCLKCTRL register, this clock will become active automatically when needed. The VDACn can automatically start and stop it.

### 8.3.1.13 SYSRTCCLK - SYSRTC Clock

SYSRTCCLK is the selected clock for the SYSRTC peripheral. This clock tree can be clocked from any of the low-frequency oscillators: LFXO, LFRCO, or ULFRCO. SYSRTCCLK is selected via the CLKSEL field in CMU\_SYSRTCCLKCTRL.

### 8.3.1.14 PCNT0CLK - PCNT0 Clock

PCNT0CLK is the selected clock for the PCNT peripheral. PCNT can be configured to clock from its S0 input signal, or the EM23GRPACLK, selectable by the CLKSEL field in CMU\_PCNT0CLKCTRL. Note that when configured to clock from the S0 input, the clock can further be selected from the direct S0 input pin, or from a PRS channel. Selection of the S0 input is determined by S0PRSEN in PCNT\_CFG.

### 8.3.1.15 EUSART0CLK - EUSART0 Clock

EUSART0CLK is the selected clock for the EUSART0 peripheral, and can choose between EM01GRPACLK, HFRCOEM23, LFXO, and LFRCO. EUSART0CLK is selected via the CLKSEL field in CMU\_EUSART0CLKCTRL. When operating EUSART0 as a high-speed UART or SPI main interface (EM0/1 only), EM01GRPACLK or HFRCOEM23 must be selected. To operate as a low-energy UART in EM0, EM1, or EM2, LFXO or LFRCO must be selected. To operate as a SPI secondary interface, EM01GRPACLK or HFRCOEM23 should be selected.

### 8.3.1.16 TRACECLK - Debug Trace Clock

The CMU scales the clock used for debug trace via the PRESC field in the CMU\_TRACECLKCTRL register. The debug trace clock is limited to 40 MHz maximum. Therefore, if the SYSCLK is 40 MHz or less, the default DIV1 setting may be used. When SYSCLK is above 40 MHz, use DIV2 to avoid data pump overflow. The selected debug trace clock will be used to run the Cortex®-M33 trace logic. Note that this register should be configured properly before enabling ETM.

### 8.3.1.17 WDOGnCLK - Watchdog Timer Clock

The Watchdog Timer (WDOGn) can be configured to use one of four different clock sources: LFRCO, LFXO, ULFRCO, or HCLKDIV1024. Select option HCLKDIV1024 to track Watchdog timeout with CPU clock speed.

### 8.3.2 Switching Clock Source

The FSRCO oscillator is a fixed frequency (20 MHz), low energy oscillator with extremely short start-up time. Therefore, this oscillator is chosen by hardware as the clock source for SYSCLK when the device starts up (e.g. after reset).

Software can switch between the different clock sources at run-time. For example, when the HFRCODPLL is the clock source, software can switch to HFXO by writing the field CLKSEL in the CMU\_SYSCLKCTRL register. See [Figure 8.5 CMU Switching From HFRCO to HFXO Before HFXO is Ready](#) on page 156 for a description of the sequence of events for this specific operation.

When switching the SYSCLK to HFXO via the CLKSEL bitfield in CMU\_SYSCLKCTRL, HFXO is automatically started. Switching to an oscillator that is not ready yet, the SYSCLK will stop for the duration of the oscillator start-up time. This effectively stalls the Core Modules. It is possible to avoid this by first enabling the target oscillator (e.g. HFXO) and then waiting for that oscillator to become ready before switching the clock source. This way, the system continues to run on the HFRCO until the target oscillator (e.g. HFXO) is ready and provides a reliable clock. This sequence of events is shown in [Figure 8.6 CMU Switching From HFRCO to HFXO After HFXO is Ready](#) on page 157.

Generally, all oscillators have a separate flag that is set when the oscillator is ready. This flag can also be configured to generate an interrupt.



**Figure 8.5. CMU Switching From HFRCO to HFXO Before HFXO is Ready**



**Figure 8.6. CMU Switching From HFRCO to HFXO After HFXO is Ready**

Switching clock source for various clock switches is done by setting the CLKSEL bitfields in CMU\_\*CLKCTRL. To ensure no stalls in the peripherals, the clock source should be ready before switching to it.

**Note:** To save energy, remember to disable all clock switches and/or module enable bits when not in use.

### 8.3.3 RC Oscillator Calibration

The CMU has built-in hardware support to efficiently calibrate RC oscillators (ULFRCO, HFRCODPLL, HFRCOEM23) at run-time or measure the timing of other periodic signals routed via PRS, see [Figure 8.7 Hardware Support for RC Oscillator Calibration on page 158](#) for an illustration of this circuit.

The concept is to select a reference and compare the RC frequency or PRS timing with the reference frequency. When the calibration circuit is started, one down-counter running on a selectable clock (DOWNSEL in CMU\_CALCTRL) and one up-counter running on a selectable clock (UPSEL in CMU\_CALCTRL) are started simultaneously. Reference clocks may also be routed through the PRS channels via the CALUP and CALDN consumer inputs. The top value for the down-counter must be written (CALTOP in CMU\_CALCTRL) before calibration is started. The down-counter counts for CALTOP + 1 cycles. When the down-counter has reached 0, the up-counter is sampled and the CALRDY interrupt flag in the IF register is set. If CONT in CMU\_CALCTRL is cleared, the counters are stopped after finishing the ongoing calibration. If continuous mode is selected by setting CONT in CMU\_CALCTRL, the down-counter reloads the top value and continues counting, while the up-counter restarts from 0.

Software can then read out the sampled up-counter value from CMU\_CALCNT. The up-counter has counted (the sampled value)+ 1 cycles. The ratio between the reference and the oscillator subject to the calibration can easily be found using (the top value)+1 and (the sampled value)+1. Overflows of the up-counter will not occur. If the up-counter reaches its top value before the down-counter reaches 0, the up-counter stays at its top value. Calibration can be started and stopped by writing CALSTART and CALSTOP bitfields in CMU\_CALCMD, respectively. With this hardware support, it is simple to write efficient software calibration algorithms.



**Figure 8.7. Hardware Support for RC Oscillator Calibration**

The counter operation for single and continuous mode are shown in [Figure 8.8 Single Calibration \(CONT=0\) on page 159](#) and [Figure 8.9 Continuous Calibration \(CONT=1\) on page 160](#) respectively.



**Figure 8.8. Single Calibration (CONT=0)**



**Figure 8.9. Continuous Calibration (CONT=1)**

### 8.3.4 Energy Modes

The availability of oscillators and system clocks depends on the chosen energy mode. By default, the high frequency oscillators and high frequency clocks are available down to EM1 Sleep. From EM2 DeepSleep onwards these oscillators and clocks are normally off, although special cases exist as summarized in [Table 8.1 Oscillator and clock availability in Energy Modes on page 161](#). The CMU figures in [8.3 Functional Description](#) also indicate which oscillators and clocks can be used in what energy modes.

The low frequency oscillators (LFRCO and LFXO) are available in all energy modes except in EM3 Stop when they are off by definition. By default, these oscillators are also off in EM4 Shutoff. The LFXO or LFRCO can be requested in EM4 as needed. The ultra low frequency oscillator (ULFRCO) is on in all energy modes, except for EM4 Shutoff, but it can be requested on in that state as well if needed. The low frequency clocks are in various power domains and therefore their availability not only depends on the chosen clock source, but also on the chosen energy mode as indicated in [Table 8.1 Oscillator and clock availability in Energy Modes on page 161](#).

**Table 8.1. Oscillator and clock availability in Energy Modes**

|                                                                  | EM0 Active /<br>EM1 Sleep | EM2 DeepSleep   | EM3 Stop        | EM4 Shutoff     |
|------------------------------------------------------------------|---------------------------|-----------------|-----------------|-----------------|
| HFRCODPLL                                                        | On <sup>1</sup>           | Off             | Off             | Off             |
| HFXO                                                             | On <sup>1</sup>           | Off             | Off             | Off             |
| HFRCOEM23                                                        | On <sup>1</sup>           | On <sup>2</sup> | On <sup>2</sup> | Off             |
| LFRCO, LFXO                                                      | On <sup>1</sup>           | On <sup>1</sup> | Off             | On <sup>3</sup> |
| ULFRCO                                                           | On                        | On              | On              | On <sup>3</sup> |
| SYSCLK, HCLK, PCLK, LSPCLK, RHCLK,<br>EM01GRPACLK, EM01GRPCCLK   | On <sup>1</sup>           | Off             | Off             | Off             |
| IADCCLK, VDACnCLK                                                | On <sup>1</sup>           | On <sup>2</sup> | On <sup>2</sup> | Off             |
| EM23GRPACLK, WDOGnCLK, SYSRTCCLK,<br>VDACn_REFRESH_CLK, PCNT0CLK | On <sup>1</sup>           | On <sup>1</sup> | On <sup>4</sup> | Off             |
| EM4GRPACLK                                                       | On <sup>1</sup>           | On <sup>1</sup> | On <sup>4</sup> | On <sup>3</sup> |

1 Under software control.

2 Default off, but kept active if requested by modules.

3 Default off, but kept active if used by BURTC.

4 On only if ULFRCO is used as clock source.

### 8.3.5 Clock Output

The CMU has up to three CLKOUTn signals that can be routed to the PRS or GPIO. The selections for CLKOUTn are controlled using the CLKOUTSELn bitfields in CMU\_EXPORTCLKCTRL (CLKOUTSEL0 controls CLKOUT0, for example).

The following clocks can be selected for CLKOUTn:

- HCLK and EXPORTCLK. The HCLK is the high frequency clock for AHB. The EXPORTCLK is a prescaled version of SYSCLK as controlled by the PRESC bitfield in the CMU\_EXPORTCLKCTRL register.
- The qualified clock from any of the on-chip oscillators. A qualified clock will not have any glitches or skewed duty-cycle during start-up. For the LFXO and HFXO, correct configuration of the TIMEOUT bitfield(s) in LFXO\_CFG and HFXO\_XTALCFG, respectively is required to guarantee a properly qualified clock.

HCLK will only have a 50-50 duty cycle when HCLKPRESC in CMU\_SYSCLKCTRL is DIV1. EXPORTCLK will only be 50-50 duty cycle when the selected division factor is even.

The CLKOUTn signals may be routed to GPIO via the DBUS as CMU.CLKOUTn using controls in the GPIO registers. The required output pins must be enabled in the GPIO\_CMU\_ROUTEEN register and the pin locations can be configured in the GPIO\_CMU\_CLKOUTnROUTE registers.

The CLKOUTn signals can also be used as PRS producers (see [13.3.3 Producers](#) for more detail on PRS producers). CLKOUTn signals used as PRS producers may be simultaneously routed to GPIO, but this is not required to use CLKOUTn as a PRS producer.

### 8.3.6 Clock Input from a Pin

It is possible to configure the CMU to input a clock from the CMU\_CLKIN0. This clock can be selected to drive SYSCLK and DPLL reference using CMU\_SYSCLKCTRL.CLKSEL and CMU\_DPLLREFCLKCTRL.CLKSEL respectively. The required input pin locations can be configured in the GPIO\_CMU\_CLKIN0ROUTE register.

### 8.3.7 Interrupts

The interrupts generated by the CMU module are combined into one interrupt vector. If CMU interrupts are enabled, an interrupt will be made if one or more of the interrupt flags in CMU\_IF and their corresponding bits in CMU\_IEN are set.

### 8.3.8 Protection

It is possible to lock the control and command registers to prevent unintended software writes to critical clock settings. This is controlled by the CMU\_LOCK register.

The WDOGCLKCTRL registers are separately locked by CMU\_WDOGLOCK register. This is to prevent EM3 Stop mode from disabling the watch dog clocks inadvertently.

In addition to software locks, hardware locks are implemented to prevent metastability. CMU\_CALCTRL is locked by hardware when calibration is started by CMU\_CALCMD.CALSTART. CMU\_DPLLREFCLKCTRL is locked by hardware when DPLL is enabled via DPLL\_EN.EN. Because these switches are not glitch-less, clock selection must be configured before enabling the operation and cannot be changed during operation.

## 8.4 CMU Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description                           |
|--------|---------------------|-------------|---------------------------------------|
| 0x000  | CMU_IPVERSION       | R           | IP Version ID                         |
| 0x008  | CMU_STATUS          | RH          | Status Register                       |
| 0x010  | CMU_LOCK            | W           | Configuration Lock Register           |
| 0x014  | CMU_WDOGLOCK        | W           | WDOG Configuration Lock Register      |
| 0x020  | CMU_IF              | RWH INTFLAG | Interrupt Flag Register               |
| 0x024  | CMU_IEN             | RW          | Interrupt Enable Register             |
| 0x050  | CMU_CALCMD          | W           | Calibration Command Register          |
| 0x054  | CMU_CALCTRL         | RW          | Calibration Control Register          |
| 0x058  | CMU_CALCNT          | R           | Calibration Result Counter Register   |
| 0x064  | CMU_CLKEN0          | RW          | Clock Enable Register 0               |
| 0x068  | CMU_CLKEN1          | RW          | Clock Enable Register 1               |
| 0x070  | CMU_SYSCLKCTRL      | RW          | System Clock Control                  |
| 0x080  | CMU_TRACECLKCTRL    | RW          | Debug Trace Clock Control             |
| 0x090  | CMU_EXPORTCLKCTRL   | RW          | Export Clock Control                  |
| 0x100  | CMU_DPLLREFCLKCTRL  | RW          | Digital PLL Reference Clock Control   |
| 0x120  | CMU_EM01GRPACLKCTRL | RW          | EM01 Peripheral Group a Clock Control |
| 0x128  | CMU_EM01GRPCCLKCTRL | RW          | EM01 Peripheral Group C Clock Control |
| 0x140  | CMU_EM23GRPACLKCTRL | RW          | EM23 Peripheral Group a Clock Control |
| 0x160  | CMU_EM4GRPACLKCTRL  | RW          | EM4 Peripheral Group a Clock Control  |
| 0x180  | CMU_IADCCLKCTRL     | RW          | IADC Clock Control                    |
| 0x200  | CMU_WDOG0CLKCTRL    | RW          | Watchdog0 Clock Control               |
| 0x208  | CMU_WDOG1CLKCTRL    | RW          | Watchdog1 Clock Control               |
| 0x220  | CMU_EUSART0CLKCTRL  | RW          | EUSART0 Clock Control                 |
| 0x240  | CMU_SYSRTC0CLKCTRL  | RW          | System RTC0 Clock Control             |
| 0x260  | CMU_VDAC0CLKCTRL    | RW          | VDAC0 Clock Control                   |
| 0x270  | CMU_PCNT0CLKCTRL    | RW          | Pulse Counter 0 Clock Control         |
| 0x280  | CMU_RADIOCLKCTRL    | RW          | Radio Clock Control                   |
| 0x294  | CMU_VDAC1CLKCTRL    | RW          | VDAC1 Clock Control                   |
| 0x1000 | CMU_IPVERSION_SET   | R           | IP Version ID                         |
| 0x1008 | CMU_STATUS_SET      | RH          | Status Register                       |
| 0x1010 | CMU_LOCK_SET        | W           | Configuration Lock Register           |
| 0x1014 | CMU_WDOGLOCK_SET    | W           | WDOG Configuration Lock Register      |
| 0x1020 | CMU_IF_SET          | RWH INTFLAG | Interrupt Flag Register               |
| 0x1024 | CMU_IEN_SET         | RW          | Interrupt Enable Register             |
| 0x1050 | CMU_CALCMD_SET      | W           | Calibration Command Register          |

| Offset | Name                                    | Type        | Description                           |
|--------|-----------------------------------------|-------------|---------------------------------------|
| 0x1054 | <a href="#">CMU_CALCTRL_SET</a>         | RW          | Calibration Control Register          |
| 0x1058 | <a href="#">CMU_CALCNT_SET</a>          | R           | Calibration Result Counter Register   |
| 0x1064 | <a href="#">CMU_CLKEN0_SET</a>          | RW          | Clock Enable Register 0               |
| 0x1068 | <a href="#">CMU_CLKEN1_SET</a>          | RW          | Clock Enable Register 1               |
| 0x1070 | <a href="#">CMU_SYSCLKCTRL_SET</a>      | RW          | System Clock Control                  |
| 0x1080 | <a href="#">CMU_TRACECLKCTRL_SET</a>    | RW          | Debug Trace Clock Control             |
| 0x1090 | <a href="#">CMU_EXPORTCLKCTRL_SET</a>   | RW          | Export Clock Control                  |
| 0x1100 | <a href="#">CMU_DPLLREFCLKCTRL_SET</a>  | RW          | Digital PLL Reference Clock Control   |
| 0x1120 | <a href="#">CMU_EM01GRPACLKCTRL_SET</a> | RW          | EM01 Peripheral Group a Clock Control |
| 0x1128 | <a href="#">CMU_EM01GRPCCLKCTRL_SET</a> | RW          | EM01 Peripheral Group C Clock Control |
| 0x1140 | <a href="#">CMU_EM23GRPACLKCTRL_SET</a> | RW          | EM23 Peripheral Group a Clock Control |
| 0x1160 | <a href="#">CMU_EM4GRPACLKCTRL_SET</a>  | RW          | EM4 Peripheral Group a Clock Control  |
| 0x1180 | <a href="#">CMU_IADCCCLKCTRL_SET</a>    | RW          | IADC Clock Control                    |
| 0x1200 | <a href="#">CMU_WDOG0CLKCTRL_SET</a>    | RW          | Watchdog0 Clock Control               |
| 0x1208 | <a href="#">CMU_WDOG1CLKCTRL_SET</a>    | RW          | Watchdog1 Clock Control               |
| 0x1220 | <a href="#">CMU_EUSART0CLKCTRL_SET</a>  | RW          | EUSART0 Clock Control                 |
| 0x1240 | <a href="#">CMU_SYSRTC0CLKCTRL_SET</a>  | RW          | System RTC0 Clock Control             |
| 0x1260 | <a href="#">CMU_VDAC0CLKCTRL_SET</a>    | RW          | VDAC0 Clock Control                   |
| 0x1270 | <a href="#">CMU_PCNT0CLKCTRL_SET</a>    | RW          | Pulse Counter 0 Clock Control         |
| 0x1280 | <a href="#">CMU_RADIOCLKCTRL_SET</a>    | RW          | Radio Clock Control                   |
| 0x1294 | <a href="#">CMU_VDAC1CLKCTRL_SET</a>    | RW          | VDAC1 Clock Control                   |
| 0x2000 | <a href="#">CMU_IPVERSION_CLR</a>       | R           | IP Version ID                         |
| 0x2008 | <a href="#">CMU_STATUS_CLR</a>          | RH          | Status Register                       |
| 0x2010 | <a href="#">CMU_LOCK_CLR</a>            | W           | Configuration Lock Register           |
| 0x2014 | <a href="#">CMU_WDOGLOCK_CLR</a>        | W           | WDOG Configuration Lock Register      |
| 0x2020 | <a href="#">CMU_IF_CLR</a>              | RWH INTFLAG | Interrupt Flag Register               |
| 0x2024 | <a href="#">CMU_IEN_CLR</a>             | RW          | Interrupt Enable Register             |
| 0x2050 | <a href="#">CMU_CALCMD_CLR</a>          | W           | Calibration Command Register          |
| 0x2054 | <a href="#">CMU_CALCTRL_CLR</a>         | RW          | Calibration Control Register          |
| 0x2058 | <a href="#">CMU_CALCNT_CLR</a>          | R           | Calibration Result Counter Register   |
| 0x2064 | <a href="#">CMU_CLKEN0_CLR</a>          | RW          | Clock Enable Register 0               |
| 0x2068 | <a href="#">CMU_CLKEN1_CLR</a>          | RW          | Clock Enable Register 1               |
| 0x2070 | <a href="#">CMU_SYSCLKCTRL_CLR</a>      | RW          | System Clock Control                  |
| 0x2080 | <a href="#">CMU_TRACECLKCTRL_CLR</a>    | RW          | Debug Trace Clock Control             |
| 0x2090 | <a href="#">CMU_EXPORTCLKCTRL_CLR</a>   | RW          | Export Clock Control                  |

| Offset | Name                     | Type        | Description                           |
|--------|--------------------------|-------------|---------------------------------------|
| 0x2100 | CMU_DPLLREFCLKCTRL_CLR   | RW          | Digital PLL Reference Clock Control   |
| 0x2120 | CMU_EM01GRPACLKCTRL_CL_R | RW          | EM01 Peripheral Group a Clock Control |
| 0x2128 | CMU_EM01GRPCCLKCTRL_CL_R | RW          | EM01 Peripheral Group C Clock Control |
| 0x2140 | CMU_EM23GRPACLKCTRL_CL_R | RW          | EM23 Peripheral Group a Clock Control |
| 0x2160 | CMU_EM4GRPACLKCTRL_CLR   | RW          | EM4 Peripheral Group a Clock Control  |
| 0x2180 | CMU_IADCCCLKCTRL_CLR     | RW          | IADC Clock Control                    |
| 0x2200 | CMU_WDOG0CLKCTRL_CLR     | RW          | Watchdog0 Clock Control               |
| 0x2208 | CMU_WDOG1CLKCTRL_CLR     | RW          | Watchdog1 Clock Control               |
| 0x2220 | CMU_EUSART0CLKCTRL_CLR   | RW          | EUSART0 Clock Control                 |
| 0x2240 | CMU_SYSRTC0CLKCTRL_CLR   | RW          | System RTC0 Clock Control             |
| 0x2260 | CMU_VDAC0CLKCTRL_CLR     | RW          | VDAC0 Clock Control                   |
| 0x2270 | CMU_PCNT0CLKCTRL_CLR     | RW          | Pulse Counter 0 Clock Control         |
| 0x2280 | CMU_RADIOCLKCTRL_CLR     | RW          | Radio Clock Control                   |
| 0x2294 | CMU_VDAC1CLKCTRL_CLR     | RW          | VDAC1 Clock Control                   |
| 0x3000 | CMU_IPVERSION_TGL        | R           | IP Version ID                         |
| 0x3008 | CMU_STATUS_TGL           | RH          | Status Register                       |
| 0x3010 | CMU_LOCK_TGL             | W           | Configuration Lock Register           |
| 0x3014 | CMU_WDOGLOCK_TGL         | W           | WDOG Configuration Lock Register      |
| 0x3020 | CMU_IF_TGL               | RWH INTFLAG | Interrupt Flag Register               |
| 0x3024 | CMU_IEN_TGL              | RW          | Interrupt Enable Register             |
| 0x3050 | CMU_CALCMD_TGL           | W           | Calibration Command Register          |
| 0x3054 | CMU_CALCTRL_TGL          | RW          | Calibration Control Register          |
| 0x3058 | CMU_CALCNT_TGL           | R           | Calibration Result Counter Register   |
| 0x3064 | CMU_CLKEN0_TGL           | RW          | Clock Enable Register 0               |
| 0x3068 | CMU_CLKEN1_TGL           | RW          | Clock Enable Register 1               |
| 0x3070 | CMU_SYSCLKCTRL_TGL       | RW          | System Clock Control                  |
| 0x3080 | CMU_TRACECLKCTRL_TGL     | RW          | Debug Trace Clock Control             |
| 0x3090 | CMU_EXPORTCLKCTRL_TGL    | RW          | Export Clock Control                  |
| 0x3100 | CMU_DPLLREFCLKCTRL_TGL   | RW          | Digital PLL Reference Clock Control   |
| 0x3120 | CMU_EM01GRPACLKCTRL_TG_L | RW          | EM01 Peripheral Group a Clock Control |
| 0x3128 | CMU_EM01GRPCCLKCTRL_TG_L | RW          | EM01 Peripheral Group C Clock Control |
| 0x3140 | CMU_EM23GRPACLKCTRL_TG_L | RW          | EM23 Peripheral Group a Clock Control |
| 0x3160 | CMU_EM4GRPACLKCTRL_TGL   | RW          | EM4 Peripheral Group a Clock Control  |

| Offset | Name                                   | Type | Description                   |
|--------|----------------------------------------|------|-------------------------------|
| 0x3180 | <a href="#">CMU_IADCCLKCTRL_TGL</a>    | RW   | IADC Clock Control            |
| 0x3200 | <a href="#">CMU_WDOG0CLKCTRL_TGL</a>   | RW   | Watchdog0 Clock Control       |
| 0x3208 | <a href="#">CMU_WDOG1CLKCTRL_TGL</a>   | RW   | Watchdog1 Clock Control       |
| 0x3220 | <a href="#">CMU_EUSART0CLKCTRL_TGL</a> | RW   | EUSART0 Clock Control         |
| 0x3240 | <a href="#">CMU_SYSRTC0CLKCTRL_TGL</a> | RW   | System RTC0 Clock Control     |
| 0x3260 | <a href="#">CMU_VDAC0CLKCTRL_TGL</a>   | RW   | VDAC0 Clock Control           |
| 0x3270 | <a href="#">CMU_PCNT0CLKCTRL_TGL</a>   | RW   | Pulse Counter 0 Clock Control |
| 0x3280 | <a href="#">CMU_RADIOCLKCTRL_TGL</a>   | RW   | Radio Clock Control           |
| 0x3294 | <a href="#">CMU_VDAC1CLKCTRL_TGL</a>   | RW   | VDAC1 Clock Control           |

## 8.5 CMU Register Description

### 8.5.1 CMU\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|        | 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 |
| Reset  | 0x3          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description   |
|------|-----------|-------|--------|---------------|
| 31:0 | IPVERSION | 0x3   | R      | IP Version ID |

## 8.5.2 CMU\_STATUS - Status Register

| Offset | Bit Position |          |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |        |
|--------|--------------|----------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--------|
|        | 31           | 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 |  |  |  |  |  |  |  |        |
| Reset  | 0x0          | 0x0      | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |        |
| Access | R            | R        | R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |        |
| Name   | LOCK         | WDOGLOCK |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  | CALRDY |

| Bit  | Name                                                    | Reset                                                                                                                                                                             | Access | Description                               |
|------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------|
| 31   | LOCK                                                    | 0x0                                                                                                                                                                               | R      | <b>Configuration Lock Status</b>          |
|      | Indicates the current status of configuration lock      |                                                                                                                                                                                   |        |                                           |
|      | Value                                                   | Mode                                                                                                                                                                              |        | Description                               |
|      | 0                                                       | UNLOCKED                                                                                                                                                                          |        | Configuration lock is unlocked            |
|      | 1                                                       | LOCKED                                                                                                                                                                            |        | Configuration lock is locked              |
| 30   | WDOGLOCK                                                | 0x0                                                                                                                                                                               | R      | <b>Configuration Lock Status for WDOG</b> |
|      | Indicates the current status of WDOG configuration lock |                                                                                                                                                                                   |        |                                           |
|      | Value                                                   | Mode                                                                                                                                                                              |        | Description                               |
|      | 0                                                       | UNLOCKED                                                                                                                                                                          |        | WDOG configuration lock is unlocked       |
|      | 1                                                       | LOCKED                                                                                                                                                                            |        | WDOG configuration lock is locked         |
| 29:1 | Reserved                                                | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                           |
| 0    | CALRDY                                                  | 0x0                                                                                                                                                                               | R      | <b>Calibration Ready</b>                  |
|      | Calibration is Ready (0 when calibration is ongoing).   |                                                                                                                                                                                   |        |                                           |

**8.5.3 CMU\_LOCK - Configuration Lock Register**

| Offset | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x010  | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit   | Name     | Reset                                                                                                       | Access | Description                                                                                                                                                       |
|-------|----------|-------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |                                                                                                             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:0  | LOCKKEY  | 0x93F7                                                                                                      | W      | <b>Configuration Lock Key</b>                                                                                                                                     |
|       |          | Write any other value than the unlock code to lock registers from editing. Write the unlock code to unlock. |        |                                                                                                                                                                   |
|       | Value    | Mode                                                                                                        |        | Description                                                                                                                                                       |
|       | 37879    | UNLOCK                                                                                                      |        | Write this value to unlock                                                                                                                                        |

**8.5.4 CMU\_WDOGLOCK - WDOG Configuration Lock Register**

| Offset | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x014  | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit   | Name     | Reset                                                                                                       | Access | Description                                                                                                                                                       |
|-------|----------|-------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |                                                                                                             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:0  | LOCKKEY  | 0x5257                                                                                                      | W      | <b>Configuration Lock Key</b>                                                                                                                                     |
|       |          | Write any other value than the unlock code to lock registers from editing. Write the unlock code to unlock. |        |                                                                                                                                                                   |
|       | Value    | Mode                                                                                                        |        | Description                                                                                                                                                       |
|       | 37879    | UNLOCK                                                                                                      |        | Write this value to unlock                                                                                                                                        |

**8.5.5 CMU\_IF - Interrupt Flag Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |       |        |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-------|--------|---|
| 0x020         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0   | 0      |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW    | RW     |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | CALOF | CALRDY |   |

| Bit  | Name            | Reset                                                                                                                                                                             | Access | Description                                                                                                                                                           |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                       |
| 1    | CALOF           | 0x0                                                                                                                                                                               | RW     | <b>Calibration Overflow Interrupt Flag</b><br><br>Set when calibration overflow has occurred (i.e. if a new calibration completes before CMU_CALSTATUS has been read) |
| 0    | CALRDY          | 0x0                                                                                                                                                                               | RW     | <b>Calibration Ready Interrupt Flag</b><br><br>Set when calibration is completed                                                                                      |

**8.5.6 CMU\_IEN - Interrupt Enable Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |       |        |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-------|--------|---|
| 0x024         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0   | 0      |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW    | RW     |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | CALOF | CALRDY |   |

| Bit  | Name            | Reset                                                                                                                                                                             | Access | Description                                                                        |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------|
| 31:2 | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                    |
| 1    | CALOF           | 0x0                                                                                                                                                                               | RW     | <b>Calibration Overflow Interrupt Enable</b><br><br>Enable/disable CALOF interrupt |
| 0    | CALRDY          | 0x0                                                                                                                                                                               | RW     | <b>Calibration Ready Interrupt Enable</b><br><br>Enable/disable CALRDY interrupt   |

## 8.5.7 CMU\_CALCMD - Calibration Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |       |         |          |       |       |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-------|---------|----------|-------|-------|
| 0x050  | 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     |         |          |       |       |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0   | 1       | 0        |       |       |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | W(nB) | W(nB)   | 0x0      | 0     |       |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |       | CALSTOP | CALSTART | W(nB) | W(nB) |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                       |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 1    | CALSTOP  | 0x0   | W(nB)  | <b>Calibration Stop</b><br><br>Stops the calibration counters.                                                                                                    |
| 0    | CALSTART | 0x0   | W(nB)  | <b>Calibration Start</b><br><br>Starts the calibration, effectively loading the CMU_CALCTRL.CALCNT into the down-counter and start decrementing.                  |

**8.5.8 CMU\_CALCTRL - Calibration Control Register**

| Offset | Bit Position |       |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |        |   |   |   |   |   |   |
|--------|--------------|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|---|---|---|---|---|---|
| 0x054  | 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 |
| Reset  | 0x0          |       |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0    |   |   |   |   |   |   |
| Access | RW           |       |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW     |   |   |   |   |   |   |
| Name   | DWNSEL       | UPSEL | CONT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CALTOP |   |   |   |   |   |   |

| Bit   | Name                                                                                                                     | Reset     | Access | Description                                     |
|-------|--------------------------------------------------------------------------------------------------------------------------|-----------|--------|-------------------------------------------------|
| 31:28 | DWNSEL                                                                                                                   | 0x0       | RW     | <b>Calibration Down-counter Select</b>          |
|       | Selects clock source for the calibration down-counter. Changing this while calibration is running results in bus fault.. |           |        |                                                 |
|       | Value                                                                                                                    | Mode      |        | Description                                     |
|       | 0                                                                                                                        | DISABLED  |        | Down-counter is not clocked                     |
|       | 1                                                                                                                        | HCLK      |        | HCLK is clocking down-counter                   |
|       | 2                                                                                                                        | PRS       |        | PRS CMU_CALDN consumer is clocking down-counter |
|       | 3                                                                                                                        | HFXO      |        | HFXO is clocking down-counter                   |
|       | 4                                                                                                                        | LFXO      |        | LFXO is clocking down-counter                   |
|       | 5                                                                                                                        | HFRCODPLL |        | HFRCODPLL is clocking down-counter              |
|       | 6                                                                                                                        | HFRCOEM23 |        | HFRCOEM23 is clocking down-counter              |
|       | 9                                                                                                                        | FSRCO     |        | FSRCO is clocking down-counter                  |
|       | 10                                                                                                                       | LFRCO     |        | LFRCO is clocking down-counter                  |
|       | 11                                                                                                                       | ULFRCO    |        | ULFRCO is clocking down-counter                 |
| 27:24 | UPSEL                                                                                                                    | 0x0       | RW     | <b>Calibration Up-counter Select</b>            |
|       | Selects clock source for the calibration up-counter. Changing this while calibration is running results in bus fault.    |           |        |                                                 |
|       | Value                                                                                                                    | Mode      |        | Description                                     |
|       | 0                                                                                                                        | DISABLED  |        | Up-counter is not clocked                       |
|       | 1                                                                                                                        | PRS       |        | PRS CMU_CALUP consumer is clocking up-counter   |
|       | 2                                                                                                                        | HFXO      |        | HFXO is clocking up-counter                     |
|       | 3                                                                                                                        | LFXO      |        | LFXO is clocking up-counter                     |
|       | 4                                                                                                                        | HFRCODPLL |        | HFRCODPLL is clocking up-counter                |
|       | 5                                                                                                                        | HFRCOEM23 |        | HFRCOEM23 is clocking up-counter                |
|       | 8                                                                                                                        | FSRCO     |        | FSRCO is clocking up-counter                    |
|       | 9                                                                                                                        | LFRCO     |        | LFRCO is clocking up-counter                    |
|       | 10                                                                                                                       | ULFRCO    |        | ULFRCO is clocking up-counter                   |
| 23    | CONT                                                                                                                     | 0x0       | RW     | <b>Continuous Calibration</b>                   |

| Bit                                                                                                             | Name     | Reset | Access | Description                                                                                                                                                       |
|-----------------------------------------------------------------------------------------------------------------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set this bit to enable continuous calibration. Changing this while calibration is running results in bus fault. |          |       |        |                                                                                                                                                                   |
| 22:20                                                                                                           | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| Write top value before calibration. Changing this while calibration is running results in bus fault.            |          |       |        |                                                                                                                                                                   |
| 19:0                                                                                                            | CALTOP   | 0x0   | RW     | <b>Calibration Counter Top Value</b>                                                                                                                              |

### 8.5.9 CMU\_CALCNT - Calibration Result Counter Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |  |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|--|--|--------|
| 0x058  | 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 |  |  |        |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |   |  |  |        |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | R |  |  |        |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |  | CALCNT |

| Bit                                                                                                                                                        | Name     | Reset | Access | Description                             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------|-----------------------------------------|
| To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions |          |       |        |                                         |
| 31:20                                                                                                                                                      | Reserved |       |        |                                         |
| 19:0                                                                                                                                                       | CALCNT   | 0x0   | R      | <b>Calibration Result Counter Value</b> |
| Read calibration result when Calibration Ready flag has been set.                                                                                          |          |       |        |                                         |

### 8.5.10 CMU\_CLKEN0 - Clock Enable Register 0

| Offset | Bit Position |    |     |     |
|--------|--------------|----|-----|-----|
| Reset  | 0x064        | 31 | 30  | 29  |
| Access | SYSRCTC      | RW | 0x0 | 0x0 |
|        | BURTC        | RW | 0x0 | 0x0 |
|        | BURAM        | RW | 0x0 | 0x0 |
|        | PRS          | RW | 0x0 | 0x0 |
|        | GPIO         | RW | 0x0 | 0x0 |
|        |              |    | 26  | 25  |
|        | ULFRCO       | RW | 0x0 | 0x0 |
|        | LFXO         | RW | 0x0 | 0x0 |
|        | LFRCO        | RW | 0x0 | 0x0 |
|        | FSRCO        | RW | 0x0 | 0x0 |
|        | HFXO0        | RW | 0x0 | 0x0 |
|        | HFRCOEM23    | RW | 0x0 | 0x0 |
|        | HFRCO0       | RW | 0x0 | 0x0 |
|        | DPLL0        | RW | 0x0 | 0x0 |
|        | SYSCFG       | RW | 0x0 | 0x0 |
|        | I2C1         | RW | 0x0 | 0x0 |
|        | I2C0         | RW | 0x0 | 0x0 |
|        | WDOG0        | RW | 0x0 | 0x0 |
|        | LETIMER0     | RW | 0x0 | 0x0 |
|        | AMUXCP0      | RW | 0x0 | 0x0 |
|        | IADC0        | RW | 0x0 | 0x0 |
|        | USART0       | RW | 0x0 | 0x0 |
|        | TIMER4       | RW | 0x0 | 0x0 |
|        | TIMER3       | RW | 0x0 | 0x0 |
|        | TIMER2       | RW | 0x0 | 0x0 |
|        | TIMER1       | RW | 0x0 | 0x0 |
|        | TIMER0       | RW | 0x0 | 0x0 |
|        | GPCRC        | RW | 0x0 | 0x0 |
|        | RADIOAES     | RW | 0x0 | 0x0 |
|        | LDMAXBAR     | RW | 0x0 | 0x0 |
|        | LDMA         | RW | 0x0 | 0x0 |

| Bit | Name      | Reset                                                                                                                                                                      | Access | Description                                                          |
|-----|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------|
| 31  | DCDC      | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 30  | SYSRTC0   | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 29  | BURTC     | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 28  | BURAM     | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 27  | PRS       | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 26  | GPIO      | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 25  | Reserved  | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                      |
| 24  | ULFRCO    | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 23  | LFXO      | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 22  | LFRCO     | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 21  | FSRCO     | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 20  | HFXO0     | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 19  | HFRCOEM23 | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                  |
| 18  | HFRCO0    | 0x0                                                                                                                                                                        | RW     | <b>Enable Bus Clock</b><br>Enables HFRCODPLL/HFRCO0 module PCLK/HCLK |

| Bit | Name     | Reset | Access | Description                                         |
|-----|----------|-------|--------|-----------------------------------------------------|
| 17  | DPLL0    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 16  | SYSCFG   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 15  | I2C1     | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 14  | I2C0     | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 13  | WDOG0    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 12  | LETIMER0 | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 11  | AMUXCP0  | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 10  | IADC0    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 9   | USART0   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 8   | TIMER4   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 7   | TIMER3   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 6   | TIMER2   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 5   | TIMER1   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 4   | TIMER0   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 3   | GPCRC    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 2   | RADIOAES | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 1   | LDMAXBAR | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |
| 0   | LDMA     | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK |

## 8.5.11 CMU\_CLKEN1 - Clock Enable Register 1

| Offset | Bit Position |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
|--------|--------------|----------|------|--------|--------|-----|----|----|-----|----|----|-----|----|----|-----|----|----|-----|----|----|-----|----|----|-----|----|
| Reset  | 31           | RW       | 0x0  | 30     | RW     | 0x0 | 29 | RW | 0x0 | 28 | RW | 0x0 | 27 | RW | 0x0 | 26 | RW | 0x0 | 25 | RW | 0x0 | 24 | RW | 0x0 | 23 |
| Access |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| Name   | MVP          |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 31     | VDAC1        | ECAIFADC | DMEM | RFECA1 | RFECA0 |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 30     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 29     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 28     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 27     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 26     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 25     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 24     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 23     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 22     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 21     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 20     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 19     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |
| 18     |              |          |      |        |        |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |

| Bit | Name     | Reset | Access | Description                                                                                                                                                                       |
|-----|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 30  | MVP      | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 29  | VDAC1    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 28  | ECAIFADC | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 27  | DMEM     | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 26  | RFECA1   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 25  | RFECA0   | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 24  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23  | EUSART1  | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 22  | EUSART0  | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 21  | PCNT0    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 20  | VDAC0    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 19  | ACMP1    | 0x0   | RW     | <b>Enable Bus Clock</b><br>Enables module PCLK/HCLK                                                                                                                               |
| 18  | ACMP0    | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |

| Bit | Name          | Reset | Access | Description                                                                                                                                                                       |
|-----|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 17  | WDOG1         | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 16  | MSC           | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 15  | ICACHE0       | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 14  | SMU           | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 13  | KEYSCAN       | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 12  | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11  | BUFC          | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 10  | SEMAILBOXHOST | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 9   | RFMAILBOX     | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 8   | HOSTMAILBOX   | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 7   | RFSCRATCHPAD  | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 6   | SYNTH         | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 5   | RAC           | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 4   | PROTIMER      | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 3   | FRC           | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 2   | RFCRC         | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 1   | MODEM         | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |
| 0   | AGC           | 0x0   | RW     | <b>Enable Bus Clock</b>                                                                                                                                                           |
|     |               |       |        | Enables module PCLK/HCLK                                                                                                                                                          |

## 8.5.12 CMU\_SYSCLKCTRL - System Clock Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------|---|---|---|
| 0x070  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x1    |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW     |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | CLKSEL |   |   |   |

| Bit   | Name                                       | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved                                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 16    | RHCLKPRESC                                 | 0x0   | RW     | <b>Radio HCLK Prescaler</b>                                                                                                                                       |
|       | Specifies the clock divider for Radio HCLK |       |        |                                                                                                                                                                   |
|       | Value                                      | Mode  |        | Description                                                                                                                                                       |
|       | 0                                          | DIV1  |        | Radio HCLK is SYSCLK divided by 1                                                                                                                                 |
|       | 1                                          | DIV2  |        | Radio HCLK is SYSCLK divided by 2                                                                                                                                 |
| 15:12 | HCLKPRESC                                  | 0x0   | RW     | <b>HCLK Prescaler</b>                                                                                                                                             |
|       | Specifies the clock divider for HCLK       |       |        |                                                                                                                                                                   |
|       | Value                                      | Mode  |        | Description                                                                                                                                                       |
|       | 0                                          | DIV1  |        | HCLK is SYSCLK divided by 1                                                                                                                                       |
|       | 1                                          | DIV2  |        | HCLK is SYSCLK divided by 2                                                                                                                                       |
|       | 3                                          | DIV4  |        | HCLK is SYSCLK divided by 4                                                                                                                                       |
|       | 7                                          | DIV8  |        | HCLK is SYSCLK divided by 8                                                                                                                                       |
|       | 15                                         | DIV16 |        | HCLK is SYSCLK divided by 16                                                                                                                                      |
| 11    | Reserved                                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 10    | PCLKPRESC                                  | 0x0   | RW     | <b>PCLK Prescaler</b>                                                                                                                                             |
|       | Specifies the clock divider for PCLK       |       |        |                                                                                                                                                                   |
|       | Value                                      | Mode  |        | Description                                                                                                                                                       |
|       | 0                                          | DIV1  |        | PCLK is HCLK divided by 1                                                                                                                                         |
|       | 1                                          | DIV2  |        | PCLK is HCLK divided by 2                                                                                                                                         |
| 9:3   | Reserved                                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 2:0   | CLKSEL                                     | 0x1   | RW     | <b>Clock Select</b>                                                                                                                                               |
|       | Selects the clock source for SYSCLK.       |       |        |                                                                                                                                                                   |

| Bit | Name      | Reset | Access | Description                  |
|-----|-----------|-------|--------|------------------------------|
|     | Value     | Mode  |        | Description                  |
| 1   | FSRCO     |       |        | FSRCO is clocking SYSCLK     |
| 2   | HFRCODPLL |       |        | HFRCODPLL is clocking SYSCLK |
| 3   | HFXO      |       |        | HFXO is clocking SYSCLK      |
| 4   | CLKIN0    |       |        | CLKIN0 is clocking SYSCLK    |

### 8.5.13 CMU\_TRACECLKCTRL - Debug Trace Clock Control

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |    |       |        |        |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|----|-------|--------|--------|
| 0x080         | 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  |       |        |        |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 | 0x1 |    |       |        |        |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW  | RW  | RW |       |        |        |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |    | PRESC | CLKSEL | CLKSEL |

| Bit  | Name                                                                                                                                                                                       | Reset       | Access | Description                                                                                                                                                       |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved                                                                                                                                                                                   |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 5:4  | PRESC                                                                                                                                                                                      | 0x0         | RW     | <b>TRACECLK Prescaler</b>                                                                                                                                         |
|      | Clock prescaler for the TRACECLKIN of TPIU. Changing this while the TRCENA bit is set in the ARM M33 Debug Exception and Monitor Control Register (DEMCR) will result in a bus fault.      |             |        |                                                                                                                                                                   |
|      | Value                                                                                                                                                                                      | Mode        |        | Description                                                                                                                                                       |
|      | 0                                                                                                                                                                                          | DIV1        |        | TRACECLK is SYSCLK divided by 1                                                                                                                                   |
|      | 1                                                                                                                                                                                          | DIV2        |        | TRACECLK is SYSCLK divided by 2                                                                                                                                   |
|      | 2                                                                                                                                                                                          | DIV3        |        | TRACECLK is SYSCLK divided by 3                                                                                                                                   |
|      | 3                                                                                                                                                                                          | DIV4        |        | TRACECLK is SYSCLK divided by 4                                                                                                                                   |
| 3:2  | Reserved                                                                                                                                                                                   |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 1:0  | CLKSEL                                                                                                                                                                                     | 0x1         | RW     | <b>Clock Select</b>                                                                                                                                               |
|      | Selects clock source for the TRACECLKIN of TPIU. Changing this while the TRCENA bit is set in the ARM M33 Debug Exception and Monitor Control Register (DEMCR) will result in a bus fault. |             |        |                                                                                                                                                                   |
|      | Value                                                                                                                                                                                      | Mode        |        | Description                                                                                                                                                       |
|      | 0                                                                                                                                                                                          | DISABLE     |        | TRACE clock is disable                                                                                                                                            |
|      | 1                                                                                                                                                                                          | SYSCLK      |        | SYSCLK is driving TRACE                                                                                                                                           |
|      | 2                                                                                                                                                                                          | HFRCOEM23   |        | HFRCOEM23 is driving TRACE                                                                                                                                        |
|      | 3                                                                                                                                                                                          | HFRCODPLLRT |        | HFRCODPLLRT is driving TRACE                                                                                                                                      |

### **8.5.14 CMU\_EXPORTCLKCTRL - Export Clock Control**

| Bit   | Name       | Reset     | Access | Description                                                                                                                                                                       |
|-------|------------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved   |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 28:24 | PRESC      | 0x0       | RW     | <b>EXPORTCLK Prescaler</b><br>Specifies the clock divider for EXPORTCLK (relative to SYSCLK).                                                                                     |
| 23:20 | Reserved   |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | CLKOUTSEL2 | 0x0       | RW     | <b>Clock Output Select 2</b><br>Controls the clock output 2 multiplexer.                                                                                                          |
|       | Value      | Mode      |        | Description                                                                                                                                                                       |
|       | 0          | DISABLED  |        | CLKOUT2 is not clocked                                                                                                                                                            |
|       | 1          | HCLK      |        | HCLK is clocking CLKOUT2                                                                                                                                                          |
|       | 2          | HFEXPCLK  |        | EXPORTCLK is clocking CLKOUT2                                                                                                                                                     |
|       | 3          | ULFRCO    |        | ULFRCO is clocking CLKOUT2                                                                                                                                                        |
|       | 4          | LFRCO     |        | LFRCO is clocking CLKOUT2                                                                                                                                                         |
|       | 5          | LFXO      |        | LFXO is clocking CLKOUT2                                                                                                                                                          |
|       | 6          | HFRCODPLL |        | HFRCODPLL is clocking CLKOUT2                                                                                                                                                     |
|       | 7          | HFXO      |        | HFXO is clocking CLKOUT2                                                                                                                                                          |
|       | 8          | FSRCO     |        | FSRCO is clocking CLKOUT2                                                                                                                                                         |
|       | 9          | HFRCOEM23 |        | HFRCOEM23 is clocking CLKOUT2                                                                                                                                                     |
| 15:12 | Reserved   |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:8  | CLKOUTSEL1 | 0x0       | RW     | <b>Clock Output Select 1</b><br>Controls the clock output 1 multiplexer.                                                                                                          |
|       | Value      | Mode      |        | Description                                                                                                                                                                       |
|       | 0          | DISABLED  |        | CLKOUT1 is not clocked                                                                                                                                                            |
|       | 1          | HCLK      |        | HCLK is clocking CLKOUT1                                                                                                                                                          |
|       | 2          | HFEXPCLK  |        | EXPORTCLK is clocking CLKOUT1                                                                                                                                                     |

| Bit | Name       | Reset     | Access | Description                                                                                                                                                                       |
|-----|------------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | ULFRCO     |           |        | ULFRCO is clocking CLKOUT1                                                                                                                                                        |
| 4   | LFRCO      |           |        | LFRCO is clocking CLKOUT1                                                                                                                                                         |
| 5   | LFXO       |           |        | LFXO is clocking CLKOUT1                                                                                                                                                          |
| 6   | HFRCODPLL  |           |        | HFRCODPLL is clocking CLKOUT1                                                                                                                                                     |
| 7   | HFXO       |           |        | HFXO is clocking CLKOUT1                                                                                                                                                          |
| 8   | FSRCO      |           |        | FSRCO is clocking CLKOUT1                                                                                                                                                         |
| 9   | HFRCOEM23  |           |        | HFRCOEM23 is clocking CLKOUT1                                                                                                                                                     |
| 7:4 | Reserved   |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0 | CLKOUTSEL0 | 0x0       | RW     | <b>Clock Output Select 0</b><br><br>Controls the clock output 0 multiplexer.                                                                                                      |
|     | Value      | Mode      |        | Description                                                                                                                                                                       |
|     | 0          | DISABLED  |        | CLKOUT0 is not clocked                                                                                                                                                            |
|     | 1          | HCLK      |        | HCLK is clocking CLKOUT0                                                                                                                                                          |
|     | 2          | HFEXPCLK  |        | EXPORTCLK is clocking CLKOUT0                                                                                                                                                     |
|     | 3          | ULFRCO    |        | ULFRCO is clocking CLKOUT0                                                                                                                                                        |
|     | 4          | LFRCO     |        | LFRCO is clocking CLKOUT0                                                                                                                                                         |
|     | 5          | LFXO      |        | LFXO is clocking CLKOUT0                                                                                                                                                          |
|     | 6          | HFRCODPLL |        | HFRCODPLL is clocking CLKOUT0                                                                                                                                                     |
|     | 7          | HFXO      |        | HFXO is clocking CLKOUT0                                                                                                                                                          |
|     | 8          | FSRCO     |        | FSRCO is clocking CLKOUT0                                                                                                                                                         |
|     | 9          | HFRCOEM23 |        | HFRCOEM23 is clocking CLKOUT0                                                                                                                                                     |

## 8.5.15 CMU\_DPLLREFCLKCTRL - Digital PLL Reference Clock Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|--------|
| 0x100  | 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   |        |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0 |        |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     | RW     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     | CLKSEL |

| Bit                                                                                                    | Name     | Reset                                                                                                                                                                             | Access | Description                   |
|--------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------|
| 31:2                                                                                                   | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                               |
| 1:0                                                                                                    | CLKSEL   | 0x0                                                                                                                                                                               | RW     | <b>Clock Select</b>           |
| Selects the clock source for DPLL reference. Changing this while DPLL is enabled results in bus fault. |          |                                                                                                                                                                                   |        |                               |
| Value                                                                                                  |          | Mode                                                                                                                                                                              |        | Description                   |
| 0                                                                                                      |          | DISABLED                                                                                                                                                                          |        | DPLLREFCLK is not clocked     |
| 1                                                                                                      |          | HFXO                                                                                                                                                                              |        | HFXO is clocking DPLLREFCLK   |
| 2                                                                                                      |          | LFXO                                                                                                                                                                              |        | LFXO is clocking DPLLREFCLK   |
| 3                                                                                                      |          | CLKIN0                                                                                                                                                                            |        | CLKIN0 is clocking DPLLREFCLK |

## 8.5.16 CMU\_EM01GRPACLKCTRL - EM01 Peripheral Group a Clock Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |    |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|----|--------|
| 0x120  | 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      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x1 |    |        |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     | RW |        |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |    | CLKSEL |

| Bit                                              | Name     | Reset       | Access                                                                                                                               | Description                                                                                                                                                                       |
|--------------------------------------------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3                                             | Reserved |             |                                                                                                                                      | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0                                              | CLKSEL   | 0x1         | RW                                                                                                                                   | <b>Clock Select</b>                                                                                                                                                               |
| Selects the clock source for EM01 Group A Clock. |          |             |                                                                                                                                      |                                                                                                                                                                                   |
| Value                                            |          | Mode        | Description                                                                                                                          |                                                                                                                                                                                   |
| 1                                                |          | HFRCODPLL   | HFRCODPLL is clocking EM01GRPACLK                                                                                                    |                                                                                                                                                                                   |
| 2                                                |          | HFXO        | HFXO is clocking EM01GRPACLK                                                                                                         |                                                                                                                                                                                   |
| 3                                                |          | FSRCO       | FSRCO is clocking EM01GRPACLK                                                                                                        |                                                                                                                                                                                   |
| 4                                                |          | HFRCOEM23   | HFRCOEM23 is clocking EM01GRPACLK                                                                                                    |                                                                                                                                                                                   |
| 5                                                |          | HFRCODPLLRT | HFRCODPLL (retimed) is clocking EM01GRPACLK. Check with datasheet for frequency limitation when using retiming with voltage scaling. |                                                                                                                                                                                   |
| 6                                                |          | HFXORT      | HFXO (retimed) is clocking EM01GRPACLK. Check with datasheet for frequency limitation when using retiming with voltage scaling.      |                                                                                                                                                                                   |

## 8.5.17 CMU\_EM01GRPCCLKCTRL - EM01 Peripheral Group C Clock Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|--------|
| 0x128  | 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      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x1 |        |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW  |        |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | CLKSEL |

| Bit                                              | Name     | Reset       | Access                                                                                                                               | Description                                                                                                                                                                       |
|--------------------------------------------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3                                             | Reserved |             |                                                                                                                                      | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0                                              | CLKSEL   | 0x1         | RW                                                                                                                                   | <b>Clock Select</b>                                                                                                                                                               |
| Selects the clock source for EM01 Group C Clock. |          |             |                                                                                                                                      |                                                                                                                                                                                   |
| Value                                            |          | Mode        | Description                                                                                                                          |                                                                                                                                                                                   |
| 1                                                |          | HFRCODPLL   | HFRCODPLL is clocking EM01GRPCCLK                                                                                                    |                                                                                                                                                                                   |
| 2                                                |          | HFXO        | HFXO is clocking EM01GRPCCLK                                                                                                         |                                                                                                                                                                                   |
| 3                                                |          | FSRCO       | FSRCO is clocking EM01GRPCCLK                                                                                                        |                                                                                                                                                                                   |
| 4                                                |          | HFRCOEM23   | HFRCOEM23 is clocking EM01GRPCCLK                                                                                                    |                                                                                                                                                                                   |
| 5                                                |          | HFRCODPLLRT | HFRCODPLL (retimed) is clocking EM01GRPCCLK. Check with datasheet for frequency limitation when using retiming with voltage scaling. |                                                                                                                                                                                   |
| 6                                                |          | HFXORT      | HFXO (retimed) is clocking EM01GRPCCLK. Check with datasheet for frequency limitation when using retiming with voltage scaling.      |                                                                                                                                                                                   |

**8.5.18 CMU\_EM23GRPACLKCTRL - EM23 Peripheral Group a Clock Control**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x140         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|               |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit                                                                                                                                                                                                                                                                                                                                                            | Name     | Reset                          | Access | Description                                                                                                                                                                       |       |      |             |   |       |                               |   |      |                              |   |        |                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|-------|-------------------------------|---|------|------------------------------|---|--------|--------------------------------|
| 31:2                                                                                                                                                                                                                                                                                                                                                           | Reserved |                                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |       |      |             |   |       |                               |   |      |                              |   |        |                                |
| 1:0                                                                                                                                                                                                                                                                                                                                                            | CLKSEL   | 0x1                            | RW     | <b>Clock Select</b>                                                                                                                                                               |       |      |             |   |       |                               |   |      |                              |   |        |                                |
| Selects the clock source for EM23 Group A Clock.                                                                                                                                                                                                                                                                                                               |          |                                |        |                                                                                                                                                                                   |       |      |             |   |       |                               |   |      |                              |   |        |                                |
| <table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>1</td> <td>LFRCO</td> <td>LFRCO is clocking EM23GRPACLK</td> </tr> <tr> <td>2</td> <td>LFXO</td> <td>LFXO is clocking EM23GRPACLK</td> </tr> <tr> <td>3</td> <td>ULFRCO</td> <td>ULFRCO is clocking EM23GRPACLK</td> </tr> </tbody> </table> |          |                                |        |                                                                                                                                                                                   | Value | Mode | Description | 1 | LFRCO | LFRCO is clocking EM23GRPACLK | 2 | LFXO | LFXO is clocking EM23GRPACLK | 3 | ULFRCO | ULFRCO is clocking EM23GRPACLK |
| Value                                                                                                                                                                                                                                                                                                                                                          | Mode     | Description                    |        |                                                                                                                                                                                   |       |      |             |   |       |                               |   |      |                              |   |        |                                |
| 1                                                                                                                                                                                                                                                                                                                                                              | LFRCO    | LFRCO is clocking EM23GRPACLK  |        |                                                                                                                                                                                   |       |      |             |   |       |                               |   |      |                              |   |        |                                |
| 2                                                                                                                                                                                                                                                                                                                                                              | LFXO     | LFXO is clocking EM23GRPACLK   |        |                                                                                                                                                                                   |       |      |             |   |       |                               |   |      |                              |   |        |                                |
| 3                                                                                                                                                                                                                                                                                                                                                              | ULFRCO   | ULFRCO is clocking EM23GRPACLK |        |                                                                                                                                                                                   |       |      |             |   |       |                               |   |      |                              |   |        |                                |

**8.5.19 CMU\_EM4GRPACLKCTRL - EM4 Peripheral Group a Clock Control**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x160         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|               |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit                                                                                                                                                                                                                                                                                                                                                         | Name     | Reset                         | Access | Description                                                                                                                                                                       |       |      |             |   |       |                              |   |      |                             |   |        |                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|-------|------------------------------|---|------|-----------------------------|---|--------|-------------------------------|
| 31:2                                                                                                                                                                                                                                                                                                                                                        | Reserved |                               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |       |      |             |   |       |                              |   |      |                             |   |        |                               |
| 1:0                                                                                                                                                                                                                                                                                                                                                         | CLKSEL   | 0x1                           | RW     | <b>Clock Select</b>                                                                                                                                                               |       |      |             |   |       |                              |   |      |                             |   |        |                               |
| Selects the clock source for EM4 Group A Clock.                                                                                                                                                                                                                                                                                                             |          |                               |        |                                                                                                                                                                                   |       |      |             |   |       |                              |   |      |                             |   |        |                               |
| <table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>1</td> <td>LFRCO</td> <td>LFRCO is clocking EM4GRPACLK</td> </tr> <tr> <td>2</td> <td>LFXO</td> <td>LFXO is clocking EM4GRPACLK</td> </tr> <tr> <td>3</td> <td>ULFRCO</td> <td>ULFRCO is clocking EM4GRPACLK</td> </tr> </tbody> </table> |          |                               |        |                                                                                                                                                                                   | Value | Mode | Description | 1 | LFRCO | LFRCO is clocking EM4GRPACLK | 2 | LFXO | LFXO is clocking EM4GRPACLK | 3 | ULFRCO | ULFRCO is clocking EM4GRPACLK |
| Value                                                                                                                                                                                                                                                                                                                                                       | Mode     | Description                   |        |                                                                                                                                                                                   |       |      |             |   |       |                              |   |      |                             |   |        |                               |
| 1                                                                                                                                                                                                                                                                                                                                                           | LFRCO    | LFRCO is clocking EM4GRPACLK  |        |                                                                                                                                                                                   |       |      |             |   |       |                              |   |      |                             |   |        |                               |
| 2                                                                                                                                                                                                                                                                                                                                                           | LFXO     | LFXO is clocking EM4GRPACLK   |        |                                                                                                                                                                                   |       |      |             |   |       |                              |   |      |                             |   |        |                               |
| 3                                                                                                                                                                                                                                                                                                                                                           | ULFRCO   | ULFRCO is clocking EM4GRPACLK |        |                                                                                                                                                                                   |       |      |             |   |       |                              |   |      |                             |   |        |                               |

### 8.5.20 CMU\_IADCCLKCTRL - IADC Clock Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |        |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|--------|---|---|
| 0x180  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x1    |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW     |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | CLKSEL |   |   |

| Bit                                                                                                                                                          | Name        | Reset                           | Access | Description                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2                                                                                                                                                         | Reserved    |                                 |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0                                                                                                                                                          | CLKSEL      | 0x1                             | RW     | <b>Clock Select</b>                                                                                                                                                               |
| Selects the clock source for IADC. EM01GRPACLK should never be selected as clock source for IADC when disabling the EM01GRACLK (e.g. because of EM23 entry). |             |                                 |        |                                                                                                                                                                                   |
| Value                                                                                                                                                        | Mode        | Description                     |        |                                                                                                                                                                                   |
| 1                                                                                                                                                            | EM01GRPACLK | EM01GRPACLK is clocking IADCCLK |        |                                                                                                                                                                                   |
| 2                                                                                                                                                            | FSRCO       | FSRCO is clocking IADCCLK       |        |                                                                                                                                                                                   |
| 3                                                                                                                                                            | HFRCOEM23   | HFRCOEM23 is clocking IADCCLK   |        |                                                                                                                                                                                   |

### 8.5.21 CMU\_WDOG0CLKCTRL - Watchdog0 Clock Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |     |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------|-----|---|---|
| 0x200  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        | 0x1 |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW     |     |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | CLKSEL |     |   |   |

| Bit                                 | Name        | Reset                            | Access | Description                                                                                                                                                                       |
|-------------------------------------|-------------|----------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3                                | Reserved    |                                  |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0                                 | CLKSEL      | 0x1                              | RW     | <b>Clock Select</b>                                                                                                                                                               |
| Selects the clock source for WDOG0. |             |                                  |        |                                                                                                                                                                                   |
| Value                               | Mode        | Description                      |        |                                                                                                                                                                                   |
| 1                                   | LFRCO       | LFRCO is clocking WDOG0CLK       |        |                                                                                                                                                                                   |
| 2                                   | LFXO        | LFXO is clocking WDOG0CLK        |        |                                                                                                                                                                                   |
| 3                                   | ULFRCO      | ULFRCO is clocking WDOG0CLK      |        |                                                                                                                                                                                   |
| 4                                   | HCLKDIV1024 | HCLKDIV1024 is clocking WDOG0CLK |        |                                                                                                                                                                                   |

## 8.5.22 CMU\_WDOG1CLKCTRL - Watchdog1 Clock Control

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |        |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|--|--------|----|
| 0x208         | 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 |  |        |    |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x1 |   |  |        |    |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |        |    |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  | CLKSEL | RW |

| Bit                                 | Name     | Reset       | Access                           | Description                                                                                                                                                                       |
|-------------------------------------|----------|-------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3                                | Reserved |             |                                  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0                                 | CLKSEL   | 0x1         | RW                               | <b>Clock Select</b>                                                                                                                                                               |
| Selects the clock source for WDOG1. |          |             |                                  |                                                                                                                                                                                   |
| Value                               |          | Mode        | Description                      |                                                                                                                                                                                   |
| 1                                   |          | LFRCO       | LFRCO is clocking WDOG0CLK       |                                                                                                                                                                                   |
| 2                                   |          | LFXO        | LFXO is clocking WDOG0CLK        |                                                                                                                                                                                   |
| 3                                   |          | ULFRCO      | ULFRCO is clocking WDOG0CLK      |                                                                                                                                                                                   |
| 4                                   |          | HCLKDIV1024 | HCLKDIV1024 is clocking WDOG0CLK |                                                                                                                                                                                   |

## 8.5.23 CMU\_EUSART0CLKCTRL - EUSART0 Clock Control

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    |        |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|----|--------|
| 0x220         | 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  |        |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x1 |    |        |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | RW |        |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    | CLKSEL |

| Bit                                                                                                                                                                  | Name     | Reset       | Access | Description                                                                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3                                                                                                                                                                 | Reserved |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0                                                                                                                                                                  | CLKSEL   | 0x1         | RW     | <b>Clock Select</b>                                                                                                                                                               |
| This bit controls which clock is used for EUSART0. EM01GRPCCLK should never be selected as clock source when disabling the EM01GRCCCLK (e.g. because of EM23 entry). |          |             |        |                                                                                                                                                                                   |
|                                                                                                                                                                      | Value    | Mode        |        | Description                                                                                                                                                                       |
|                                                                                                                                                                      | 0        | DISABLED    |        | EUSART0 is not clocked                                                                                                                                                            |
|                                                                                                                                                                      | 1        | EM01GRPCCLK |        | EM01GRPCCLK is clocking EUSART0                                                                                                                                                   |
|                                                                                                                                                                      | 2        | HFRCOEM23   |        | HFRCOEM23 is clocking EUSART0                                                                                                                                                     |
|                                                                                                                                                                      | 3        | LFRCO       |        | LFRCO is clocking EUSART0                                                                                                                                                         |
|                                                                                                                                                                      | 4        | LFXO        |        | LFXO is clocking EUSART0                                                                                                                                                          |

## 8.5.24 CMU\_SYSRTC0CLKCTRL - System RTC0 Clock Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|--------|
| 0x240  | 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      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x1 |        |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW  |        |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | CLKSEL |

| Bit                                   | Name     | Reset  | Access                        | Description                                                                                                                                                                       |
|---------------------------------------|----------|--------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2                                  | Reserved |        |                               | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0                                   | CLKSEL   | 0x1    | RW                            | <b>Clock Select</b>                                                                                                                                                               |
| Selects the clock source for SYSRTC0. |          |        |                               |                                                                                                                                                                                   |
| Value                                 |          | Mode   | Description                   |                                                                                                                                                                                   |
| 1                                     |          | LFRCO  | LFRCO is clocking SYSRTC0CLK  |                                                                                                                                                                                   |
| 2                                     |          | LFXO   | LFXO is clocking SYSRTC0CLK   |                                                                                                                                                                                   |
| 3                                     |          | ULFRCO | ULFRCO is clocking SYSRTC0CLK |                                                                                                                                                                                   |

## 8.5.25 CMU\_VDAC0CLKCTRL - VDAC0 Clock Control

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |  |  |  |  |        |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|--|--|--|--|--|--------|
| 0x260         | 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 |  |  |  |  |  |        |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x1 |   |  |  |  |  |  |        |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |  |  |  |  |        |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |  |  |  |  | CLKSEL |

| Bit                                                                                                                                                              | Name     | Reset       | Access | Description                                                                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3                                                                                                                                                             | Reserved |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0                                                                                                                                                              | CLKSEL   | 0x1         | RW     | <b>Clock Select</b>                                                                                                                                                               |
| This bit controls which clock is used for VDAC. EM01GRPACLK should never be selected as clock source when disabling the EM01GRACLK (e.g. because of EM23 entry). |          |             |        |                                                                                                                                                                                   |
| Value                                                                                                                                                            |          | Mode        |        | Description                                                                                                                                                                       |
| 0                                                                                                                                                                |          | DISABLED    |        | VDAC is not clocked                                                                                                                                                               |
| 1                                                                                                                                                                |          | EM01GRPACLK |        | EM01GRPACLK is clocking VDAC                                                                                                                                                      |
| 2                                                                                                                                                                |          | EM23GRPACLK |        | EM23GRPACLK is clocking VDAC                                                                                                                                                      |
| 3                                                                                                                                                                |          | FSRCO       |        | FSRCO is clocking VDAC                                                                                                                                                            |
| 4                                                                                                                                                                |          | HFRCOEM23   |        | HFRCOEM23 is clocking VDAC                                                                                                                                                        |

**8.5.26 CMU\_PCNT0CLKCTRL - Pulse Counter 0 Clock Control**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |        |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|--------|---|
| 0x270         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x1 |        |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW  |        |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     | CLKSEL |   |

| Bit  | Name     | Reset                                            | Access | Description                                                                                                                                                                       |
|------|----------|--------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |                                                  |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0  | CLKSEL   | 0x1                                              | RW     | <b>Clock Select</b>                                                                                                                                                               |
|      |          | This bit controls which clock is used for PCNT0. |        |                                                                                                                                                                                   |
|      | Value    | Mode                                             |        | Description                                                                                                                                                                       |
|      | 0        | DISABLED                                         |        | PCNT0 is not clocked                                                                                                                                                              |
|      | 1        | EM23GRPACLK                                      |        | EM23GRPACLK is clocking PCNT0                                                                                                                                                     |
|      | 2        | PCNTS0                                           |        | External pin PCNT_S0 is clocking PCNT0                                                                                                                                            |

**8.5.27 CMU\_RADIOCLKCTRL - Radio Clock Control**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|
| 0x280         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW  |   |   |
| <b>Name</b>   | DBGCLK       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | EN  |   |   |

| Bit  | Name     | Reset                                                                                                               | Access | Description                                                                                                                                                                       |
|------|----------|---------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | DBGCLK   | 0x0                                                                                                                 | RW     | <b>Enable Clock for Debugger</b>                                                                                                                                                  |
|      |          | When set to 1, this forces radio busmatrix and RAC clocks to run, allowing RAC sequencer debugger to stay attached. |        |                                                                                                                                                                                   |
| 30:1 | Reserved |                                                                                                                     |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | EN       | 0x0                                                                                                                 | RW     | <b>Enable</b>                                                                                                                                                                     |
|      |          | Enables radio bridge clock                                                                                          |        |                                                                                                                                                                                   |

## 8.5.28 CMU\_VDAC1CLKCTRL - VDAC1 Clock Control

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |        |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|--|--|--|--|--|--------|
| 0x294         | 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   |  |  |  |  |  |        |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x1 |  |  |  |  |  |        |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  |        |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |  |  |  |  |  | CLKSEL |

| Bit                                                                                                                                                              | Name     | Reset       | Access | Description                                                                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3                                                                                                                                                             | Reserved |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0                                                                                                                                                              | CLKSEL   | 0x1         | RW     | <b>Clock Select</b>                                                                                                                                                               |
| This bit controls which clock is used for VDAC. EM01GRPACLK should never be selected as clock source when disabling the EM01GRACLK (e.g. because of EM23 entry). |          |             |        |                                                                                                                                                                                   |
| Value                                                                                                                                                            |          | Mode        |        | Description                                                                                                                                                                       |
| 0                                                                                                                                                                |          | DISABLED    |        | VDAC is not clocked                                                                                                                                                               |
| 1                                                                                                                                                                |          | EM01GRPACLK |        | EM01GRPACLK is clocking VDAC                                                                                                                                                      |
| 2                                                                                                                                                                |          | EM23GRPACLK |        | EM23GRPACLK is clocking VDAC                                                                                                                                                      |
| 3                                                                                                                                                                |          | FSRCO       |        | FSRCO is clocking VDAC                                                                                                                                                            |
| 4                                                                                                                                                                |          | HFRCOEM23   |        | HFRCOEM23 is clocking VDAC                                                                                                                                                        |

## 9. Oscillators



### Quick Facts

#### What?

The EFR32xG24 has a wide range of high frequency and low frequency oscillators.

#### Why?

The High Frequency oscillators support EM0/1 operation. The Low-frequency oscillators provide a low frequency clock for the low energy peripherals in EM/2/3/4.

#### How?

The HFXO supports high frequency crystal oscillators. The LFXO supports 32.768 kHz crystal oscillators. The RC oscillators are internal oscillators that require no external components.

### 9.1 Introduction

The EFR32xG24 has several oscillators. This chapter contains a detailed function description and register descriptions for each oscillator. The CMU chapter includes information on how to select clock sources. Each oscillator may require some initial configuration or calibration before being enabled. The CMU supports clock on demand and can enable and disable oscillators. Therefore, it is important to properly configure each oscillator before selecting it as a clock source in the CMU.

### 9.2 HFXO - High Frequency Crystal Oscillator

#### 9.2.1 Introduction

The High Frequency Crystal Oscillator (HFXO) uses an external high frequency crystal and provides a sequencer for starting up the crystal safely and reliably, while minimize energy consumption. An external sine wave clock source can also be used in the absence of a crystal.

#### 9.2.2 Features

- Optimized for 39.0 MHz crystals
- Multiple programming options of start-up parameters to enable optimization of different crystals, supporting a wide range of ESR and ESL
- Support for external sine wave input
- Programmable two-phase start-up to minimize energy consumption
- Built-in current optimization (Automatic oscillation amplitude control)
- Independent on-chip frequency tuning capacitors
- Hardware request for on-demand enable/disable
- Register lock

## 9.2.3 Functional Description

### 9.2.3.1 Enabling and Disabling

While the HFXO supports on-demand clocking, it is generally recommended to manually manage the HFXO, at least initially, because it requires software configuration and has a long start-up time. Software can set the FORCEEN to start HFXO and keep it enabled even if it is not selected as a clock source.

However, once started and before EM2 entry, switching the HFXO to on-demand mode may be desirable. This allows the MCU to enter EM2 and then restart the HFXO automatically upon EM2 exit. (During EM1P the HFXO can be conditionally started, depending on the wake-up trigger source.)

The HFXO can be enabled and disabled via both hardware and software mechanisms. Enabling via software is done by setting the FORCEEN bit in the HFXO\_CTRL register. Disabling via software is done by setting the DISONDEMAND bit and clearing FORCEEN bit in the HFXO\_CTRL register. The hardware controlled on-demand mode is enabled by clearing the FORCEEN and DISONDEMAND bits in the HFXO\_CTRL register. Once configured the on-demand mode hardware can autonomously start and stop the HFXO based on various peripheral clock requests in combination with clock switch selections in the CMU. The HFXO is automatically stopped when entering EM2, EM3, or EM4. Hardware can also stop the HFXO via hardware in response to change in peripheral requests and clock switch selections in the CMU.

### 9.2.3.2 Start-up Time

The start-up time differs for different crystals and the HFXO has a configurable time-out to accommodate each crystal type. Software configures the timeout by setting the various TIMEOUT bit fields of the HFXO\_XTALCFG register. The time-out delays the assertion of the RDY signal for HFXO. The programmed timeout should allow enough time for the oscillator to stabilize. The time-out can be optimized for the chosen crystal used in the application.

The start-up behavior of the HFXO also depends on how and how long the HFXO is disabled.

### 9.2.3.3 Configuration

The High Frequency Crystal Oscillator needs to be configured to ensure safe start-up for the given crystal. Refer to the Device Data sheet and application notes for guidelines in selecting correct components and crystals as well as for configuration trade-offs.

The HFXO crystal is connected to the HFXTAL\_I/HFXTAL\_O pins as shown in [Figure 9.1 HFXO Pin Connection on page 194](#).



**Figure 9.1. HFXO Pin Connection**

Upon enabling the HFXO, a hardware state machine sequentially applies the configurable start-up state, intermediate start-up state, and steady state control settings from the HFXO\_XTALCFG and HFXO\_XTALCTRL registers. After reaching the steady operation state of the HFXO, it is recommended to further optimize current consumption using the Core Bias Optimization Algorithm to trade off noise and current consumption.

Refer to [AN0016.2](#) for more information on settings for different crystals. Write the configuration values, which depends on the crystal's CL, RESR and oscillation frequency, into HFXO\_XTALCFG and HFXO\_XTALCTRL registers.

- COREBIASSTARTUP (HFXO\_XTALCFG) - current setting applied at start-up time
- COREBIASSTARTUPI (HFXO\_XTALCFG) - current setting applied at intermediate start-up time
- COREBIASANA (HFXO\_XTALCTRL) - current setting applied at steady state
- CTUNEXISTARTUP (HFXO\_XTALCFG) - tuning cap setting for XI applied at start-up time
- CTUNEXIANA (HFXO\_XTALCTRL) - tuning cap setting for XI applied at steady state
- CTUNEXOSTARTUP (HFXO\_XTALCFG) - tuning cap setting for XO applied at start-up time
- CTUNEXOANA (HFXO\_XTALCTRL) - tuning cap setting for XO applied at steady state
- CTUNEFIXANA (HFXO\_XTALCTRL) - fixed tuning cap setting applied throughout
- TIMEOUTSTEADY (HFXO\_XTALCFG) - duration for the steady state settling time
- TIMEOUTCBLSB (HFXO\_XTALCFG) - duration for the optimization settling after each step

All HFXO configuration needs to be performed prior to enabling the HFXO, whether via software by setting FORCEEN bit field, or allowing hardware request by clearing DISONDEMAND bit field in the HFXO\_CTRL register.

By default, the HFXO is started in crystal mode, but it is possible to connect an active external sine or clipped sine wave clock source to the HFXTAL\_I pin of the HFXO. By configuring the MODE field in HFXO\_CFG to EXTCLK, the HFXO can be bypassed and the source clock can be provided through the HFXTAL\_I pin.

### 9.2.3.4 Status Flags

The ENS flag in the HFXO\_STATUS indicates if the HFXO has been successfully enabled. Once the HFXO oscillation amplitude has exceeded the start-up threshold and intermediate start-up threshold, the steady state settling timeout begins. When the steady state timeout has expired, the HFXO is ready for use as indicated by the RDY flag in the HFXO\_STATUS. Once Core Bias Optimization is enabled, the COREBIASOPTRDY flag in the CMU\_STATUS register indicates when the optimization is ready. It is advised to wait for this flag before using the HFXO, because optimization can cause minor disturbance to the oscillator frequency.

### 9.2.3.5 On-Demand Clocking

Hardware can request to enable the HFXO by setting the HFXO\_STATUS.HWREQ bit field. The HFXO can also optionally be configured via the HFXO\_STATUS.DISONDEMAND to shut down when no hardware request is present. This is known as on-demand clocking and allows the oscillator to be controlled without any software intervention. On-demand HFXO enable can be used, for example, upon wake-up of the Radio Controller (RAC). The RAC module always requires the HFXO for its operation. Any hardware request for HFXO, including request from RAC, is indicated in the HWREQ bit field of the HFXO\_STATUS register. This request enables the HFXO, provided that DISONDEMAND bit field is cleared in HFXO\_CTRL register. The HFXO is only disabled by hardware upon EM2, EM3 or EM4 entry.

The HFXO analog circuitry can optionally continue operating with the clock output shut off when the HFXO is disabled. This is configured by setting the KEEPWARM bit in HFXO\_STATUS.

### 9.2.3.6 Interrupts

RDYIF and COREBIASOPTRDYIF are interrupt flags as well as status flags. This allows software flexibility to implement interrupt service routine or polling loop for these events. When steady state timeout has exceeded, sticky RDYIF is set until it is cleared by software. If optimization is enabled, sticky COREBIASOPTRDYIF is set when optimization is completed successfully. However, if optimization fails to complete, sticky COREBIASOPTERRIF is set, and the HFXO control state machine stays in the error state until the oscillator is disabled. Similarly, if HFXO fails to start-up, meaning it has not reached the steady state, sticky DNSERRIF is set. The HFXO control state machine stays in the error state until the oscillator is disabled.

### 9.2.3.7 Protection

It is possible to lock the control registers, configuration registers, and command register to prevent unintended software writes to critical clock settings. This is controlled by the HFXO\_LOCK register. A LOCK bit is available in HFXO\_STATUS register. Furthermore, these registers are locked automatically by hardware to prevent clock domain crossing malfunction. To gain access to these registers while oscillator is in steady operation state, set FORCEEN to 1, then set DISONDEMAND to 1 in the HFXO\_CTRL register. A FSMLOCK bit in HFXO\_STATUS register indicates when it is safe for software to update control registers and configuration registers. When software is finished with updates, put the oscillator back to on-demand mode by clearing DISONDEMAND to 0, followed by clearing FORCEEN to 0 in the HFXO\_CTRL register. While DISONDEMAND is 0, FSMLOCK is always set, even if hardware is not requesting. This is to prevent a race condition between software access and hardware lock.

### 9.2.3.8 Tuning

While the oscillator is running in steady operation state, it may be desirable to change control settings. One example is frequency tuning by modifying the tuning capacitance via CTUNEXIANA and CTUNEXOANA fields in the HFXO\_XTALCTRL register. When tuning, care should be taken to make small changes to the CTUNE registers. Ideally, change the CTUNE registers by one LSB at a time and alternate between the XI and XO registers. Sufficient wait time for settling, on the order of TIMEOUTSTEADY, should pass before new frequency measurement is taken.

**Note:** While the HFXO can support crystals with a tuning range of 38 MHz to 40 MHz, the radio specifically requires a 39.0 MHz crystal. There may also be specific crystal tolerance requirements for each RF protocol supported by the radio.

### 9.2.3.9 High Frequency Clock Output (HFCLKOUT)

Certain device package options include a dedicated HFCLKOUT pin. This signal is designed to be a very high quality sinusoidal clock output operating at the crystal frequency. It is suitable for driving the crystal input on other Silicon Labs EFR products, and enables multi-radio systems operating from a single crystal. When using the HFCLKOUT feature, there are additional controls and considerations.

#### Enabling and Disabling

The HFCLKOUT feature can be enabled and disabled through software or hardware. To enable the output buffer in software the FORCEENBUFOUT bit in HFXO\_CTRL should be set to 1. To disable, the DISONDEMANDBUFOUT bit should be set to 1 and FORCEENBUFOUT cleared to 0 in HFXO\_CTRL.

Hardware (on-demand) control is possible as well. The on-demand hardware mechanism uses a GPIO input (HFXO0.BUF-OUT\_REQ\_IN\_ASYNC, routed to PA or PB pin in the GPIO interface) to allow the other radio device to request the oscillator output. The external device requests HFCLKOUT by setting the input high. If the HFXO is not already running when external hardware requests HFCLKOUT, the HFXO will automatically be enabled and stabilized before the HFCLKOUT buffer turns on. When the external hardware enable request becomes inactive (input logic low), the HFXO block may also be automatically shut down to save energy if no other HFXO requestors are active.

Hardware control is enabled by clearing both the FORCEENBUFOUT and DISONDEMANDBUFOUT bits in the HFXO\_CTRL register.

**Note:** Under hardware control, HFCLKOUT is available in EM0, EM1, EM2 and EM3 and will be automatically shut down in EM4.

#### Tuning

If the HFCLKOUT feature is enabled, CTUNEXIBUFOUTANA should normally be set to CTUNEXIANA. This will guarantee a maximum capacitance change of  $\pm 300 \text{ fF}$  between enabling/disabling HFCLKOUT (expected maximum frequency shift of  $\pm 10 \text{ ppm}$  for a typical crystal). For a lower frequency shift, it is recommended to tune CTUNEXIBUFOUTANA at the target frequency while HFCLKOUT is enabled.

#### 9.2.4 HFXO Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description                        |
|--------|---------------------|-------------|------------------------------------|
| 0x000  | HFXO_IPVERSION      | R           | IP Version ID                      |
| 0x010  | HFXO_XTALCFG        | RW SYNC     | Crystal Configuration Register     |
| 0x018  | HFXO_XTALCTRL       | RWH SYNC    | Crystal Control Register           |
| 0x01C  | HFXO_XTALCTRL1      | RW SYNC     | BUFOUT Crystal Control Register    |
| 0x020  | HFXO_CFG            | RW SYNC     | Configuration Register             |
| 0x028  | HFXO_CTRL           | RWH SYNC    | Control Register                   |
| 0x040  | HFXO_BUFOUTTRIM     | RW SYNC     | BUFOUT Trim Configuration Register |
| 0x044  | HFXO_BUFOUTCTRL     | RW SYNC     | BUFOUT Control Register            |
| 0x050  | HFXO_CMD            | W SYNC      | Command Register                   |
| 0x058  | HFXO_STATUS         | RH          | Status Register                    |
| 0x070  | HFXO_IF             | RWH INTFLAG | Interrupt Flag Register            |
| 0x074  | HFXO_IEN            | RW          | Interrupt Enable Register          |
| 0x080  | HFXO_LOCK           | W           | Configuration Lock Register        |
| 0x1000 | HFXO_IPVERSION_SET  | R           | IP Version ID                      |
| 0x1010 | HFXO_XTALCFG_SET    | RW SYNC     | Crystal Configuration Register     |
| 0x1018 | HFXO_XTALCTRL_SET   | RWH SYNC    | Crystal Control Register           |
| 0x101C | HFXO_XTALCTRL1_SET  | RW SYNC     | BUFOUT Crystal Control Register    |
| 0x1020 | HFXO_CFG_SET        | RW SYNC     | Configuration Register             |
| 0x1028 | HFXO_CTRL_SET       | RWH SYNC    | Control Register                   |
| 0x1040 | HFXO_BUFOUTTRIM_SET | RW SYNC     | BUFOUT Trim Configuration Register |
| 0x1044 | HFXO_BUFOUTCTRL_SET | RW SYNC     | BUFOUT Control Register            |
| 0x1050 | HFXO_CMD_SET        | W SYNC      | Command Register                   |
| 0x1058 | HFXO_STATUS_SET     | RH          | Status Register                    |
| 0x1070 | HFXO_IF_SET         | RWH INTFLAG | Interrupt Flag Register            |
| 0x1074 | HFXO_IEN_SET        | RW          | Interrupt Enable Register          |
| 0x1080 | HFXO_LOCK_SET       | W           | Configuration Lock Register        |
| 0x2000 | HFXO_IPVERSION_CLR  | R           | IP Version ID                      |
| 0x2010 | HFXO_XTALCFG_CLR    | RW SYNC     | Crystal Configuration Register     |
| 0x2018 | HFXO_XTALCTRL_CLR   | RWH SYNC    | Crystal Control Register           |
| 0x201C | HFXO_XTALCTRL1_CLR  | RW SYNC     | BUFOUT Crystal Control Register    |
| 0x2020 | HFXO_CFG_CLR        | RW SYNC     | Configuration Register             |
| 0x2028 | HFXO_CTRL_CLR       | RWH SYNC    | Control Register                   |
| 0x2040 | HFXO_BUFOUTTRIM_CLR | RW SYNC     | BUFOUT Trim Configuration Register |
| 0x2044 | HFXO_BUFOUTCTRL_CLR | RW SYNC     | BUFOUT Control Register            |
| 0x2050 | HFXO_CMD_CLR        | W SYNC      | Command Register                   |

| Offset | Name                | Type        | Description                        |
|--------|---------------------|-------------|------------------------------------|
| 0x2058 | HFXO_STATUS_CLR     | RH          | Status Register                    |
| 0x2070 | HFXO_IF_CLR         | RWH INTFLAG | Interrupt Flag Register            |
| 0x2074 | HFXO_IEN_CLR        | RW          | Interrupt Enable Register          |
| 0x2080 | HFXO_LOCK_CLR       | W           | Configuration Lock Register        |
| 0x3000 | HFXO_IPVERSION_TGL  | R           | IP Version ID                      |
| 0x3010 | HFXO_XTALCFG_TGL    | RW SYNC     | Crystal Configuration Register     |
| 0x3018 | HFXO_XTALCTRL_TGL   | RWH SYNC    | Crystal Control Register           |
| 0x301C | HFXO_XTALCTRL1_TGL  | RW SYNC     | BUFOUT Crystal Control Register    |
| 0x3020 | HFXO_CFG_TGL        | RW SYNC     | Configuration Register             |
| 0x3028 | HFXO_CTRL_TGL       | RWH SYNC    | Control Register                   |
| 0x3040 | HFXO_BUFOUTTRIM_TGL | RW SYNC     | BUFOUT Trim Configuration Register |
| 0x3044 | HFXO_BUFOUTCTRL_TGL | RW SYNC     | BUFOUT Control Register            |
| 0x3050 | HFXO_CMD_TGL        | W SYNC      | Command Register                   |
| 0x3058 | HFXO_STATUS_TGL     | RH          | Status Register                    |
| 0x3070 | HFXO_IF_TGL         | RWH INTFLAG | Interrupt Flag Register            |
| 0x3074 | HFXO_IEN_TGL        | RW          | Interrupt Enable Register          |
| 0x3080 | HFXO_LOCK_TGL       | W           | Configuration Lock Register        |

## 9.2.5 HFXO Register Description

### 9.2.5.1 HFXO\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|        | 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 |
| Reset  | 0x3          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description   |
|------|-----------|-------|--------|---------------|
| 31:0 | IPVERSION | 0x3   | R      | IP Version ID |

The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION.

## 9.2.5.2 HFXO\_XTALCFG - Crystal Configuration Register

| Offset | Bit Position |               |                |                  |                 |                  |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|--------|--------------|---------------|----------------|------------------|-----------------|------------------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 0x010  | 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 |
| Reset  | 0xB          |               |                |                  |                 |                  |    |    |    |    |    |    | 0x0 |    |    |    |    |    |    |    |    |    |   |   | 0x20 |   |   |   |   |   |   |   |
| Access | RW           |               |                |                  |                 |                  |    |    |    |    |    |    | RW  |    |    |    |    |    |    |    |    |    |   |   | RW   |   |   |   |   |   |   |   |
| Name   | TIMEOUTCBLSB | TIMEOUTSTEADY | CTUNEXOSTARTUP | CTUNEXISTSTARTUP | COREBIASSTARTUP | COREBIASSTARTUPI |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |

| Bit   | Name         | Reset | Access | Description                                                                                                                                                       |
|-------|--------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 27:24 | TIMEOUTCBLSB | 0xB   | RW     | <b>Core Bias LSB Change Timeout</b><br><br>wait duration for the COREBIAS change to settle out, used at each step of COREBIAS optimization algorithm              |
| Value | Mode         |       |        | Description                                                                                                                                                       |
| 0     | T8US         |       |        | The core bias LSB change timeout is set to 8 us minimum. The maximum can be +40%.                                                                                 |
| 1     | T20US        |       |        | The core bias LSB change timeout is set to 20 us minimum. The maximum can be +40%.                                                                                |
| 2     | T41US        |       |        | The core bias LSB change timeout is set to 41 us minimum. The maximum can be +40%.                                                                                |
| 3     | T62US        |       |        | The core bias LSB change timeout is set to 62 us minimum. The maximum can be +40%.                                                                                |
| 4     | T83US        |       |        | The core bias LSB change timeout is set to 83 us minimum. The maximum can be +40%.                                                                                |
| 5     | T104US       |       |        | The core bias LSB change timeout is set to 104 us minimum. The maximum can be +40%.                                                                               |
| 6     | T125US       |       |        | The core bias LSB change timeout is set to 125 us minimum. The maximum can be +40%.                                                                               |
| 7     | T166US       |       |        | The core bias LSB change timeout is set to 166 us minimum. The maximum can be +40%.                                                                               |
| 8     | T208US       |       |        | The core bias LSB change timeout is set to 208 us minimum. The maximum can be +40%.                                                                               |
| 9     | T250US       |       |        | The core bias LSB change timeout is set to 250 us minimum. The maximum can be +40%.                                                                               |
| 10    | T333US       |       |        | The core bias LSB change timeout is set to 333 us minimum. The maximum can be +40%.                                                                               |
| 11    | T416US       |       |        | The core bias LSB change timeout is set to 416 us minimum. The maximum can be +40%.                                                                               |
| 12    | T833US       |       |        | The core bias LSB change timeout is set to 833 us minimum. The maximum can be +40%.                                                                               |

| Bit   | Name           | Reset   | Access | Description                                                                                                       |
|-------|----------------|---------|--------|-------------------------------------------------------------------------------------------------------------------|
| 13    |                | T1250US |        | The core bias LSB change timeout is set to 1250 us minimum. The maximum can be +40%.                              |
| 14    |                | T2083US |        | The core bias LSB change timeout is set to 2083 us minimum. The maximum can be +40%.                              |
| 15    |                | T3750US |        | The core bias LSB change timeout is set to 3750 us minimum. The maximum can be +40%.                              |
| 23:20 | TIMEOUTSTEADY  | 0xB     | RW     | <b>Steady State Timeout</b><br><br>wait duration for the steady state settings to settle out                      |
|       | Value          | Mode    |        | Description                                                                                                       |
|       | 0              | T4US    |        | The steady state timeout is set to 16 us minimum. The maximum can be +40%.                                        |
|       | 1              | T16US   |        | The steady state timeout is set to 41 us minimum. The maximum can be +40%.                                        |
|       | 2              | T41US   |        | The steady state timeout is set to 83 us minimum. The maximum can be +40%.                                        |
|       | 3              | T83US   |        | The steady state timeout is set to 125 us minimum. The maximum can be +40%.                                       |
|       | 4              | T125US  |        | The steady state timeout is set to 166 us minimum. The maximum can be +40%.                                       |
|       | 5              | T166US  |        | The steady state timeout is set to 208 us minimum. The maximum can be +40%.                                       |
|       | 6              | T208US  |        | The steady state timeout is set to 250 us minimum. The maximum can be +40%.                                       |
|       | 7              | T250US  |        | The steady state timeout is set to 333 us minimum. The maximum can be +40%.                                       |
|       | 8              | T333US  |        | The steady state timeout is set to 416 us minimum. The maximum can be +40%.                                       |
|       | 9              | T416US  |        | The steady state timeout is set to 500 us minimum. The maximum can be +40%.                                       |
|       | 10             | T500US  |        | The steady state timeout is set to 666 us minimum. The maximum can be +40%.                                       |
|       | 11             | T666US  |        | The steady state timeout is set to 833 us minimum. The maximum can be +40%.                                       |
|       | 12             | T833US  |        | The steady state timeout is set to 1666 us minimum. The maximum can be +40%.                                      |
|       | 13             | T1666US |        | The steady state timeout is set to 2500 us minimum. The maximum can be +40%.                                      |
|       | 14             | T2500US |        | The steady state timeout is set to 4166 us minimum. The maximum can be +40%.                                      |
|       | 15             | T4166US |        | The steady state timeout is set to 7500 us minimum. The maximum can be +40%.                                      |
| 19:16 | CTUNEXOSTARTUP | 0x0     | RW     | <b>Startup Tuning Capacitance on XO</b><br><br>4 most significant bits of CTUNEXOANA applied during startup phase |
| 15:12 | CTUNEXISTARTUP | 0x0     | RW     | <b>Startup Tuning Capacitance on XI</b>                                                                           |

| Bit                                                                              | Name             | Reset | Access | Description                                   |
|----------------------------------------------------------------------------------|------------------|-------|--------|-----------------------------------------------|
| 4 most significant bits of CTUNEXIANA applied during startup phase               |                  |       |        |                                               |
| 11:6                                                                             | COREBIASSTARTUP  | 0x20  | RW     | <b>Startup Core Bias Current</b>              |
| 6 most significant bits of COREBIASANA applied during startup phase              |                  |       |        |                                               |
| 5:0                                                                              | COREBIASSTARTUPI | 0x20  | RW     | <b>Intermediate Startup Core Bias Current</b> |
| 6 most significant bits of COREBIASANA applied during intermediate startup phase |                  |       |        |                                               |

## 9.2.5.3 HFXO\_XTALCTRL - Crystal Control Register

| Offset | Bit Position                                       |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------------------------------------------|------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------|------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Reset  | 0x0                                                | 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 |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access | RW                                                 |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | SKIPCOREBIASOPT                                    |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | COREBIASANA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31     | SKIPCOREBIASOPT                                    | 0x0  | RW | Core Degeneration                                                                                                                                                                 | CTUNEFIXANA | CTUNEXOANA | CTUNEXIANA | COREBIASANA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30:28  | Reserved                                           | 0x0  | RW | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27:26  | COREDEGENANA                                       | 0x0  | RW | <b>Core Degeneration</b>                                                                                                                                                          |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Core degeneration control                          |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |                                                    |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25:24  | CTUNEFIXANA                                        | 0x3  | RW | <b>Fixed Tuning Capacitance</b>                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Adds or removes fixed capacitance on XI or XO      |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |                                                    |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23:16  | CTUNEXOANA                                         | 0x3C | RW | <b>Tuning Capacitance on XO</b>                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Approximately 80fF per step. 0 is min. 255 is max. |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:8   | CTUNEXIANA                                         | 0x3C | RW | <b>Tuning Capacitance on XI</b>                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Approximately 80fF per step. 0 is min. 255 is max. |      |    |                                                                                                                                                                                   |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7:0    | COREBIASANA                                        | 0x3C | RW | <b>Core Bias Current</b>                                                                                                                                                          |             |            |            |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit | Name | Reset | Access | Description                 |
|-----|------|-------|--------|-----------------------------|
|     |      |       |        | Approximately 10uA per step |

**9.2.5.4 HFXO\_XTALCTRL1 - BUFOUT Crystal Control Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |                  |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|------------------|--|
| 0x01C         | 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    |                  |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x3C |                  |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW   |                  |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      | CTUNEXIBUFOUTANA |  |

| Bit  | Name             | Reset | Access | Description                                                                                                                                                                       |
|------|------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | CTUNEXIBUFOUTANA | 0x3C  | RW     | <b>BUFOUT Tuning Capacitance on XI</b><br><br>Tuning Capacitance on XI when BUFOUT is ON. Approximately 80fF per step. 0 is min. 255 is max.                                      |

## 9.2.5.5 HFXO\_CFG - Configuration Register

| Offset | Bit Position |    |    |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                |    |     |   |  |  |  |
|--------|--------------|----|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------------|----|-----|---|--|--|--|
| 0x020  | 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   |   |  |  |  |
| Reset  |              |    |    | 0x1            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                |    |     |   |  |  |  |
| Access |              |    |    | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                |    |     |   |  |  |  |
| Name   |              |    |    | FORCELFTIMEOUT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | SQBUFSCHTRGANA | RW | 0x0 | 3 |  |  |  |
|        |              |    |    |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | ENXIDCBIASANA  | RW | 0x0 | 2 |  |  |  |
|        |              |    |    |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | MODE           | RW | 0x0 |   |  |  |  |

| Bit   | Name           | Reset       | Access | Description                                                                                                                                                                       |
|-------|----------------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved       |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 28    | FORCELFTIMEOUT | 0x1         | RW     | <b>Force Low Frequency Timeout</b>                                                                                                                                                |
|       |                |             |        | For deterministic timeout, clear this bit and configure PRS to trigger based on 32kHz timer (e.g., RTC).                                                                          |
| 27:4  | Reserved       |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3     | SQBUFSCHTRGANA | 0x0         | RW     | <b>Squaring Buffer Schmitt Trigger</b>                                                                                                                                            |
|       |                |             |        | Used in EXTCLK mode to prevent self oscillation                                                                                                                                   |
|       | Value          | Mode        |        | Description                                                                                                                                                                       |
|       | 0              | DISABLE     |        | Squaring buffer schmitt trigger is disabled                                                                                                                                       |
|       | 1              | ENABLE      |        | Squaring buffer schmitt trigger is enabled                                                                                                                                        |
| 2     | ENXIDCBIASANA  | 0x0         | RW     | <b>Enable XI Internal DC Bias</b>                                                                                                                                                 |
|       |                |             |        | Set to enable internal DC bias. Bit is ignored in XTAL mode.                                                                                                                      |
| 1:0   | MODE           | 0x0         | RW     | <b>Crystal Oscillator Mode</b>                                                                                                                                                    |
|       |                |             |        | Set this to configure the external source for the HFXO.                                                                                                                           |
|       | Value          | Mode        |        | Description                                                                                                                                                                       |
|       | 0              | XTAL        |        | crystal oscillator                                                                                                                                                                |
|       | 1              | EXTCLK      |        | external sinusoidal clock can be supplied on XI pin.                                                                                                                              |
|       | 2              | EXTCLKPKDET |        | external sinusoidal clock can be supplied on XI pin (peak detector used).                                                                                                         |

## 9.2.5.6 HFXO\_CTRL - Control Register

| Offset | Bit Position      |                |             |               |            |         |               |               |               |                |                |              |          |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |
|--------|-------------------|----------------|-------------|---------------|------------|---------|---------------|---------------|---------------|----------------|----------------|--------------|----------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|
| Reset  | 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 |
| Access | RW                | RW             | RW          | RW            | RW         | RW      | RW            | RW            | RW            | RW             | RW             | RW           | RW       | RW           | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW |   |   |
| Name   | DISONDEMANDBUFOUT | DISONDEMANDPRS | DISONDEMAND | FORCEENBUFOUT | FORCEENPRS | FORCEEN | PRSSTATUSSEL1 | PRSSTATUSSEL0 | FORCECTUNEMAX | FORCEX02GNDANA | FORCEX12GNDANA | EM23ONDemand | KEEPWARM | BUFOUTFREEZE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |

| Bit   | Name              | Reset | Access | Description                                                                                                                                                       |
|-------|-------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 26    | DISONDEMANDBUFOUT | 0x1   | RW     | <b>Disable On-demand For BUFOUT</b><br><br>Disable On Demand for the BUFOUT request interface.                                                                    |
| 25    | DISONDEMANDPRS    | 0x1   | RW     | <b>Disable On-demand For PRS</b><br><br>Disable On Demand for the PRS request interface.                                                                          |
| 24    | DISONDEMAND       | 0x1   | RW     | <b>Disable On-demand For Digital Clock</b><br><br>Disable On Demand for the digital clock request interface.                                                      |
| 23:19 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 18    | FORCEENBUFOUT     | 0x0   | RW     | <b>Force BUFOUT Request</b><br><br>Force BUFOUT request.                                                                                                          |
| 17    | FORCEENPRS        | 0x0   | RW     | <b>Force PRS Oscillator Request</b><br><br>Force PRS oscillator request.                                                                                          |
| 16    | FORCEEN           | 0x0   | RW     | <b>Force Digital Clock Request</b><br><br>Force digital clock request.                                                                                            |
| 15:12 | PRSSTATUSSEL1     | 0x0   | RW     | <b>PRS Status 1 Output Select</b><br><br>Mux select for various status signals to be output through PRS.                                                          |
| Value | Mode              |       |        | Description                                                                                                                                                       |
| 0     | DISABLED          |       |        | PRS mux outputs 0                                                                                                                                                 |
| 1     | ENS               |       |        | PRS mux outputs enabled status                                                                                                                                    |
| 2     | COREBIASOPTRDY    |       |        | PRS mux outputs core bias optimization ready status                                                                                                               |
| 3     | RDY               |       |        | PRS mux outputs ready status                                                                                                                                      |
| 4     | PRSRDY            |       |        | PRS mux outputs PRS ready status                                                                                                                                  |
| 5     | BUFOUTRDY         |       |        | PRS mux outputs BUFOUT ready status                                                                                                                               |

| Bit  | Name           | Reset          | Access | Description                                                                                                                                                                                               |
|------|----------------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | HWREQ          |                |        | PRS mux outputs oscillator requested by digital clock status                                                                                                                                              |
| 9    | PRSHWREQ       |                |        | PRS mux outputs oscillator requested by PRS request status                                                                                                                                                |
| 10   | BUFOUTHWREQ    |                |        | PRS mux outputs oscillator requested by BUFOUT request status                                                                                                                                             |
| 11:8 | PRSSTATUSSEL0  | 0x0            | RW     | <b>PRS Status 0 Output Select</b><br><br>Mux select for various status signals to be output through PRS.                                                                                                  |
|      | Value          | Mode           |        | Description                                                                                                                                                                                               |
|      | 0              | DISABLED       |        | PRS mux outputs 0                                                                                                                                                                                         |
|      | 1              | ENS            |        | PRS mux outputs enabled status                                                                                                                                                                            |
|      | 2              | COREBIASOPTRDY |        | PRS mux outputs core bias optimization ready status                                                                                                                                                       |
|      | 3              | RDY            |        | PRS mux outputs ready status                                                                                                                                                                              |
|      | 4              | PRSRDY         |        | PRS mux outputs PRS ready status                                                                                                                                                                          |
|      | 5              | BUFOUTRDY      |        | PRS mux outputs BUFOUT ready status                                                                                                                                                                       |
|      | 8              | HWREQ          |        | PRS mux outputs oscillator requested by digital clock status                                                                                                                                              |
|      | 9              | PRSHWREQ       |        | PRS mux outputs oscillator requested by PRS request status                                                                                                                                                |
|      | 10             | BUFOUTHWREQ    |        | PRS mux outputs oscillator requested by BUFOUT request status                                                                                                                                             |
| 7    | Reserved       |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                         |
| 6    | FORCECTUNEMAX  | 0x1            | RW     | <b>Force Tuning Cap to Max Value</b><br><br>When oscillator is disabled, force tuning capacitor to maximum value. Set this bit to 1 in XTAL mode to prevent overshoot upon disable.                       |
| 5    | FORCEXO2GNDANA | 0x0            | RW     | <b>Force XO Pin to Ground</b><br><br>Set to enable grounding of XO pin.                                                                                                                                   |
|      | Value          | Mode           |        | Description                                                                                                                                                                                               |
|      | 0              | DISABLE        |        | Disabled (not pulled)                                                                                                                                                                                     |
|      | 1              | ENABLE         |        | Enabled (pulled)                                                                                                                                                                                          |
| 4    | FORCEXI2GNDANA | 0x0            | RW     | <b>Force XI Pin to Ground</b><br><br>Set to enable grounding of XI pin. Do not enable if MODE=EXTCLK and an external source is supplied.                                                                  |
|      | Value          | Mode           |        | Description                                                                                                                                                                                               |
|      | 0              | DISABLE        |        | Disabled (not pulled)                                                                                                                                                                                     |
|      | 1              | ENABLE         |        | Enabled (pulled)                                                                                                                                                                                          |
| 3    | EM23ONDEMAND   | 0x0            | RW     | <b>On-demand During EM23</b><br><br>Use this bit to prevent EM23 shutdown of the module's power domain upon EM23 entry. Set this bit to 1 if on-demand requests are supposed to be honored while in EM23. |
| 2    | KEEPWARM       | 0x0            | RW     | <b>Keep Warm</b>                                                                                                                                                                                          |

| Bit | Name         | Reset | Access | Description                                                                                                                                                                       |
|-----|--------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |              |       |        | Upon disable, if this bit is set, analog oscillator will keep running, while clock output is shutoff. Clearing this bit has no effect until the next disable event.               |
| 1   | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0   | BUFOUTFREEZE | 0x0   | RW     | <b>Freeze BUFOUT Controls</b><br><br>Freeze BUFOUT Controls in current state (ON or OFF).                                                                                         |

### 9.2.5.7 HFXO\_BUFOUTTRIM - BUFOUT Trim Configuration Register

| Bit  | Name       | Reset | Access | Description                                                                                                                                                                                                                       |
|------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                 |
| 3:0  | VTRTRIMANA | 0x8   | RW     | <b>BUFOUT Reference Trim</b><br><br>Change this field to set bias levels between 200uA and 400uA. $\text{bias\_current} = \text{VTRTCANA} * \text{VTRTRIMANA} * \text{scale\_factor}$ . The default setting corresponds to 200uA. |

## 9.2.5.8 HFxo\_BUFOUTCTRL - BUFOUT Control Register

| Offset | Bit Position        |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|--------|---------------------|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|
| 0x044  | 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 |  |  |  |  |  |  |
| Reset  | 0x0                 |    |    |    |    |    |    |    | 0x6             |    |    |    |    |    |    |    |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| Access | RW                  |    |    |    |    |    |    |    | RW              |    |    |    |    |    |    |    | RW          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| Name   | MINIMUMSTARTUPDELAY |    |    |    |    |    |    |    | TIMEOUTSTARTUP  |    |    |    |    |    |    |    | TIMEOUTTUNE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|        | XOUTGMANA           |    |    |    |    |    |    |    | PEAKDETTHRESANA |    |    |    |    |    |    |    | XOUTCFANA   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|        | XOUTBIASANA         |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |

| Bit   | Name                | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | MINIMUMSTARTUPDELAY | 0x0   | RW     | <b>Minimum Startup Delay</b>                                                                                                                                                      |
|       |                     |       |        | If set, BUFOUT does not start until timeout expires. This prevents waste of power if BUFOUT is ready too early.                                                                   |
| 30:24 | Reserved            |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

|       |                |     |    |                                                                                                                                       |
|-------|----------------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------|
| 23:20 | TIMEOUTSTARTUP | 0x6 | RW | <b>Oscillator Startup Timeout</b>                                                                                                     |
|       |                |     |    | Wait duration for the typical oscillator startup sequence to prevent BUFOUT starting too early, used when MINIMUMSTARTUPDELAY is set. |

| Value | Mode   | Description                                                                       |
|-------|--------|-----------------------------------------------------------------------------------|
| 0     | T42US  | The oscillator startup timeout is set to 42 us minimum. The maximum can be +40%.  |
| 1     | T83US  | The oscillator startup timeout is set to 83 us minimum. The maximum can be +40%.  |
| 2     | T108US | The oscillator startup timeout is set to 108 us minimum. The maximum can be +40%. |
| 3     | T133US | The oscillator startup timeout is set to 133 us minimum. The maximum can be +40%. |
| 4     | T158US | The oscillator startup timeout is set to 158 us minimum. The maximum can be +40%. |
| 5     | T183US | The oscillator startup timeout is set to 183 us minimum. The maximum can be +40%. |
| 6     | T208US | The oscillator startup timeout is set to 208 us minimum. The maximum can be +40%. |
| 7     | T233US | The oscillator startup timeout is set to 233 us minimum. The maximum can be +40%. |
| 8     | T258US | The oscillator startup timeout is set to 258 us minimum. The maximum can be +40%. |
| 9     | T283US | The oscillator startup timeout is set to 283 us minimum. The maximum can be +40%. |

| Bit   | Name         | Reset  | Access | Description                                                                                             |
|-------|--------------|--------|--------|---------------------------------------------------------------------------------------------------------|
| 10    | T333US       |        |        | The oscillator startup timeout is set to 333 us minimum. The maximum can be +40%.                       |
| 11    | T375US       |        |        | The oscillator startup timeout is set to 375 us minimum. The maximum can be +40%.                       |
| 12    | T417US       |        |        | The oscillator startup timeout is set to 417 us minimum. The maximum can be +40%.                       |
| 13    | T458US       |        |        | The oscillator startup timeout is set to 458 us minimum. The maximum can be +40%.                       |
| 14    | T500US       |        |        | The oscillator startup timeout is set to 500 us minimum. The maximum can be +40%.                       |
| 15    | T667US       |        |        | The oscillator startup timeout is set to 667 us minimum. The maximum can be +40%.                       |
| 19:16 | TIMEOUTCTUNE | 0x4    | RW     | <b>Tuning Cap Change Timeout</b>                                                                        |
|       |              |        |        | Wait duration for the CTUNE change to settle out, used when CTUNE changes as result of enabling BUFOUT. |
|       | Value        | Mode   |        | Description                                                                                             |
|       | 0            | T2US   |        | The tuning cap change timeout is set to 2 us minimum. The maximum can be +40%.                          |
|       | 1            | T5US   |        | The tuning cap change timeout is set to 5 us minimum. The maximum can be +40%.                          |
|       | 2            | T10US  |        | The tuning cap change timeout is set to 10 us minimum. The maximum can be +40%.                         |
|       | 3            | T16US  |        | The tuning cap change timeout is set to 16 us minimum. The maximum can be +40%.                         |
|       | 4            | T21US  |        | The tuning cap change timeout is set to 21 us minimum. The maximum can be +40%.                         |
|       | 5            | T26US  |        | The tuning cap change timeout is set to 26 us minimum. The maximum can be +40%.                         |
|       | 6            | T31US  |        | The tuning cap change timeout is set to 31 us minimum. The maximum can be +40%.                         |
|       | 7            | T42US  |        | The tuning cap change timeout is set to 42 us minimum. The maximum can be +40%.                         |
|       | 8            | T52US  |        | The tuning cap change timeout is set to 52 us minimum. The maximum can be +40%.                         |
|       | 9            | T63US  |        | The tuning cap change timeout is set to 63 us minimum. The maximum can be +40%.                         |
|       | 10           | T83US  |        | The tuning cap change timeout is set to 83 us minimum. The maximum can be +40%.                         |
|       | 11           | T104US |        | The tuning cap change timeout is set to 104 us minimum. The maximum can be +40%.                        |
|       | 12           | T208US |        | The tuning cap change timeout is set to 208 us minimum. The maximum can be +40%.                        |
|       | 13           | T313US |        | The tuning cap change timeout is set to 313 us minimum. The maximum can be +40%.                        |
|       | 14           | T521US |        | The tuning cap change timeout is set to 521 us minimum. The maximum can be +40%.                        |

| Bit   | Name            | Reset  | Access | Description                                                                                 |
|-------|-----------------|--------|--------|---------------------------------------------------------------------------------------------|
|       | 15              | T938US |        | The tuning cap change timeout is set to 938 us minimum. The maximum can be +40%.            |
| 15:12 | PEAKDETTHRESANA | 0x3    | RW     | <b>Peak Detector Threshold for XOUT</b><br><br>Sets the peak detector threshold for BUFOUT. |
|       | Value           | Mode   |        | Description                                                                                 |
|       | 0               | V105MV |        |                                                                                             |
|       | 1               | V132MV |        |                                                                                             |
|       | 2               | V157MV |        |                                                                                             |
|       | 3               | V184MV |        |                                                                                             |
|       | 4               | V210MV |        |                                                                                             |
|       | 5               | V236MV |        |                                                                                             |
|       | 6               | V262MV |        |                                                                                             |
|       | 7               | V289MV |        |                                                                                             |
|       | 8               | V315MV |        |                                                                                             |
|       | 9               | V341MV |        |                                                                                             |
|       | 10              | V367MV |        |                                                                                             |
|       | 11              | V394MV |        |                                                                                             |
|       | 12              | V420MV |        |                                                                                             |
|       | 13              | V446MV |        |                                                                                             |
|       | 14              | V472MV |        |                                                                                             |
|       | 15              | V499MV |        |                                                                                             |
| 11:8  | XOUTGMANA       | 0xC    | RW     |                                                                                             |
| 7:4   | XOUTCFANA       | 0x1    | RW     | <b>Buffer Gain</b><br><br>Buffer gain.                                                      |
| 3:0   | XOUTBIASANA     | 0x5    | RW     | <b>Driver Bias Current</b><br><br>Driver bias current.                                      |

## 9.2.5.9 HFxo\_CMD - Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |             |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|-------------|
| 0x050  | 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     | COREBIASOPT |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0   |             |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | W(nB) |             |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       | COREBIASOPT |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                                       |
|------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | COREBIASOPT | 0x0   | W(nB)  | <b>Core Bias Optimizaton</b>                                                                                                                                                      |

On devices with a radio, this bit is used to start the core bias current optimization algorithm and run it one time. Optimization should be executed if the temperature changes by more than 40 degC. Do not run this command while the radio is in RX or TX modes. Do not issue this command more than once until COREBIASOPTRDY is asserted, or the previous command may be cancelled.

## 9.2.5.10 HFXO\_STATUS - Status Register

| Offset | Bit Position |          |     |    |    |    |    |    |    |             |     |    |    |          |     |    |    |    |    |    |    |   |   |   |   |   |           |     |        |                |     |     |
|--------|--------------|----------|-----|----|----|----|----|----|----|-------------|-----|----|----|----------|-----|----|----|----|----|----|----|---|---|---|---|---|-----------|-----|--------|----------------|-----|-----|
| 0x058  | 31           | 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   |     |
| Reset  | 0x0          | 0x0      | 0x0 |    |    |    |    |    |    | R           | 0x0 |    |    | R        | 0x0 |    |    |    |    |    |    |   |   |   |   |   |           |     |        |                |     |     |
| Access | R            | R        |     |    |    |    |    |    |    | R           | 0x0 |    |    | R        | 0x0 |    |    |    |    |    |    |   |   |   |   |   | R         | 0x0 |        | R              | 0x0 |     |
| Name   | LOCK         | SYNCBUSY |     |    |    |    |    |    |    | BUFOUTHWREQ |     |    |    | PRSHWREQ |     |    |    |    |    |    |    |   |   |   |   |   | BUFOUTRDY |     | PRSRDY | COREBIASOPTRDY |     |     |
|        |              |          |     |    |    |    |    |    |    |             |     |    |    |          |     |    |    |    |    |    |    |   |   |   |   |   |           |     |        |                |     | RDY |

| Bit   | Name         | Reset                                                                                                                                                             | Access | Description                                   |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------|
| 31    | LOCK         | 0x0                                                                                                                                                               | R      | <b>Configuration Lock Status</b>              |
|       |              | Indicates the current status of configuration lock.                                                                                                               |        |                                               |
|       | Value        | Mode                                                                                                                                                              |        | Description                                   |
|       | 0            | UNLOCKED                                                                                                                                                          |        | Configuration lock is unlocked                |
|       | 1            | LOCKED                                                                                                                                                            |        | Configuration lock is locked                  |
| 30    | SYNCBUSY     | 0x0                                                                                                                                                               | R      | <b>Sync Busy</b>                              |
|       |              | Indicates synchronization is ongoing.                                                                                                                             |        |                                               |
| 29:22 | Reserved     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                               |
| 21    | BUFOUTHWREQ  | 0x0                                                                                                                                                               | R      | <b>Oscillator Requested by BUFOUT Request</b> |
|       |              | Oscillator is requested by the BUFOUT oscillator request interface.                                                                                               |        |                                               |
| 20    | PRSHWREQ     | 0x0                                                                                                                                                               | R      | <b>Oscillator Requested by PRS Request</b>    |
|       |              | Oscillator is requested by the PRS oscillator request interface.                                                                                                  |        |                                               |
| 19    | ISWARM       | 0x0                                                                                                                                                               | R      | <b>Oscillator Is Kept Warm</b>                |
|       |              | Oscillator is currently kept in warm state. Re-enable from warm state skips startup sequence.                                                                     |        |                                               |
| 18    | Reserved     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                               |
| 17    | HWREQ        | 0x0                                                                                                                                                               | R      | <b>Oscillator Requested by Digital Clock</b>  |
|       |              | Oscillator is requested by digital clock request interface.                                                                                                       |        |                                               |
| 16    | ENS          | 0x0                                                                                                                                                               | R      | <b>Enabled Status</b>                         |
|       |              | Oscillator is enabled.                                                                                                                                            |        |                                               |
| 15    | BUFOUTFROZEN | 0x0                                                                                                                                                               | R      | <b>BUFOUT Frozen</b>                          |
|       |              | FSM is frozen with respect to starting BUFOUT enable or disable sequences.                                                                                        |        |                                               |
| 14:4  | Reserved     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                               |
| 3     | BUFOUTRDY    | 0x0                                                                                                                                                               | R      | <b>BUFOUT Ready Status</b>                    |
|       |              | The BUFOUT clock is ready.                                                                                                                                        |        |                                               |

| Bit | Name           | Reset | Access | Description                                                                                  |
|-----|----------------|-------|--------|----------------------------------------------------------------------------------------------|
| 2   | PRSRDY         | 0x0   | R      | <b>PRS Ready Status</b><br>The PRS oscillator startup is ready.                              |
| 1   | COREBIASOPTRDY | 0x0   | R      | <b>Core Bias Optimization Ready</b><br>Core bias current optimization algorithm is complete. |
| 0   | RDY            | 0x0   | R      | <b>Ready Status</b><br>The digital clock branch (osc.clk_qual) is ready.                     |

### 9.2.5.11 HFXO\_IF - Interrupt Flag Register

| Offset | Bit Position    |    |     |    |    |    |    |    |
|--------|-----------------|----|-----|----|----|----|----|----|
| Reset  | 0x070           | 31 | 30  | 29 | 28 | 27 | 26 | 25 |
| Access |                 | 30 | 29  | 28 | 27 | 26 | 25 | 24 |
| Name   | COREBIASOPTERR  | RW | 0x0 | 21 |    |    |    |    |
|        | LFTIMEOUTERR    | RW | 0x0 | 31 | 30 | 29 | 28 | 27 |
|        | DNSERR          | RW | 0x0 | 26 | 25 | 24 | 23 | 22 |
|        | BUFOUTDNSEERR   | RW | 0x0 | 22 |    |    |    |    |
|        | BUFOUTFREEZEERR | RW | 0x0 | 21 |    |    |    |    |
| Reset  | PRSERR          | RW | 0x0 | 20 | 19 | 18 | 17 | 16 |
| Access |                 |    |     | 21 | 20 | 19 | 18 | 17 |
| Name   | BUFOUTERR       | RW | 0x0 | 15 | 14 | 13 | 12 | 11 |
|        | PRSERR          | RW | 0x0 | 20 | 19 | 18 | 17 | 16 |
|        | BUFOUTFROZEN    | RW | 0x0 | 15 | 14 | 13 | 12 | 11 |
|        | BUFOUTRDY       | RW | 0x0 | 3  | 2  | 1  | 0  |    |
|        | PRSRDY          | RW | 0x0 | 4  | 3  | 2  | 1  | 0  |
| Offset | COREBIASOPTRDY  | RW | 0x0 | 31 | 30 | 29 | 28 | 27 |
|        | RDY             | RW | 0x0 | 26 | 25 | 24 | 23 | 22 |

| Bit   | Name            | Reset                                                                                                                                                                             | Access | Description                                                                                                                                          |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | COREBIASOPTERR  | 0x0                                                                                                                                                                               | RW     | <b>Core Bias Optimization Error Interrupt</b><br>Core bias current optimization algorithm fails to complete.                                         |
| 30    | LFTIMEOUTERR    | 0x0                                                                                                                                                                               | RW     | <b>Low Frequency Timeout Error Interrupt</b><br>Low frequency timeout triggers before the steady state timeout triggers.                             |
| 29    | DNSERR          | 0x0                                                                                                                                                                               | RW     | <b>Did Not Start Error Interrupt</b><br>Crystal oscillator fails to startup.                                                                         |
| 28    | BUFOUTDNSERR    | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Did Not Start Error Interrupt</b><br>BUFOUT fails to startup.                                                                              |
| 27    | BUFOUTFREEZEERR | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Freeze Error Interrupt</b><br>BUFOUTFREEZE should not be set when HWREQ is low as this can prevent service to companion chip indefinitely. |
| 26:22 | Reserved        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                      |
| 21    | BUFOUTERR       | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Request Error Interrupt</b><br>BUFOUT request is asserted while oscillator is forced to shutdown.                                          |
| 20    | PRSERR          | 0x0                                                                                                                                                                               | RW     | <b>PRS Request Error Interrupt</b><br>PRS request is asserted while oscillator is forced to shutdown.                                                |
| 19:16 | Reserved        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                      |
| 15    | BUFOUTFROZEN    | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT FROZEN Interrupt</b><br>FSM is frozen with respect to starting BUFOUT enable or disable sequences.                                         |
| 14:4  | Reserved        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                      |
| 3     | BUFOUTRDY       | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Ready Interrupt</b><br>The BUFOUT clock is ready.                                                                                          |
| 2     | PRSRDY          | 0x0                                                                                                                                                                               | RW     | <b>PRS Ready Interrupt</b><br>The PRS oscillator startup is ready.                                                                                   |
| 1     | COREBIASOPTRDY  | 0x0                                                                                                                                                                               | RW     | <b>Core Bias Optimization Ready Interrupt</b>                                                                                                        |

| Bit                                                   | Name | Reset | Access | Description                          |
|-------------------------------------------------------|------|-------|--------|--------------------------------------|
| Core bias current optimization algorithm is complete. |      |       |        |                                      |
| 0                                                     | RDY  | 0x0   | RW     | <b>Digital Clock Ready Interrupt</b> |
| The digital clock branch (osc.clk_qual) is ready.     |      |       |        |                                      |

## 9.2.5.12 HFXO\_IEN - Interrupt Enable Register

| Offset | Bit Position   |              |        |               |                 |           |       |              |           |        |                |     |     |     |     |     |     |   |
|--------|----------------|--------------|--------|---------------|-----------------|-----------|-------|--------------|-----------|--------|----------------|-----|-----|-----|-----|-----|-----|---|
| 0x074  | 31             | 20           | 19     | 18            | 17              | 16        | 15    | 14           | 13        | 12     | 11             | 10  | 9   | 8   | 7   | 6   | 5   | 4 |
| Reset  | 0x0            | 0x0          | 0x0    | 0x0           | 0x0             | 0x0       | 0x0   | 0x0          | 0x0       | 0x0    | 0x0            | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 |   |
| Access | RW             | RW           | RW     | RW            | RW              | RW        | RW    | RW           | RW        | RW     | RW             | RW  | RW  | RW  | RW  | RW  | RW  |   |
| Name   | COREBIASOPTERR | LFTIMEOUTERR | DNSERR | BUFOUTDNSSERR | BUFOUTFREEZEERR | BUFOUTERR | PRSER | BUFOUTFROZEN | BUFOUTRDY | PRSRDY | COREBIASOPTRDY | RDY |     |     |     |     |     |   |

| Bit   | Name            | Reset                                                                                                                                                                             | Access | Description                                                                                                                                              |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | COREBIASOPTERR  | 0x0                                                                                                                                                                               | RW     | <b>Core Bias Optimization Error Interrupt</b><br><br>Core bias current optimization algorithm fails to complete.                                         |
| 30    | LFTIMEOUTERR    | 0x0                                                                                                                                                                               | RW     | <b>Low Frequency Timeout Error Interrupt</b><br><br>Low frequency timeout triggers before the steady state timeout triggers.                             |
| 29    | DNSERR          | 0x0                                                                                                                                                                               | RW     | <b>Did Not Start Error Interrupt</b><br><br>Crystal oscillator fails to startup.                                                                         |
| 28    | BUFOUTDNSSERR   | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Did Not Start Error Interrupt</b><br><br>BUFOUT fails to startup.                                                                              |
| 27    | BUFOUTFREEZEERR | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Freeze Error Interrupt</b><br><br>BUFOUTFREEZE should not be set when HWREQ is low as this can prevent service to companion chip indefinitely. |
| 26:22 | Reserved        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                          |
| 21    | BUFOUTERR       | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Request Error Interrupt</b><br><br>BUFOUT request is asserted while oscillator is forced to shutdown.                                          |
| 20    | PRSER           | 0x0                                                                                                                                                                               | RW     | <b>PRS Request Error Interrupt</b><br><br>PRS request is asserted while oscillator is forced to shutdown.                                                |
| 19:16 | Reserved        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                          |
| 15    | BUFOUTFROZEN    | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT FROZEN Interrupt</b><br><br>FSM is frozen with respect to starting BUFOUT enable or disable sequences.                                         |
| 14:4  | Reserved        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                          |
| 3     | BUFOUTRDY       | 0x0                                                                                                                                                                               | RW     | <b>BUFOUT Ready Interrupt</b><br><br>The BUFOUT clock is ready.                                                                                          |
| 2     | PRSRDY          | 0x0                                                                                                                                                                               | RW     | <b>PRS Ready Interrupt</b><br><br>The PRS oscillator startup is ready.                                                                                   |
| 1     | COREBIASOPTRDY  | 0x0                                                                                                                                                                               | RW     | <b>Core Bias Optimization Ready Interrupt</b>                                                                                                            |

| Bit                                                   | Name | Reset | Access | Description                          |
|-------------------------------------------------------|------|-------|--------|--------------------------------------|
| Core bias current optimization algorithm is complete. |      |       |        |                                      |
| 0                                                     | RDY  | 0x0   | RW     | <b>Digital Clock Ready Interrupt</b> |
| The digital clock branch (osc.clk_qual) is ready.     |      |       |        |                                      |

### 9.2.5.13 HFXO\_LOCK - Configuration Lock Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x080         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x580E  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | W       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LOCKKEY |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset                                                                                                       | Access | Description                                                                                                                                                       |
|-------|----------|-------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |                                                                                                             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:0  | LOCKKEY  | 0x580E                                                                                                      | W      | <b>Configuration Lock Key</b>                                                                                                                                     |
|       |          | Write any other value than the unlock code to lock registers from editing. Write the unlock code to unlock. |        |                                                                                                                                                                   |
|       |          | Value                                                                                                       |        | Mode                                                                                                                                                              |
|       |          | 22542                                                                                                       |        | UNLOCK                                                                                                                                                            |
|       |          | Description                                                                                                 |        |                                                                                                                                                                   |
|       |          | Write this value to unlock                                                                                  |        |                                                                                                                                                                   |

## 9.3 HFRCO - High-Frequency RC Oscillator

### 9.3.1 Introduction

The HFRCO is a calibrated internal High Frequency RC oscillator.

### 9.3.2 Features

- 1 MHz - 80 MHz High Frequency RC Oscillator with DPLL working in EM01 (HFRCO0/HFRCODPLL)
- 1 MHz - 40 MHz High Frequency RC Oscillator working in EM23 (HFRCOEM23)
- Low start-up time
- Run-time band change or tuning

### 9.3.3 Functional Description

#### 9.3.3.1 Start-up

The HFRCO starts up quickly in a few micro-seconds (refer to device data sheet for start-up time specifications.) After the start-up time, the RDY status bit will go high and the RDY interrupt will be triggered. It can take another two clock cycles for the clock to propagate through the CMU before the clock is seen by peripherals.

### 9.3.3.2 On-Demand Clocking

Software can request to enable the HFRCO by setting the HFRCO\_CTRL.FORCEEN bit field. The HFRCO can also optionally be configured via the HFRCO\_CTRL.DISONDEMAND to shut down when no hardware request is present. This is known as on-demand clocking and allows the oscillator to be controlled without any software intervention. This means that HFRCO receives a request for clock from the CMU whenever the oscillator clock is needed. These requests can come at any time from any power domain (depending on which peripheral is requesting the clock.)

#### 9.3.3.2.1 EM2/EM3 On-Demand Operation (HFRCOEM23)

The HFRCOEM23 can be used by certain peripherals as an on-demand, high-speed clock source in energy modes down to EM3. To enable operation as an on-demand clock in EM2 and EM3, the EM23ONDEMAND bit in the CTRL register should be set to 1. Setting this bit ensures that the associated PD0 power domain will remain active and allow the oscillator to honor the request.

**Note:** This feature is not available on the HFRCODPLL oscillator, which only operates in EM0 and EM1.

### 9.3.3.3 Calibration

Several different frequencies are calibrated during production test on every device. In order to use a factory-calibrated value, software must read the value from the appropriate location in the DEVINFO page and write it to the CAL register.

The TUNING and FINETUNING bit fields in the CAL register can be used to trim HFRCO manually.

Software may write the CAL register at any time. If there is already a frequency updating occurring, the current change would apply when the previous update is done. FREQBSY in STATUS register indicates if the updating is finished.

The minimum and maximum frequencies attainable for each setting of the FREQRANGE field are listed in the device data sheet.

**Table 9.1. HFRCODPLL Calibration Frequencies**

| DEVINFO Location | Target Frequency |
|------------------|------------------|
| HFRCODPLLCAL0    | 4 MHz            |
| HFRCODPLLCAL1    | 5 MHz            |
| HFRCODPLLCAL3    | 7 MHz            |
| HFRCODPLLCAL4    | 10 MHz           |
| HFRCODPLLCAL6    | 13 MHz           |
| HFRCODPLLCAL7    | 16 MHz           |
| HFRCODPLLCAL8    | 19 MHz (default) |
| HFRCODPLLCAL9    | 20 MHz           |
| HFRCODPLLCAL10   | 26 MHz           |
| HFRCODPLLCAL11   | 32 MHz           |
| HFRCODPLLCAL12   | 38 MHz           |
| HFRCODPLLCAL13   | 48 MHz           |
| HFRCODPLLCAL14   | 56 MHz           |
| HFRCODPLLCAL15   | 64 MHz           |
| HFRCODPLLCAL16   | 80 MHz           |

### 9.3.3.4 Interrupts

HFRCO has one interrupt: IF.RDY. RDY is triggered when the timeout has finished and the qualified HFRCO clock is ready. The clock is gated until it is ready.

### 9.3.3.5 Status Flags

#### 9.3.3.5.1 FREQBSY

The FREQBSY bit indicates the HFRCO is busy updating its frequency after writing to the CAL register. The FREQBSY bit should be used whenever frequency is changed. E.g. After software writes to the CAL register, FREQBSY would assert immediately. Software should wait for FREQBSY to be zero before attempting to write to the CAL register again.

For band-change, FREQBSY would not de-assert until after the timeout upon being re-enabled.

For normal start-up, FREQBSY would not assert.

When DPLL is on, FREQBSY would not assert as the frequency change is not caused by writing to the CAL register. When disabling DPLL the last tuning value is written back to the CAL register, which will assert FREQBSY.

#### 9.3.3.5.2 ENS

ENS indicates the HFRCO is enabled. This flag is used to check if the HFRCO is enabled by any requester.

**Note:** When a band change occurs, the HFRCO is disabled and re-enabled. This will cause the ENS bit to briefly de-assert.

#### 9.3.3.5.3 RDY

RDY indicates HFRCO is enabled and start-up timeout has exceeded. Used to check if the HFRCO clock is ready after enable.

Changing bands will de-assert RDY as the oscillator must reset and start up again.

#### 9.3.3.5.4 SYNCBUSY

SYNCBUSY indicates ongoing synchronization of CAL register fields. Same as all other modules.

### 9.3.3.6 Forced Oscillator Control

The HFRCO can be forced on and off using the FORCEEN and DISONDEMAND bits in the CTRL register.

Setting FORCEEN will force the oscillator core to run, but peripherals will still need to request the clock to un-gate the clock signal.

### 9.3.3.7 Oscillator Modes

The HFRCO has three modes of operation, an **on-demand** mode (which is the normal software use case), a **force on** and a **force off** mode.

In **on-demand** mode the oscillator will start whenever a peripheral requests it. Which in most cases is whenever the peripheral is enabled.

In **force on** mode the analog core will run independently of whether it is requested or not. This can be useful for measuring analog current without any digital load on the clocks.

In **force off** mode, the analog core will be shut off independently of whether it is requested or not. This can be useful for changing analog test settings without risking glitches on the clock.

The DISONDEMAND bit can also be used to give software full control over the clock for exceptional cases where software control is desired.

Table 9.2. Oscillator modes

| Bit Field                    | FORCEEN | DISONDEMAND |
|------------------------------|---------|-------------|
| On-Demand (normal operation) | 0       | 0           |
| Forced On                    | 1       | X           |
| Forced Off                   | 0       | 1           |

### 9.3.4 HFRCO Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description               |
|--------|---------------------|-------------|---------------------------|
| 0x000  | HFRCO_IPVERSION     | R           | IP Version ID             |
| 0x004  | HFRCO_CTRL          | RW          | Ctrl Register             |
| 0x008  | HFRCO_CAL           | RWH SYNC    | Calibration Register      |
| 0x00C  | HFRCO_STATUS        | RH          | Status Register           |
| 0x010  | HFRCO_IF            | RWH INTFLAG | Interrupt Flag Register   |
| 0x014  | HFRCO_IEN           | RW          | Interrupt Enable Register |
| 0x01C  | HFRCO_LOCK          | W           | Lock Register             |
| 0x1000 | HFRCO_IPVERSION_SET | R           | IP Version ID             |
| 0x1004 | HFRCO_CTRL_SET      | RW          | Ctrl Register             |
| 0x1008 | HFRCO_CAL_SET       | RWH SYNC    | Calibration Register      |
| 0x100C | HFRCO_STATUS_SET    | RH          | Status Register           |
| 0x1010 | HFRCO_IF_SET        | RWH INTFLAG | Interrupt Flag Register   |
| 0x1014 | HFRCO_IEN_SET       | RW          | Interrupt Enable Register |
| 0x101C | HFRCO_LOCK_SET      | W           | Lock Register             |
| 0x2000 | HFRCO_IPVERSION_CLR | R           | IP Version ID             |
| 0x2004 | HFRCO_CTRL_CLR      | RW          | Ctrl Register             |
| 0x2008 | HFRCO_CAL_CLR       | RWH SYNC    | Calibration Register      |
| 0x200C | HFRCO_STATUS_CLR    | RH          | Status Register           |
| 0x2010 | HFRCO_IF_CLR        | RWH INTFLAG | Interrupt Flag Register   |
| 0x2014 | HFRCO_IEN_CLR       | RW          | Interrupt Enable Register |
| 0x201C | HFRCO_LOCK_CLR      | W           | Lock Register             |
| 0x3000 | HFRCO_IPVERSION_TGL | R           | IP Version ID             |
| 0x3004 | HFRCO_CTRL_TGL      | RW          | Ctrl Register             |
| 0x3008 | HFRCO_CAL_TGL       | RWH SYNC    | Calibration Register      |
| 0x300C | HFRCO_STATUS_TGL    | RH          | Status Register           |
| 0x3010 | HFRCO_IF_TGL        | RWH INTFLAG | Interrupt Flag Register   |
| 0x3014 | HFRCO_IEN_TGL       | RW          | Interrupt Enable Register |
| 0x301C | HFRCO_LOCK_TGL      | W           | Lock Register             |

### 9.3.5 HFRCO Register Description

#### 9.3.5.1 HFRCO\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset  | 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 |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|-------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x2   | R      | <b>IP Version</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                   |

#### 9.3.5.2 HFRCO\_CTRL - Ctrl Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |    |   |     |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------|---|----|---|-----|---|---|
| Reset  | 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 |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |    |   |     |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | EM23ONDEMAND |   | RW |   | 0x0 | 2 |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DISONDEMAND  |   | RW |   | 0x0 | 1 |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | FORCEEN      |   | RW |   | 0x0 | 0 |   |

| Bit                                                                                                                                                                               | Name         | Reset                                                                                                                                                             | Access | Description              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:3                                                                                                                                                                              | Reserved     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2                                                                                                                                                                                 | EM23ONDEMAND | 0x0                                                                                                                                                               | RW     | <b>EM23 On-demand</b>    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Use this bit to prevent EM23 shutdown of the HFRCOEM23 low power domain (PD0C) upon EM23 entry. Set this bit to 1 if on-demand requests are supposed to be honored while in EM23. |              |                                                                                                                                                                   |        |                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                 | DISONDEMAND  | 0x0                                                                                                                                                               | RW     | <b>Disable On-demand</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Setting this bit disable HFRCO on-demand feature                                                                                                                                  |              |                                                                                                                                                                   |        |                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                 | FORCEEN      | 0x0                                                                                                                                                               | RW     | <b>Force Enable</b>      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Setting this bit force HFRCO enabled                                                                                                                                              |              |                                                                                                                                                                   |        |                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 9.3.5.3 HFRCO\_CAL - Calibration Register

| Offset | Bit Position |        |        |         |           |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    |        |   |   |   |   |
|--------|--------------|--------|--------|---------|-----------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----|--------|---|---|---|---|
| 0x008  | 31           | 30     | 29     | 28      | 27        | 26  | 25 | 24 | 23 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4      | 3 | 2 | 1 | 0 |
| Reset  |              | 0xA    |        |         |           |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    |        |   |   |   |   |
| Access | RW           |        | RW     | 0x2     | RW        | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RW | 0x7F   | 2 | 1 | 0 |   |
| Name   | IREFTC       | CMPSEL | CLKDIV | CMPBIAS | FREQRANGE | 0x3 | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    | TUNING |   |   |   |   |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                       |
|-------|------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | IREFTC     | 0xA   | RW     | <b>Tempco Trim on Comparator Current</b><br><br>Writing this field adjusts the temperature coefficient trim on comparator current.                                |
| 27:26 | CMPSEL     | 0x2   | RW     | <b>Comparator Load Select</b><br><br>Writing this field adjusts the active load for comparators.                                                                  |
| 25:24 | CLKDIV     | 0x0   | RW     | <b>Locally Divide HFRCO Clock Output</b><br><br>Writing this field configures the HFRCO clock output divider.                                                     |
|       | Value      | Mode  |        | Description                                                                                                                                                       |
|       | 0          | DIV1  |        | Divide by 1.                                                                                                                                                      |
|       | 1          | DIV2  |        | Divide by 2.                                                                                                                                                      |
|       | 2          | DIV4  |        | Divide by 4.                                                                                                                                                      |
| 23:21 | CMPBIAS    | 0x3   | RW     | <b>Comparator Bias Current</b><br><br>Writing this field adjusts the HFRCO comparator bias current.                                                               |
| 20:16 | FREQRANGE  | 0x8   | RW     | <b>Frequency Range</b><br><br>Writing this field adjusts the HFRCO frequency range.                                                                               |
| 15    | LDOHP      | 0x1   | RW     | <b>LDO High Power Mode</b><br><br>Settings this bit puts the HFRCO LDO in high power mode.                                                                        |
| 14    | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 13:8  | FINETUNING | 0x1F  | RW     | <b>Fine Tuning Value</b><br><br>Writing this field adjusts the HFRCO fine tuning value. Higher value means lower frequency.                                       |
| 7     | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 6:0   | TUNING     | 0x7F  | RW     | <b>Tuning Value</b><br><br>Writing this field adjusts the HFRCO tuning value. Higher value means lower frequency.                                                 |

## 9.3.5.4 HFRCO\_STATUS - Status Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x00C  | 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 |  |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Name   | LOCK         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ENS |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit   | Name     | Reset                                                                                                                                                                             | Access | Description                    |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------|
| 31    | LOCK     | 0x0                                                                                                                                                                               | R      | <b>Lock Status</b>             |
|       |          | If set, all HFRCO lockable registers are locked.                                                                                                                                  |        |                                |
|       | Value    | Mode                                                                                                                                                                              |        | Description                    |
|       | 0        | UNLOCKED                                                                                                                                                                          |        | HFRCO is unlocked              |
|       | 1        | LOCKED                                                                                                                                                                            |        | HFRCO is locked                |
| 30:17 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                |
| 16    | ENS      | 0x0                                                                                                                                                                               | R      | <b>Enable Status</b>           |
|       |          | HFRCO is enabled.                                                                                                                                                                 |        |                                |
| 15:3  | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                |
| 2     | SYNCBUSY | 0x0                                                                                                                                                                               | R      | <b>Synchronization Busy</b>    |
|       |          | This bit is set when there is an ongoing synchronization of CAL register bitfields.                                                                                               |        |                                |
| 1     | FREQBSY  | 0x0                                                                                                                                                                               | R      | <b>Frequency Updating Busy</b> |
|       |          | HFRCO is busy updating frequency.                                                                                                                                                 |        |                                |
| 0     | RDY      | 0x0                                                                                                                                                                               | R      | <b>Ready</b>                   |
|       |          | HFRCO is enabled and start-up time has exceeded.                                                                                                                                  |        |                                |

**9.3.5.5 HFRCO\_IF - Interrupt Flag Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|----|-----|---|---|
| 0x010         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RDY | RW | 0x0 | 0 |   |

| Bit  | Name            | Reset                                                                                                                                                                             | Access | Description                                                                          |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------|
| 31:1 | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                      |
| 0    | <b>RDY</b>      | 0x0                                                                                                                                                                               | RW     | <b>Ready Interrupt Flag</b><br><br>Set when HFRCO is ready (start-up time exceeded). |

**9.3.5.6 HFRCO\_IEN - Interrupt Enable Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|----|-----|---|---|
| 0x014         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |     |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RDY | RW | 0x0 | 0 |   |

| Bit  | Name            | Reset                                                                                                                                                                             | Access | Description                                                         |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------|
| 31:1 | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                     |
| 0    | <b>RDY</b>      | 0x0                                                                                                                                                                               | RW     | <b>RDY Interrupt Enable</b><br><br>Enable/disable the RDY interrupt |

### **9.3.5.7 HFRCO\_LOCK - Lock Register**

| Bit                                                                                                         | Name     | Reset  | Access      | Description                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------|----------|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                       | Reserved |        |             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                                                        | LOCKKEY  | 0x8195 | W           | <b>Lock Key</b>                                                                                                                                                                   |
| Write any other value than the unlock code to lock registers from editing. Write the unlock code to unlock. |          |        |             |                                                                                                                                                                                   |
| Value                                                                                                       | Mode     |        | Description |                                                                                                                                                                                   |
| 33173                                                                                                       | UNLOCK   |        | Unlock code |                                                                                                                                                                                   |

## 9.4 DPLL - Digital Phased Locked Loop

### 9.4.1 Introduction

The Digital Phase-Locked Loop (DPLL) uses a reference clock to generate a desired clock frequency at a specified ratio to the reference clock.

## 9.4.2 Features

- Frequency Lock Mode
  - Phase-Lock Mode
  - Output frequency =  $F_{REF} \cdot (N+1)/(M+1)$ , where N and M are 12-bit values
  - Very fast lock time
  - Very fast transient tracking
  - Low output jitter
  - Lock detection with an interrupt
  - Lock fail detection with interrupts

### 9.4.3 Functional Description

#### 9.4.3.1 Enabling and Disabling

The DPLL can be enabled and disabled by software via the DPLL\_EN register. Before enabling DPLL, software should:

1. Select reference clock by setting the CLKSEL field in CMU\_DPLLREFCLKCTRL.
2. The CMU should not be running from the HFRCO. If necessary, the CMU should switch to the FSRCO until after the DPLL has locked to avoid over-clocking due to overshoot. If necessary, select FSRCO or HFXO in the CMU\_SYSCLKCTRL register CLKSEL field.
3. Configure the DPLL.
4. Make certain that the ENS bit in DPLL\_STATUS is low.

The DPLL is disabled automatically when entering EM2, EM3, or EM4. Note that disabling the DPLL will not automatically turn off the reference clock. The CLKSEF field in CMU\_DPLLREFCLKCTRL must be set to DISABLED before entering EM2 or the selected REFCLK may continue to run in EM2.

#### 9.4.3.2 Lock Modes

The DPLL provides two lock modes, referred to as frequency-lock loop mode (FREQLL) and phase-lock loop mode (PHASELL). FREQLL mode keeps the DCO frequency-locked to the reference clock, which means the DCO frequency will be accurate. However, the phase error can accumulate over time and cause a non-zero average frequency error. FREQLL mode also provides better jitter and transient performance. PHASELL mode keeps the DCO phase-locked to the reference clock, which means the phase error does not accumulate over time, which makes the average frequency error zero. FREQLL mode is usually sufficient unless specific phase requirement exists.

#### 9.4.3.3 Configurations

The formula for the DPLL output frequency is  $F_{REF} \times (N+1) / (M+1)$ . The user should calculate N and M in DPLL\_CFG1 to achieve the target frequency. Note that with a larger value of N, the DCO lock time would increase and DCO jitter would decrease. Both effects are approximately linear. This relationship can be used to select N for a given application to strike a compromise between lock time and output jitter. For example if an ratio of 3 is desired, the DPLL could be configured as {N=599, M=199} for fast lock time but high jitter, or as {N=2999, M=999} for lower jitter but longer lock time.

**Note:** All configuration settings should be done before enabling the DPLL. They should not be changed when DPLL is running. The final tuning values can be read back from TUNING and FINETUNING in HFRCO\_CAL, after DPLL is disabled and DPLLENS in DPLL\_STATUS is low.

#### 9.4.3.4 Lock Detection

The DPLL has 3 different types of output events: ready, lock fail due to period underflow, and lock fail due to period overflow. Each of the events has its own interrupt flag. DPLLRDY is set when DPLL successfully locks to the reference clock based on the software configuration. DPLLOCKFAILLOW is set when the DPLL fails to lock because the period lower boundary is hit. DPLLOCKFAILHIGH is set when the DPLL fails to lock because the period upper boundary is hit. If the interrupt flags are set and the corresponding interrupt enable bits in DPLL\_IEN are set, the DPLL will request an interrupt. Based on different interrupt events, software should take different actions:

- If the DPLLRDY interrupt is received first, it means target clock is ready and it is safe to switch to use DCO's output.
- If the DPLLOCKFAILLOW interrupt is received first, it indicates the RANGE in HFRCO\_CAL is too small. Software should disable the DPLL and write a larger value to RANGE, then enable the DPLL again to lock.
- If the DPLLOCKFAILHIGH interrupt is received first, it indicates the RANGE in HFRCO\_CAL is too large. Software should disable DPLL and write a smaller value to RANGE, then enable DPLL again to lock.
- If the DPLLRDY interrupt is received first and then DPLLOCKFAILLOW or DPLLOCKFAILHIGH is received later, it means reference clock drifted over 1% and the DPLL has lost its locked status.
  - If AUTORECOVER in DPLL\_CFG is not set, software should disable the DPLL and enable DPLL again to lock.
  - If AUTORECOVER in DPLL\_CFG is set, hardware will re-lock automatically. When the target frequency is near the boundary of a range, the drift may cause underflow or overflow. In this case the fail interrupt will still be received. Software should disable the DPLL and modify RANGE in HFRCO\_CAL in corresponding direction, depending on whether the DPLLOCKFAILLOW or DPLLOCKFAILHIGH bit is set. Then enable DPLL again to lock.

#### 9.4.4 DPLL Register Map

The offset register address is relative to the registers base address.

| Offset | Name               | Type        | Description      |
|--------|--------------------|-------------|------------------|
| 0x000  | DPLL_IPVERSION     | R           | IP Version       |
| 0x004  | DPLL_EN            | RW ENABLE   | Enable           |
| 0x008  | DPLL_CFG           | RW CONFIG   | Config           |
| 0x00C  | DPLL_CFG1          | RW CONFIG   | Config1          |
| 0x010  | DPLL_IF            | RWH INTFLAG | Interrupt Flag   |
| 0x014  | DPLL_IEN           | RW          | Interrupt Enable |
| 0x018  | DPLL_STATUS        | RH          | Status           |
| 0x024  | DPLL_LOCK          | W           | Lock             |
| 0x1000 | DPLL_IPVERSION_SET | R           | IP Version       |
| 0x1004 | DPLL_EN_SET        | RW ENABLE   | Enable           |
| 0x1008 | DPLL_CFG_SET       | RW CONFIG   | Config           |
| 0x100C | DPLL_CFG1_SET      | RW CONFIG   | Config1          |
| 0x1010 | DPLL_IF_SET        | RWH INTFLAG | Interrupt Flag   |
| 0x1014 | DPLL_IEN_SET       | RW          | Interrupt Enable |
| 0x1018 | DPLL_STATUS_SET    | RH          | Status           |
| 0x1024 | DPLL_LOCK_SET      | W           | Lock             |
| 0x2000 | DPLL_IPVERSION_CLR | R           | IP Version       |
| 0x2004 | DPLL_EN_CLR        | RW ENABLE   | Enable           |
| 0x2008 | DPLL_CFG_CLR       | RW CONFIG   | Config           |
| 0x200C | DPLL_CFG1_CLR      | RW CONFIG   | Config1          |
| 0x2010 | DPLL_IF_CLR        | RWH INTFLAG | Interrupt Flag   |
| 0x2014 | DPLL_IEN_CLR       | RW          | Interrupt Enable |
| 0x2018 | DPLL_STATUS_CLR    | RH          | Status           |
| 0x2024 | DPLL_LOCK_CLR      | W           | Lock             |
| 0x3000 | DPLL_IPVERSION_TGL | R           | IP Version       |
| 0x3004 | DPLL_EN_TGL        | RW ENABLE   | Enable           |
| 0x3008 | DPLL_CFG_TGL       | RW CONFIG   | Config           |
| 0x300C | DPLL_CFG1_TGL      | RW CONFIG   | Config1          |
| 0x3010 | DPLL_IF_TGL        | RWH INTFLAG | Interrupt Flag   |
| 0x3014 | DPLL_IEN_TGL       | RW          | Interrupt Enable |
| 0x3018 | DPLL_STATUS_TGL    | RH          | Status           |
| 0x3024 | DPLL_LOCK_TGL      | W           | Lock             |

## 9.4.5 DPLL Register Description

### 9.4.5.1 DPLL\_IPVERSION - IP Version

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x1          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|----------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x1   | R      | <b>IP Version ID</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                      |

### 9.4.5.2 DPLL\_EN - Enable

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                   |             |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------------|-------------|--|--|
| 0x004  | 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 | DISABLING R 0x0 1 | EN RW 0x0 0 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                   |             |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                   |             |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                   |             |  |  |

| Bit                                                                                                                                                                                                                   | Name      | Reset                                                                                                                                                             | Access | Description                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:2                                                                                                                                                                                                                  | Reserved  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                                                     | DISABLING | 0x0                                                                                                                                                               | R      | <b>Disablement Busy Status</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| When EN is cleared, DISABLING status is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS and FIFO |           |                                                                                                                                                                   |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                     | EN        | 0x0                                                                                                                                                               | RW     | <b>Module Enable</b>           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| The ENABLE bit enables the module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit.                      |           |                                                                                                                                                                   |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 9.4.5.3 DPLL\_CFG - Config

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |        |             |         |      |     |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|-------------|---------|------|-----|---|---|
| 0x008  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0    | 0x0         | 0x0     | 0x0  | 0x0 |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW     | RW          | RW      | RW   | RW  |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DITHEN | AUTORECOVER | EDGESEL | MODE |     |   |   |

| Bit   | Name        | Reset               | Access | Description                                                                                                                                                                       |
|-------|-------------|---------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7  | Reserved    |                     |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 6     | DITHEN      | 0x0                 | RW     | <b>Dither Enable Control</b><br><br>Set to enable dither function                                                                                                                 |
| 5:3   | Reserved    |                     |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2     | AUTORECOVER | 0x0                 | RW     | <b>Automatic Recovery Control</b><br><br>Set to enable automatic recovery function                                                                                                |
| 1     | EDGESEL     | 0x0                 | RW     | <b>Reference Edge Select</b><br><br>This bit controls which edge of reference is detected                                                                                         |
| 0     | MODE        | 0x0                 | RW     | <b>Operating Mode Control</b><br><br>This bit controls which mode DPLL is operating when enabled                                                                                  |
| <hr/> |             |                     |        |                                                                                                                                                                                   |
| Value | Mode        | Description         |        |                                                                                                                                                                                   |
| 0     | FLL         | Frequency Lock Mode |        |                                                                                                                                                                                   |
| 1     | PLL         | Phase Lock Mode     |        |                                                                                                                                                                                   |

**9.4.5.4 DPLL\_CFG1 - Config1**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|
| 0x00C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    | RW  |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW  |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    | N   |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | M |     |   |   |

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:16 | N               | 0x0   | RW     | <b>Factor N</b><br><br>The locked DCO frequency is given by: $F_{DCO} = F_{ref} * (N + 1)/(M+1)$ . N is required to be larger than 300.                                           |
| 15:12 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:0  | M               | 0x0   | RW     | <b>Factor M</b><br><br>The locked DCO frequency is given by: $F_{DCO} = F_{ref} * (N + 1)/(M+1)$ . M can be any value.                                                            |

**9.4.5.5 DPLL\_IF - Interrupt Flag**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |              |     |     |   |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------------|-----|-----|---|--|
| 0x010         | 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 |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0          | 2   |     |   |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW           | 0x0 | 1   |   |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | LOCKFAILHIGH | RW  | 0x0 | 2 |  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | LOCKFAILLOW  | RW  | 0x0 | 1 |  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | LOCK         | RW  | 0x0 | 0 |  |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2    | LOCKFAILHIGH    | 0x0   | RW     | <b>Lock Failure High Interrupt Flag</b><br><br>Set when DPLL fail to lock because of period overflow.                                                                             |
| 1    | LOCKFAILLOW     | 0x0   | RW     | <b>Lock Failure Low Interrupt Flag</b><br><br>Set when DPLL fail to lock because of period underflow.                                                                             |
| 0    | LOCK            | 0x0   | RW     | <b>Lock Interrupt Flag</b><br><br>Set when DPLL achieve the lock.                                                                                                                 |

#### 9.4.5.6 DPLL\_IEN - Interrupt Enable

| Bit  | Name                          | Reset | Access | Description                                                                                                                                                                       |
|------|-------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2    | LOCKFAILHIGH                  | 0x0   | RW     | <b>LOCKFAILHIGH Interrupt Enable</b>                                                                                                                                              |
|      | LOCKFAILHIGH Interrupt Enable |       |        |                                                                                                                                                                                   |
| 1    | LOCKFAILLOW                   | 0x0   | RW     | <b>LOCKFAILLOW Interrupe Enable</b>                                                                                                                                               |
|      | LOCKFAILLOW Interrupe Enable  |       |        |                                                                                                                                                                                   |
| 0    | LOCK                          | 0x0   | RW     | <b>LOCK interrupt Enable</b>                                                                                                                                                      |
|      | LOCK interrupt Enable         |       |        |                                                                                                                                                                                   |

**9.4.5.7 DPLL\_STATUS - Status**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|-----|
| 0x018         | 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   |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 | 0   |     |
| <b>Access</b> | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | R   | R   |     |
| <b>Name</b>   | LOCK         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     | ENS | RDY |

| Bit                                                | Name     | Reset                                                                                                                                                                      | Access | Description          |
|----------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------|
| 31                                                 | LOCK     | 0x0                                                                                                                                                                        | R      | <b>Lock Status</b>   |
| Indicates the current status of configuration lock |          |                                                                                                                                                                            |        |                      |
|                                                    | Value    | Mode                                                                                                                                                                       |        | Description          |
|                                                    | 0        | UNLOCKED                                                                                                                                                                   |        | DPLL is unlocked     |
|                                                    | 1        | LOCKED                                                                                                                                                                     |        | DPLL is locked       |
| 30:2                                               | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                      |
| 1                                                  | ENS      | 0x0                                                                                                                                                                        | R      | <b>Enable Status</b> |
| DPLL is enabled.                                   |          |                                                                                                                                                                            |        |                      |
| 0                                                  | RDY      | 0x0                                                                                                                                                                        | R      | <b>Ready Status</b>  |
| DPLL is enabled and locked.                        |          |                                                                                                                                                                            |        |                      |

**9.4.5.8 DPLL\_LOCK - Lock**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x024         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x7102  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | W       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LOCKKEY |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                         | Name     | Reset                                                                                                                                                                      | Access | Description     |
|-------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------|
| 31:16                                                                                                       | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                 |
| 15:0                                                                                                        | LOCKKEY  | 0x7102                                                                                                                                                                     | W      | <b>Lock Key</b> |
| Write any other value than the unlock code to lock registers from editing. Write the unlock code to unlock. |          |                                                                                                                                                                            |        |                 |
|                                                                                                             | Value    | Mode                                                                                                                                                                       |        | Description     |
|                                                                                                             | 28930    | UNLOCK                                                                                                                                                                     |        | Unlock code     |

## 9.5 LFXO - Low-Frequency Crystal Oscillator

### 9.5.1 Introduction

The Low Frequency Crystal Oscillator (LFXO) uses an external 32.768 kHz crystal to provide an accurate low-frequency clock. The module is available in all energy modes, except EM3. The main interaction is with the CMU through the clock requesting mechanism.

### 9.5.2 Features

High-level features.

- Crystal calibration
- Functional in all energy modes, except EM3
- Failure detection and EM4WU
- External CMOS mode
- Edge interrupts and EM2WU
- On-demand oscillator enabling

### 9.5.3 Functional Description

#### 9.5.3.1 Modes

The LFXO can be used in three different modes. The mode can be programmed by setting MODE bit field in the LFXO\_CFG register. If MODE is set to XTAL, the LFXO is programmed to operate in crystal mode and a 32.768 kHz crystal oscillator should be connected to LF crystal pads, LFXTAL\_I and LFXTAL\_O (see the device data sheet for details). If MODE is set to BUFECLK, the LFXO is programmed to operate in external sine mode and the sine wave should be supplied to LFXTAL\_I pin. If MODE is set to DIGECLK, LFXO is programmed to operate in external CMOS mode and the external 32.768 kHz clock should be provided on LFXTAL\_I pin. See the register descriptions for more details.

#### 9.5.3.2 Enabling

There are two ways to turn on the LFXO clock. One is to turn it on in FORCEON mode by setting FORCEEN bit to 1 in LFXO\_CTRL register. Another is to keep it ready to be turned on in ONDEMAND mode by setting FORCEEN bit to 0 and DISONDEMAND bit to 0 in LFXO\_CTRL register. This means that the oscillator will be off unless its clock requested. When a peripheral requests the clock, hardware will automatically enable the LFXO without any software intervention. The oscillator will remain on as long as the peripheral requests it. DISONDEMAND setting does not have any impact when FORCEEN set to 1. LFXO is in FORCEOFF mode when FORCEEN set to 0 and DISONDEMAND set to 1. In FORCEOFF mode all requests are blocked and LFXO will not generate the clock. The LFXO clock is available in all energy modes, except EM3.

#### 9.5.3.3 Clock Qualification

Once the LFXO is enabled, the clock should not be used until it has had time to stabilize. Therefore, a number of cycles are required to qualify the clock. Before the clock is qualified, no clock requesters will receive the LFXO clock. The number of cycles used to qualify the clock can be programmed by setting the TIMEOUT bit field in the LFXO\_CFG register. The TIMEOUT default value is set to 32,728 cycles, which is much more than necessary for stabilization. The stabilization time required will depend on the particular crystal, oscillator settings, and frequency accuracy requirements. A value of 4096 clocks is generally recommended for most applications. A low timeout of 2 cycles may be used in DIGECLK mode in order to filter out the first glitch from the pad. The 2 clock cycle timeout should not be used with crystals. There are two status bits and one interrupt associated with enabling the oscillator and qualifying its clock. Once the oscillator gets enabled the ENS bit in LFXO\_STATUS register will be set high. Note that due to the nature of on demand clocking, the oscillator can be enabled anytime, so if software reads ENS low it is not safe to assume that ENS stays low during the next instruction. It is only safe to assume that oscillator is OFF at the time ENS is being read. Similarly, if software reads ENS high it is not safe to assume that ENS stays high during the next instruction. Once the clock is qualified, the RDY status is set high in the LFXO\_STATUS register. The same uncertainties also apply to the RDY bit. However, software can wait for RDY bit to go high to detect that LFXO clock is qualified. Or it can enable the interrupt with RDYIEN in LFXO\_IEN register and receive RDYIF interrupt available in LFXO\_IF register. RDYIF also acts as EM2 wakeup source if RDYIEN set high. If put into FORCEON mode, the LFXO will start the qualification and once qualified it will gate off the clock but immediately start with no qualification upon receiving a request. If in ONDEMAND mode, the LFXO starts the qualification every time it is switched from off to on due to clock requests. The qualification can take up to 32k cycles. Note that only enabling RDY interrupt does not act as a clock request.

#### 9.5.3.4 Edge Detection Interrupts

There is a possibility for software to detect rising or falling edges of the LFXO clock. The edge detection is enabled if any of POSEDGEIEN and NEGEDGEIEN is set to 1. The corresponding flags are available in POSEDGEIF and NEGEDGEIF. If none of the interrupts are enabled, the edge detection is disabled and POSEDGEIF and NEGEDGEIF hold their last value until cleared or set by software. Disabling the edge detection is only allowed on NEGEDGEIF. Both flags act as EM2 wakeup sources if the corresponding IEN is set high.

#### 9.5.3.5 Clock Failure

In case the oscillator or crystal stops or does not output clock when expected, a failure interrupt can be raised. The failure occurs if fewer than 3 LFXO clock positive edges happen during one 1ms. The failure detection is enabled by setting FAILDETEN to 1 in LFXO\_CTRL register. This bit acts as a clock requester. Once enabled, failure detection status can be checked by reading FAILIF in LFXO\_IF register. If FAILIEN is set high, failure will generate both interrupt and EM2 wakeup. Failure detection is also implemented as EM4 wakeup source. To wakeup from EM4 on LFXO failure detection, set FAILDETEM4WUEN high in LFXO\_CTRL.

#### 9.5.3.6 Automatic Gain Control

AGC and HIGHAMPL in LFXO\_CFG are settings applied to the LFXO oscillator. Both settings provide higher crystal oscillation amplitude. This will improve duty cycle in the output clock and give lower sensitivity to noise, but at the cost of higher current consumption. The AGC bit is used to enable the Automatic Gain Control module that adjusts the amplitude of the oscillations. It is enabled by default. When disabled, the LFXO will run at the start-up current and the crystal will oscillate rail-to-rail or limited by the start-up current. The HIGHAMPL bit will have no effect when AGC is disabled. When AGC is enabled setting the HIGHAMPL bit will give about 70% higher crystal oscillation amplitude.

#### 9.5.3.7 Force Off

It is not allowed to write to LFXO\_CFG unless LFXO is in FORCEOFF mode. If this guideline is violated, the write access is blocked and a bus fault is generated. Writing to CFG registers has no effect in DIGEXTCLK mode. Note: when putting the oscillators to FORCEOFF mode, wait for ENS status to go low for the oscillator to completely shut off. Once the oscillator is forced off, it is safe to write to the LFXO\_CFG register.

#### 9.5.3.8 Register Synchronization

While the CFG registers are static LFXO configuration, LFXO\_CAL register has GAIN and CAPTUNE bit fields which can be written to while the oscillator is running. This is used to calibrate the LFXO clock. These registers are allowed to be written only if CALBSY in LFXO\_SYNCBUSY register is low. If this guideline is violated, the write access is blocked and a bus fault is generated. CALBSY is guaranteed to be low in FORCEOFF mode. When exiting FORCEOFF mode, CALBSY will go high and stay high until the initial internal synchronization is done. CALBSY is also guaranteed to be low in DIGEXTCLK mode since writing to CAL register has no effect in DIGEXTCLK mode. CAPTUNE is allowed to be incremented or decremented by one LSB when not in FORCEOFF mode. Note that CAPTUNE tunes the internal capacitors connected to LFXTAL\_I and LFXTAL\_O pads (see Register map for more details). By programming GAIN bit field it is possible to optimize start-up time and power consumption for a given crystal. Internal capacitances are not provided on all chips (see the device data sheet for more details).

#### 9.5.3.9 Register Lock

See the LFXO\_LOCK register on how to lock certain registers. Registers LFXO\_CTRL, LFXO\_CFG, and LFXO\_CAL are lockable. The LOCK bit in LFXO\_STATUS register is available to check whether the registers are locked. If locked, all updates to these registers are blocked and bus faults are issued.

#### 9.5.3.10 Reset Behavior

Upon reset, the LFXO is configured for the safe crystal start-up. The TIMEOUT is set to 32k cycles, The MODE is set to XTAL and the reset state is FORCEOFF. In order to minimize the start-up time and power consumption for a given crystal, it is possible to adjust the start-up gain in the oscillator by programming GAIN in LFXO\_CAL. All controls are retained in EM4, except LFXO\_IEN register which is reset after EM4 wakeup.

#### 9.5.4 LFXO Register Map

The offset register address is relative to the registers base address.

| Offset | Name               | Type        | Description                 |
|--------|--------------------|-------------|-----------------------------|
| 0x000  | LFXO_IPVERSION     | R           | LFXO IP Version             |
| 0x004  | LFXO_CTRL          | RW          | LFXO Control Register       |
| 0x008  | LFXO_CFG           | RW          | LFXO Configuration Register |
| 0x010  | LFXO_STATUS        | RH          | LFXO Status Register        |
| 0x014  | LFXO_CAL           | RW LFSYNC   | LFXO Calibration Register   |
| 0x018  | LFXO_IF            | RWH INTFLAG | Interrupt Flag Register     |
| 0x01C  | LFXO_IEN           | RW          | Interrupt Enable Register   |
| 0x020  | LFXO_SYNCBUSY      | RH          | LFXO Sync Busy Register     |
| 0x024  | LFXO_LOCK          | W           | Configuration Lock Register |
| 0x1000 | LFXO_IPVERSION_SET | R           | LFXO IP Version             |
| 0x1004 | LFXO_CTRL_SET      | RW          | LFXO Control Register       |
| 0x1008 | LFXO_CFG_SET       | RW          | LFXO Configuration Register |
| 0x1010 | LFXO_STATUS_SET    | RH          | LFXO Status Register        |
| 0x1014 | LFXO_CAL_SET       | RW LFSYNC   | LFXO Calibration Register   |
| 0x1018 | LFXO_IF_SET        | RWH INTFLAG | Interrupt Flag Register     |
| 0x101C | LFXO_IEN_SET       | RW          | Interrupt Enable Register   |
| 0x1020 | LFXO_SYNCBUSY_SET  | RH          | LFXO Sync Busy Register     |
| 0x1024 | LFXO_LOCK_SET      | W           | Configuration Lock Register |
| 0x2000 | LFXO_IPVERSION_CLR | R           | LFXO IP Version             |
| 0x2004 | LFXO_CTRL_CLR      | RW          | LFXO Control Register       |
| 0x2008 | LFXO_CFG_CLR       | RW          | LFXO Configuration Register |
| 0x2010 | LFXO_STATUS_CLR    | RH          | LFXO Status Register        |
| 0x2014 | LFXO_CAL_CLR       | RW LFSYNC   | LFXO Calibration Register   |
| 0x2018 | LFXO_IF_CLR        | RWH INTFLAG | Interrupt Flag Register     |
| 0x201C | LFXO_IEN_CLR       | RW          | Interrupt Enable Register   |
| 0x2020 | LFXO_SYNCBUSY_CLR  | RH          | LFXO Sync Busy Register     |
| 0x2024 | LFXO_LOCK_CLR      | W           | Configuration Lock Register |
| 0x3000 | LFXO_IPVERSION_TGL | R           | LFXO IP Version             |
| 0x3004 | LFXO_CTRL_TGL      | RW          | LFXO Control Register       |
| 0x3008 | LFXO_CFG_TGL       | RW          | LFXO Configuration Register |
| 0x3010 | LFXO_STATUS_TGL    | RH          | LFXO Status Register        |
| 0x3014 | LFXO_CAL_TGL       | RW LFSYNC   | LFXO Calibration Register   |
| 0x3018 | LFXO_IF_TGL        | RWH INTFLAG | Interrupt Flag Register     |
| 0x301C | LFXO_IEN_TGL       | RW          | Interrupt Enable Register   |
| 0x3020 | LFXO_SYNCBUSY_TGL  | RH          | LFXO Sync Busy Register     |

| Offset | Name          | Type | Description                 |
|--------|---------------|------|-----------------------------|
| 0x3024 | LFXO_LOCK_TGL | W    | Configuration Lock Register |

### 9.5.5 LFXO Register Description

#### 9.5.5.1 LFXO\_IPVERSION - LFXO IP Version

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|        | 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 |
| Reset  | 0x1          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                               |
|------|-----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | IPVERSION | 0x1   | R      | <b>IP Version ID</b><br><br>The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |

## 9.5.5.2 LFXO\_CTRL - LFXO Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 0x004  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |

| Bit  | Name           | Reset | Access | Description                                                                                                                                                                       |
|------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | FAILDETEM4WUEN | 0x0   | RW     | <b>LFXO Failure Detection EM4WU Enable</b><br><br>Set this bit to enable EM4 exit on the oscillator failure detection.                                                            |
| 4    | FAILDETEN      | 0x0   | RW     | <b>LFXO Failure Detection Enable</b><br><br>Set this bit to enable the oscillator failure detection feature. Note that setting this bit will enable the oscillator core.          |
| 3:2  | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | DISONDEMAND    | 0x1   | RW     | <b>LFXO Disable On-demand requests</b><br><br>Set this bit to disable On-demand requests.                                                                                         |
| 0    | FORCEEN        | 0x0   | RW     | <b>LFXO Force Enable</b><br><br>Set this bit to enable the oscillator core. The oscillator core is enabled regardless of On-demand requests.                                      |

## 9.5.5.3 LFXO\_CFG - LFXO Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |          |     |     |     |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|----------|-----|-----|-----|-----|---|
| 0x008  | 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 |
| Reset  | 0x7          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  | 0x0      |     |     |     | 0x1 |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   | RW       | RW  | RW  | RW  |     |   |
| Name   | TIMEOUT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MODE | HIGHAMPL | AGC | AGC | AGC |     |   |

| Bit   | Name                   | Reset                                   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------------------|-----------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | Reserved               |                                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                      |
| 10:8  | TIMEOUT                | 0x7                                     | RW     | <b>LFXO Start-up Delay</b>                                                                                                                                                                                                                                                                                                                                                                             |
|       |                        | Configures the start-up delay for LFXO. |        |                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | Value                  | Mode                                    |        | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 0                      | CYCLES2                                 |        | Timeout period of 2 cycles                                                                                                                                                                                                                                                                                                                                                                             |
|       | 1                      | CYCLES256                               |        | Timeout period of 256 cycles                                                                                                                                                                                                                                                                                                                                                                           |
|       | 2                      | CYCLES1K                                |        | Timeout period of 1024 cycles                                                                                                                                                                                                                                                                                                                                                                          |
|       | 3                      | CYCLES2K                                |        | Timeout period of 2048 cycles                                                                                                                                                                                                                                                                                                                                                                          |
|       | 4                      | CYCLES4K                                |        | Timeout period of 4096 cycles                                                                                                                                                                                                                                                                                                                                                                          |
|       | 5                      | CYCLES8K                                |        | Timeout period of 8192 cycles                                                                                                                                                                                                                                                                                                                                                                          |
|       | 6                      | CYCLES16K                               |        | Timeout period of 16384 cycles                                                                                                                                                                                                                                                                                                                                                                         |
|       | 7                      | CYCLES32K                               |        | Timeout period of 32768 cycles                                                                                                                                                                                                                                                                                                                                                                         |
| 7:6   | Reserved               |                                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                      |
| 5:4   | MODE                   | 0x0                                     | RW     | <b>LFXO Mode</b>                                                                                                                                                                                                                                                                                                                                                                                       |
|       | Selects the LFXO mode. |                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | Value                  | Mode                                    |        | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 0                      | XTAL                                    |        | A 32768Hz crystal should be connected to the LF crystal pads. Voltage must not exceed VDDIO.                                                                                                                                                                                                                                                                                                           |
|       | 1                      | BUFEXTCLK                               |        | An external sine source with minimum amplitude 100mv (zero-to-peak) and maximum amplitude 500mV (zero-to-peak) should be connected in series with LFXTAL_I pin. Minimum voltage should be larger than ground and maximum voltage smaller than VDDIO. The sine source does not need to be ac coupled externally as it is ac couples inside LFXO. LFXTAL_O is free to be used as a general purpose GPIO. |
|       | 2                      | DIGEXTCLK                               |        | An external 32KHz CMOS clock should be provided on LFXTAL_I. LFXTAL_O is free to be used as a general purpose GPIO.                                                                                                                                                                                                                                                                                    |

| Bit | Name            | Reset | Access | Description                                                                                                                                                                       |
|-----|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1   | HIGHAMPL        | 0x0   | RW     | <b>LFXO High Amplitude Enable</b><br><br>Set this bit to enable high XTAL oscillation amplitude.                                                                                  |
| 0   | AGC             | 0x1   | RW     | <b>LFXO AGC Enable</b><br><br>Set this bit to enable automatic gain control which limits XTAL oscillation amplitude.                                                              |

#### **9.5.5.4 LFXO\_STATUS - LFXO Status Register**

| Bit                                             | Name     | Reset                                                                                                                                                                             | Access | Description                            |
|-------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------|
| 31                                              | LOCK     | 0x0                                                                                                                                                                               | R      | <b>LFXO Locked Status</b>              |
| If set, all LFXO lockable registers are locked. |          |                                                                                                                                                                                   |        |                                        |
|                                                 | Value    | Mode                                                                                                                                                                              |        | Description                            |
|                                                 | 0        | UNLOCKED                                                                                                                                                                          |        | LFXO lockable registers are not locked |
|                                                 | 1        | LOCKED                                                                                                                                                                            |        | LFXO lockable registers are locked     |
| 30:17                                           | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                        |
| 16                                              | ENS      | 0x0                                                                                                                                                                               | R      | <b>LFXO Enable Status</b>              |
| LFXO is enabled.                                |          |                                                                                                                                                                                   |        |                                        |
| 15:1                                            | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                        |
| 0                                               | RDY      | 0x0                                                                                                                                                                               | R      | <b>LFXO Ready Status</b>               |
| LFXO is enabled and start-up time has exceeded. |          |                                                                                                                                                                                   |        |                                        |

**9.5.5.5 LFXO\_CAL - LFXO Calibration Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |  |  |         |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|--|--|---------|
| 0x014  | 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 |  |  |         |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |  |  |         |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |  |  |         |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | GAIN |   |   |   |   |   |   |  |  | CAPTUNE |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                        |
| 9:8   | GAIN     | 0x1   | RW     | <b>LFXO Startup Gain</b><br><br>The optimal value depends on the chosen crystal.                                                                                                                                                                                                                                                                                                                                                                                         |
| 7     | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                        |
| 6:0   | CAPTUNE  | 0x0   | RW     | <b>Internal Capacitance Tuning</b><br><br>Program internal load capacitance connected between X_N pin and ground and X_P pin and ground. The bus affects tuning capacitances on both pins symmetrically. CAPTUNE value must not exceed 0x4F. When updating CAPTUNE, its value must only be incremented or decremented by 1 which provides a tuning step of 0.25pF. The maximum value is estimated to be 20pF. Please refer to the device Datasheet for more information. |

**9.5.5.6 LFXO\_IF - Interrupt Flag Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|
| 0x018         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |

| Bit  | Name     | Reset                                                                                                                                                                      | Access | Description                                                                                                                   |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                               |
| 3    | FAIL     | 0x0                                                                                                                                                                        | RW     | <b>LFXO Failure Interrupt Flag</b><br><br>Set when LFXO failure is detected. Write 1 to clear the interrupt flag.             |
| 2    | NEGEDGE  | 0x0                                                                                                                                                                        | RW     | <b>Falling Edge Interrupt Flag</b><br><br>Triggers on every negative edge of the LFXO clock.                                  |
| 1    | POSEDGE  | 0x0                                                                                                                                                                        | RW     | <b>Rising Edge Interrupt Flag</b><br><br>Triggers on every positive edge of the LFXO clock.                                   |
| 0    | RDY      | 0x0                                                                                                                                                                        | RW     | <b>LFXO Ready Interrupt Flag</b><br><br>Set when LFXO is ready (start-up time exceeded). Write 1 to clear the interrupt flag. |

**9.5.5.7 LFXO\_IEN - Interrupt Enable Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |      |         |         |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|------|---------|---------|-----|
| 0x01C         | 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 |      |         |         |     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0  | 0       |         |     |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW   | RW      |         |     |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | FAIL | NEGEDGE | POSEDGE | RDY |

| Bit  | Name                         | Reset | Access | Description                                                                                                                                                                       |
|------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | <i>Reserved</i>              |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3    | <b>FAIL</b>                  | 0x0   | RW     | <b>LFXO Failure Interrupt Enable</b>                                                                                                                                              |
|      | Write 1 to enable FAILIF.    |       |        |                                                                                                                                                                                   |
| 2    | <b>NEGEDGE</b>               | 0x0   | RW     | <b>Falling Edge Interrupt Enable</b>                                                                                                                                              |
|      | Write 1 to enable NEGEDGEIF. |       |        |                                                                                                                                                                                   |
| 1    | <b>POSEDGE</b>               | 0x0   | RW     | <b>Rising Edge Interrupt Enable</b>                                                                                                                                               |
|      | Write 1 to enable POSEDGEIF. |       |        |                                                                                                                                                                                   |
| 0    | <b>RDY</b>                   | 0x0   | RW     | <b>LFXO Ready Interrupt Enable</b>                                                                                                                                                |
|      | Write 1 to enable RDYIF.     |       |        |                                                                                                                                                                                   |

**9.5.5.8 LFXO\_SYNCBUSY - LFXO Sync Busy Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|--|
| 0x020         | 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 |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 | 0 |   |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | CAL | R |   |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |  |

| Bit  | Name                                                                                                                                    | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | <i>Reserved</i>                                                                                                                         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | <b>CAL</b>                                                                                                                              | 0x0   | R      | <b>LFXO Synchronization status</b>                                                                                                                                                |
|      | This bit is set when there is an ongoing synchronization of CAL register bitfields. Do not write to CAL register while this bit is set. |       |        |                                                                                                                                                                                   |

**9.5.5.9 LFXO\_LOCK - Configuration Lock Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x024         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x1A20  |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | W       |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | LOCKKEY |   |   |   |   |   |   |

| Bit   | Name     | Reset                                                                                                              | Access | Description                                                                                                                                                                       |
|-------|----------|--------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |                                                                                                                    |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | LOCKKEY  | 0x1A20                                                                                                             | W      | <b>Lock Key</b>                                                                                                                                                                   |
|       |          | Write any other value than UNLOCK to lock CTRL, CFG and CAL registers. Write UNLOCK value to unlock the registers. |        |                                                                                                                                                                                   |
|       | Value    | Mode                                                                                                               |        | Description                                                                                                                                                                       |
|       | 6688     | UNLOCK                                                                                                             |        | Unlock LFXO lockable registers                                                                                                                                                    |

**9.6 LFRCO - Low-Frequency RC Oscillator****9.6.1 Introduction**

The LFRCO is an integrated low-frequency (32.768 kHz) RC oscillator. It can be used as a timing reference in EM0, EM1, EM2, and EM4. On certain part numbers, a precision mode is available in EM0, EM1 and EM2. Precision mode enables hardware that periodically recalibrates the LFRCO against the HFXO crystal frequency when temperature changes to provide a fully internal 32.768 kHz clock source with +/-500 ppm accuracy. Consult the device data sheet for details on which part numbers support precision mode.

**9.6.2 Features**

- 32.768 kHz oscillator
- High Accuracy
- Precision mode available in EM0, EM1, and EM2.
- Low-power non-precision operation available in EM0, EM1, EM2, and EM4.
- On-demand
- Lockable registers

**9.6.3 Functional Description****9.6.3.1 Start-up**

The LFRCO has a fast start-up time (refer to the data sheet electrical specifications for the exact start-up time). When the oscillator has started up and is ready to use, the RDY status bit will go high and the RDY interrupt will be triggered. After start-up, it may take two clock cycles for the clock to propagate through the CMU to the peripherals.

### 9.6.3.2 On-Demand Clocking

Software may forceably enable the LFRCO by setting the LFRCO\_CTRL.FORCEEN bit field. However, by default, the LFRCO is configured to be enabled only when required by hardware, and to shut down when no hardware request is present (i.e. LFRCO\_CTRL.DISONDEMAND=0 and LFRCO\_CTRL.FORCEEN=0). This is known as on-demand clocking and allows the oscillator to be controlled without any software intervention.

### 9.6.3.3 Register Lock

The LFRCO configuration registers NOMCAL, NOMCALINV and CFG can be locked or unlocked by software using the LOCKKEY field in the LFRCO\_LOCK register. By writing the UNLOCK value to LFRCO\_LOCK\_LOCKKEY, these registers will be unlocked and accessible to software. Any other value written to LFRCO\_LOCK\_LOCKKEY will lock the registers against write operations.

### 9.6.3.4 Precision Mode

Certain device families support a precision mode to bring the LFRCO accuracy to within +/-500 ppm, suitable for BLE sleep applications. Precision mode uses hardware to automatically re-calibrate the LFRCO against a crystal driven by the HFXO. Hardware detects temperature changes and initiates a re-calibration of the LFRCO as needed when operating in EM0, EM1, or EM2. If a re-calibration is necessary and the HFXO is not active, the precision mode hardware will automatically enable HFXO for a short time to perform the calibration. EM4 operation is not allowed while precision mode is enabled.

To enable precision mode software should set the LFRCO\_CFG\_HIGHPRECEN bit to 1 while the LFRCO is disabled (LFRCO\_STATUS\_ENS = 0). If this bit is written while the oscillator is enabled, a bus fault will be generated. In a typical application, software will only access HIGHPRECEN at startup before any peripherals are configured to request the LFRCO.

Disabling precision mode is the inverse - software should ensure that no peripherals are requesting the LFRCO, and then clear the LFRCO\_CFG\_HIGHPRECEN bit to 0.

#### 9.6.3.4.1 Reference Frequency

Precision mode uses a reference clock from the HFXO as a calibration target. Two registers (LFRCO\_NOMCALCNT and LFRCO\_NOMCALCNTINV) are used to specify the nominal relationship between the HFXO reference clock and the LFRCO frequency as shown in [Figure 9.2 LFRCO\\_NOMCALCNT Calculation on page 244](#) and [Figure 9.3 LFRCO\\_NOMCALCNTINV Calculation on page 244](#). NOMCALCNT and NOMCALCNTINV must be programmed while the LFRCO is not enabled.

$$\text{NOMCALCNT} = (320 * f_{\text{HFXO}}) / 32768$$

Where  $f_{\text{HFXO}}$  is the reference crystal frequency in Hz

**Figure 9.2. LFRCO\_NOMCALCNT Calculation**

$$\text{NOMCALCNTINV} = (1 / \text{NOMCALCNT}) * 2^{33}$$

**Figure 9.3. LFRCO\_NOMCALCNTINV Calculation**

#### 9.6.3.4.2 Temperature Check and Calibration Intervals

When starting up in precision mode, the LFRCO will calibrate itself against the HFXO. After startup, the die temperature is checked periodically and if necessary, the LFRCO will initiate a re-calibration. Periodic re-calibration is also performed if the temperature has not changed for an extended period of time.

If a very high die temperature gradient is expected (e.g. due to high-power RF transmission), software can reduce the temperature check interval temporarily by setting the LFRCO\_CMD\_REDUCETCINT bit to 1. The LFRCO will then use a shorter temperature check interval until the chip enters EM2. When EM2 is entered, the temperature-check interval will gradually be increased based on the measured temperature gradient until it is back to the normal temperature check interval.

### 9.6.3.5 Interrupts

The LFRCO implements several interrupt flags in the LFRCO\_IF register to report status, error events, or for debugging. Each interrupt flag has an enable bit in LFRCO\_IEN. Setting a bit in IEN to 1 enables the corresponding interrupt source to trigger an LFRCO interrupt.

RDYIF is triggered after start-up, when the LFRCO startup sequence is complete and the oscillator is ready to use.

POSEDGEIF and NEGEDGEIF are triggered by the rising and falling edge of LFRCO respectively. These flags will only get set if either of the interrupts are enabled (with POSEDGEIEN or NEGEDGEIEN). Note that enabling NEGEDGEIF or POSEDGEIF act as a clock requester for the LFRCO oscillator, and these two interrupt enables must be disabled in order to disable the LFRCO.

RDYIF, POSEDGEIF, and NEGEDGEIF are available only in EM0 and EM1.

Three of the interrupt sources are error flags used by precision mode to alert software that there is a problem with the oscillator and it may no longer be running with full precision. CALOORIF indicates that a calibration was performed, but the result was outside of the oscillator's adjustment range. TCOORIF indicates that a temperature measurement was performed, but the measurement was out of range. Finally, the SCHEDEERRIF flag indicates that a temperature check could not be performed due to a prior error. These three error flags are available when operating in precision mode in EM0, EM1, or EM2.

The remaining flags, TEMPCHANGEIF, CALDONEIF and TCDONEIF are available when operating in precision mode in EM0 and EM1 only and are provided for debugging purposes. Refer to the LFRCO\_IF register description for the specific conditions of these flags.

#### 9.6.4 LFRCO Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description                           |
|--------|---------------------|-------------|---------------------------------------|
| 0x000  | LFRCO_IPVERSION     | R           | IP Version                            |
| 0x004  | LFRCO_CTRL          | RW          | Control Register                      |
| 0x008  | LFRCO_STATUS        | RH          | Status Register                       |
| 0x014  | LFRCO_IF            | RWH INTFLAG | Interrupt Flag Register               |
| 0x018  | LFRCO_IEN           | RW          | Interrupt Enable Register             |
| 0x020  | LFRCO_LOCK          | W           | Configuration Lock Register           |
| 0x024  | LFRCO_CFG           | RW CONFIG   | Configuration Register                |
| 0x02C  | LFRCO_NOMCAL        | RW CONFIG   | Nominal Calibration Register          |
| 0x030  | LFRCO_NOMCALINV     | RW CONFIG   | Nominal Calibration Inverted Register |
| 0x034  | LFRCO_CMD           | W           | Command Register                      |
| 0x1000 | LFRCO_IPVERSION_SET | R           | IP Version                            |
| 0x1004 | LFRCO_CTRL_SET      | RW          | Control Register                      |
| 0x1008 | LFRCO_STATUS_SET    | RH          | Status Register                       |
| 0x1014 | LFRCO_IF_SET        | RWH INTFLAG | Interrupt Flag Register               |
| 0x1018 | LFRCO_IEN_SET       | RW          | Interrupt Enable Register             |
| 0x1020 | LFRCO_LOCK_SET      | W           | Configuration Lock Register           |
| 0x1024 | LFRCO_CFG_SET       | RW CONFIG   | Configuration Register                |
| 0x102C | LFRCO_NOMCAL_SET    | RW CONFIG   | Nominal Calibration Register          |
| 0x1030 | LFRCO_NOMCALINV_SET | RW CONFIG   | Nominal Calibration Inverted Register |
| 0x1034 | LFRCO_CMD_SET       | W           | Command Register                      |
| 0x2000 | LFRCO_IPVERSION_CLR | R           | IP Version                            |
| 0x2004 | LFRCO_CTRL_CLR      | RW          | Control Register                      |
| 0x2008 | LFRCO_STATUS_CLR    | RH          | Status Register                       |
| 0x2014 | LFRCO_IF_CLR        | RWH INTFLAG | Interrupt Flag Register               |
| 0x2018 | LFRCO_IEN_CLR       | RW          | Interrupt Enable Register             |
| 0x2020 | LFRCO_LOCK_CLR      | W           | Configuration Lock Register           |
| 0x2024 | LFRCO_CFG_CLR       | RW CONFIG   | Configuration Register                |
| 0x202C | LFRCO_NOMCAL_CLR    | RW CONFIG   | Nominal Calibration Register          |
| 0x2030 | LFRCO_NOMCALINV_CLR | RW CONFIG   | Nominal Calibration Inverted Register |
| 0x2034 | LFRCO_CMD_CLR       | W           | Command Register                      |
| 0x3000 | LFRCO_IPVERSION_TGL | R           | IP Version                            |
| 0x3004 | LFRCO_CTRL_TGL      | RW          | Control Register                      |
| 0x3008 | LFRCO_STATUS_TGL    | RH          | Status Register                       |
| 0x3014 | LFRCO_IF_TGL        | RWH INTFLAG | Interrupt Flag Register               |
| 0x3018 | LFRCO_IEN_TGL       | RW          | Interrupt Enable Register             |

| Offset | Name                | Type      | Description                           |
|--------|---------------------|-----------|---------------------------------------|
| 0x3020 | LFRCO_LOCK_TGL      | W         | Configuration Lock Register           |
| 0x3024 | LFRCO_CFG_TGL       | RW CONFIG | Configuration Register                |
| 0x302C | LFRCO_NOMCAL_TGL    | RW CONFIG | Nominal Calibration Register          |
| 0x3030 | LFRCO_NOMCALINV_TGL | RW CONFIG | Nominal Calibration Inverted Register |
| 0x3034 | LFRCO_CMD_TGL       | W         | Command Register                      |

## 9.6.5 LFRCO Register Description

### 9.6.5.1 LFRCO\_IPVERSION - IP Version

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x2          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                               |
|------|-----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | IPVERSION | 0x2   | R      | <b>IP version ID</b><br><br>The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |

**9.6.5.2 LFRCO\_CTRL - Control Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |             |         |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-------------|---------|
| 0x004         | 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       |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 | 0x0         |         |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW  | RW          |         |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     | DISONDEMAND | FORCEEN |

| Bit  | Name            | Reset                                                                                                                                                                             | Access | Description                                                                                                              |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------|
| 31:2 | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                          |
| 1    | DISONDEMAND     | 0x0                                                                                                                                                                               | RW     | <b>Disable On-Demand</b><br><br>Disable on demand functionality and enable the oscillator based on the force-enable bit. |
| 0    | FORCEEN         | 0x0                                                                                                                                                                               | RW     | <b>Force Enable</b><br><br>Force the LFRCO core on                                                                       |

## 9.6.5.3 LFRCO\_STATUS - Status Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|-----|---|
| 0x008  | 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 |  |  |  |     |   |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |     |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |     |   |
| Name   | LOCK         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ENS |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  | RDY | R |

| Bit                                                            | Name     | Reset                                                                                                                                                                             | Access | Description           |
|----------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------|
| 31                                                             | LOCK     | 0x0                                                                                                                                                                               | R      | <b>Lock Status</b>    |
| This bit is set when LFRCO is locked.                          |          |                                                                                                                                                                                   |        |                       |
| Value                                                          | Mode     | Description                                                                                                                                                                       |        |                       |
| 0                                                              | UNLOCKED | Access to configuration registers not locked                                                                                                                                      |        |                       |
| 1                                                              | LOCKED   | Access to configuration registers locked                                                                                                                                          |        |                       |
| 30:17                                                          | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                       |
| 16                                                             | ENS      | 0x0                                                                                                                                                                               | R      | <b>Enabled Status</b> |
| This bit is set when LFRCO is enabling the analog core.        |          |                                                                                                                                                                                   |        |                       |
| 15:1                                                           | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                       |
| 0                                                              | RDY      | 0x0                                                                                                                                                                               | R      | <b>Ready Status</b>   |
| This bit is set when qualification is done and LFRCO is ready. |          |                                                                                                                                                                                   |        |                       |

## 9.6.5.4 LFRCO\_IF - Interrupt Flag Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |        |    |       |    |          |    |            |    |         |    |        |    |         |    |         |    |     |   |   |   |     |   |     |   |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|--------|----|-------|----|----------|----|------------|----|---------|----|--------|----|---------|----|---------|----|-----|---|---|---|-----|---|-----|---|-----|---|
| Reset  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 0x0 | 17 | 0x0    | 16 | 0x0   | 15 | 14       | 13 | 12         | 11 | 0x0     | 10 | 0x0    | 9  | 0x0     | 8  | 0x0     | 7  | 6   | 5 | 4 | 3 | 0x0 | 2 | 0x0 | 1 | 0x0 | 0 |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    | CALOOR | RW | TCOOR | RW | SCHEDERR | RW | TEMPCHANGE | RW | CALDONE | RW | TCDONE | RW | NEGEDGE | RW | POSEDGE | RW | RDY |   |   |   |     |   |     |   |     |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |        |    |       |    |          |    |            |    |         |    |        |    |         |    |         |    |     |   |   |   |     |   |     |   |     |   |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                        |
|-------|------------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>  |
| 18    | CALOOR     | 0x0   | RW     | <b>Calibration Out Of Range Flag</b><br><br>Triggers if Calibration measure is out of range                                                                        |
| 17    | TCOOR      | 0x0   | RW     | <b>Temperature Check Out Of Range Flag</b><br><br>Triggers if Temperature Check measure is out of range                                                            |
| 16    | SCHEDERR   | 0x0   | RW     | <b>Scheduling Error Flag</b><br><br>Triggers if a scheduled Temperature Check can not be handled because prior Termperature Check or Calibration did not complete. |
| 15:11 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>  |
| 10    | TEMPCHANGE | 0x0   | RW     | <b>Temperature Change Flag</b><br><br>Triggers when Temperature Check detects a change in temperature                                                              |
| 9     | CALDONE    | 0x0   | RW     | <b>Calibration Done Flag</b><br><br>Triggers on completion of Calibration                                                                                          |
| 8     | TCDONE     | 0x0   | RW     | <b>Temperature Check Done Flag</b><br><br>Triggers on completion of Temperature Check                                                                              |
| 7:3   | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>  |
| 2     | NEGEDGE    | 0x0   | RW     | <b>Falling Edge Flag</b><br><br>Triggers on every negative edge of the LFRCO clock. IF will only be set when corresponding IEN is set.                             |
| 1     | POSEDGE    | 0x0   | RW     | <b>Rising Edge Flag</b><br><br>Triggers on every positive edge of the LFRCO clock. IF will only be set when corresponding IEN is set.                              |
| 0     | RDY        | 0x0   | RW     | <b>Ready Flag</b><br><br>Triggers when the oscillator becomes ready                                                                                                |

## 9.6.5.5 LFRCO\_IEN - Interrupt Enable Register

| Offset | Bit Position                                                       |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------|---------|--------|---------|---------|-----|----|----|----|----|----|-----|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Reset  | 31                                                                 | 30                                                                                                                                                                                | 29       | 28                                           | 27      | 26     | 25      | 24      | 23  | 22 | 21 | 20 | 19 | 18 | 0x0 | 1  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access | RW                                                                 | RW                                                                                                                                                                                | RW       | RW                                           | RW      | RW     | RW      | RW      | RW  | RW | RW | RW | RW | RW | RW  | 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | CALOOR                                                             | TCOOR                                                                                                                                                                             | SCHEDERR | TEMPCHANGE                                   | CALDONE | TCDONE | NEGEDGE | POSEDGE | RDY |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:19  | Reserved                                                           | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18     | CALOOR                                                             | 0x0                                                                                                                                                                               | RW       | <b>Calibration Out Of Range Enable</b>       |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the Calibration Out Of Range interrupt                     |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17     | TCOOR                                                              | 0x0                                                                                                                                                                               | RW       | <b>Temperature Check Out Of Range Enable</b> |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the Temperature Check Out Of Range interrupt               |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16     | SCHEDERR                                                           | 0x0                                                                                                                                                                               | RW       | <b>Scheduling Error Enable</b>               |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the Scheduling Error interrupt                             |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:11  | Reserved                                                           | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10     | TEMPCHANGE                                                         | 0x0                                                                                                                                                                               | RW       | <b>Temperature Change Enable</b>             |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the Temperature Change interrupt                           |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9      | CALDONE                                                            | 0x0                                                                                                                                                                               | RW       | <b>Calibration Done Enable</b>               |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the Calibration Done interrupt                             |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8      | TCDONE                                                             | 0x0                                                                                                                                                                               | RW       | <b>Temperature Check Done Enable</b>         |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the Temperature Check Done interrupt                       |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7:3    | Reserved                                                           | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2      | NEGEDGE                                                            | 0x0                                                                                                                                                                               | RW       | <b>Falling Edge Enable</b>                   |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the negedge interrupt and will cause the oscillator to run |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1      | POSEDGE                                                            | 0x0                                                                                                                                                                               | RW       | <b>Rising Edge Enable</b>                    |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the posedge interrupt and will cause the oscillator to run |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0      | RDY                                                                | 0x0                                                                                                                                                                               | RW       | <b>Ready Enable</b>                          |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        | Enables the ready interrupt                                        |                                                                                                                                                                                   |          |                                              |         |        |         |         |     |    |    |    |    |    |     |    |  |  |  |  |  |  |  |  |  |  |  |  |  |

**9.6.5.6 LFRCO\_LOCK - Configuration Lock Register**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---------|
| 0x020         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0     |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | W       |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | LOCKKEY |

| Bit                                                                                                         | Name     | Reset | Access                         | Description                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------|----------|-------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                       | Reserved |       |                                | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                                                        | LOCKKEY  | 0x0   | W                              | <b>Lock Key</b>                                                                                                                                                                   |
| Writing the lock key will unlock the LFRCO configuration registers. Writing any other value will lock them. |          |       |                                |                                                                                                                                                                                   |
| Value                                                                                                       | Mode     |       | Description                    |                                                                                                                                                                                   |
| 0                                                                                                           | LOCK     |       | Lock Configuration Registers   |                                                                                                                                                                                   |
| 3987                                                                                                        | UNLOCK   |       | Unlock Configuration Registers |                                                                                                                                                                                   |

**9.6.5.7 LFRCO\_CFG - Configuration Register**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |            |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------------|
| 0x024         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0        |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RW         |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | HIGHPRECEN |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0          |

| Bit  | Name                                                                                                                 | Reset | Access | Description                                                                                                                                                                       |
|------|----------------------------------------------------------------------------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved                                                                                                             |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | HIGHPRECEN                                                                                                           | 0x0   | RW     | <b>High Precision Enable</b>                                                                                                                                                      |
|      | LFRCO operates in High Precision Mode when this bit is set. HIGHPRECEN should not be written while LFRCO is enabled. |       |        |                                                                                                                                                                                   |

**9.6.5.8 LFRCO\_NOMCAL - Nominal Calibration Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x02C  | 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 |
| Reset  | 0x5B8D8      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | NOMCALCNT    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name      | Reset   | Access | Description                                                                                                                                                                                                                                                                                    |
|-------|-----------|---------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | Reserved  |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                              |
| 20:0  | NOMCALCNT | 0x5B8D8 | RW     | <b>Nominal Calibration Count</b><br><br>Expected Calibration count value. Should be set based on HFXO frequency; NOMCALCNT = $2 * f(\text{HFXO}) / (32.768 \text{ kHz} / 160)$ . Default value corresponds to 38.4 MHz HFXO frequency. NOMCALCNT should not be written while LFRCO is enabled. |

**9.6.5.9 LFRCO\_NOMCALINV - Nominal Calibration Inverted Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x030  | 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 |
| Reset  | 0x597A       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | NOMCALCNTINV |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name         | Reset  | Access | Description                                                                                                                                                                                                                                                                                           |
|-------|--------------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved     |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                     |
| 16:0  | NOMCALCNTINV | 0x597A | RW     | <b>Nominal Calibration Count Inverted</b><br><br>This register should always be set to the inverse of NOMCALCNT value. Due to format of this register, integer value should be $\text{NOMCALCNTINV} = (1 / \text{NOMCALCNT}) * (2^{33})$ . NOMCALCNTINV should not be written while LFRCO is enabled. |

**9.6.5.10 LFRCO\_CMD - Command Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|---|---|
| 0x034         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0         |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | W(nB)       |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | REDUCETCINT |   |   |

| Bit  | Name               | Reset                                                                                                                                                                             | Access | Description                                                                                                                        |
|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | <i>Reserved</i>    | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                    |
| 0    | <b>REDUCETCINT</b> | 0x0                                                                                                                                                                               | W(nB)  | <b>Reduce Temperature Check Interval</b><br><br>Setting this register field will temporarily lower the Temperature Check interval. |

**9.7 FSRCO - Fast Start RCO****9.7.1 Introduction**

This is an RC oscillator which can start and stop very fast. It is a fixed frequency oscillator, with no frequency configurability and as such any user of this clock can rely on it being a specific frequency independent of the system state. This is the first oscillator used during power up and hence it minimizes dependency to other blocks.

**9.7.2 Features**

- 20 MHz nominal frequency
- Low energy consumption

**9.7.3 Functional Description**

There are no programmable registers in this module. Software can choose to use this as system clock in the CMU block. the only way to enable or disable the FSRCO is by requesting it as a clock source in the CMU clock select registers.

**9.7.4 FSRCO Register Map**

The offset register address is relative to the registers base address.

| Offset | Name                                | Type | Description |
|--------|-------------------------------------|------|-------------|
| 0x000  | <a href="#">FSRCO_IPVERSION</a>     | R    | IP Version  |
| 0x1000 | <a href="#">FSRCO_IPVERSION_SET</a> | R    | IP Version  |
| 0x2000 | <a href="#">FSRCO_IPVERSION_CLR</a> | R    | IP Version  |
| 0x3000 | <a href="#">FSRCO_IPVERSION_TGL</a> | R    | IP Version  |

## 9.7.5 FSRCO Register Description

### 9.7.5.1 FSRCO\_IPVERSION - IP Version

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|-------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x0   | R      | <b>IP Version</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                   |

## 9.8 ULFRCO - Ultra Low Frequency RC Oscillator

### 9.8.1 Introduction

The ULFRCO is an ultra low power 1 kHz oscillator which is available in all energy modes. The ULFRCO is available to many low-frequency peripherals as a lower power alternative to one of the 32 kHz oscillators. This oscillator is also used for internal bias and housekeeping tasks in EM0-EM3.

### 9.8.2 Features

- 1 kHz nominal frequency
- Low energy consumption

### 9.8.3 Functional Description

There are no user programmable registers in this module. The oscillator is always on in all energy modes except EM4. In EM4, the oscillator is available on-demand by peripheral requests.

## 10. SMU - Security Management Unit



| Quick Facts                                                                                                                        |
|------------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b>                                                                                                                       |
| The Security Management Unit (SMU) provides configuration and status reporting for ARM TrustZone on the EFR32xG24.                 |
| <b>Why?</b>                                                                                                                        |
| Enables a robust solution at the system level.                                                                                     |
| <b>How?</b>                                                                                                                        |
| Hardware context switching and enhanced security provided by ARM TrustZone. Extension of the ARM MPU to control peripheral access. |

### 10.1 Introduction

The Security Management Unit is used to configure and extend TrustZone bus level security provided by the Cortex®-M33. In addition it increases the effective MPU regions by providing MPU control over peripheral access.

### 10.2 Features

- Per peripheral privileged and secure attributes
- Per manager privileged and secure attributes
- Separate interrupt flags for privileged, secure, or instruction access exceptions.
- Separate interrupt flag for secure manager access exceptions
- Secure and Privileged exception IRQs
- Configurable secure, non-secure, and non-secure-callable memory regions.

## 10.3 Functional Description

### 10.3.1 Bus Level Security

Bus level security is the ability to control the flow of information on the device. The components of bus level security are the Cortex®-M33, the Bus Manager Protect Unit (BMPU), and the Peripheral Protection Unit (PPU) as highlighted in [Figure 10.1 Bus Level Security Implementation on page 257](#). The SMU controls and configures all the components used in bus level security.



**Figure 10.1. Bus Level Security Implementation**

The BMPU is responsible for preventing managers (CPU, DMA, Etc..) from accessing secure addresses without authorization. For example, if a DMA configured as non-secure tries to access memory that is marked secure the BMPU will prevent access and set the corresponding interrupt flag. The BMPU prevents access of secure addresses by non-secure managers. The Cortex®-M33 has BMPU functionality built into the TrustZone implementation.

The PPU is primarily responsible for blocking access to privileged peripherals from unprivileged managers. In addition, it also ensures that secure and non-secure peripherals are only accessible at the appropriate secure or non-secure addresses as described in [10.3.6 Configuring Peripherals](#).

Since FLASH and RAM have no PPU, bus managers of any privilege state may access those resources. The Cortex®-M33 has an MPU which prevents execution of privileged memory when the CPU is in an unprivileged state. For more information on the MPU refer to the ARM Cortex®-M33 documentation.

### 10.3.2 Privileged Access Control

The Cortex®-M33 and all other managers can be in either the privileged or unprivileged state. All bus access to peripherals are tested for privilege level by the PPU and resolved as shown in [Table 10.1 Privileged Access Table on page 258](#).

If an exception is detected on a write, the write will be ignored and the appropriate interrupt flag set. If an exception is detected on a read 0x0 will be returned and the appropriate interrupt flag set.

**Table 10.1. Privileged Access Table**

| Manager Attribute | Peripheral Attribute | Result    |
|-------------------|----------------------|-----------|
| privileged        | privileged           | Success   |
| privileged        | unprivileged         | Success   |
| unprivileged      | privileged           | Exception |
| unprivileged      | unprivileged         | Success   |

### 10.3.3 Secure Access Control

The Cortex®-M33 and all other managers can be in either the secure or non-secure state. All bus accesses are tested for security status by the BMPUs and PPUs and resolve as shown in [Table 10.2 Secure Access Table on page 258](#). Secure access is computed using the secure attribute of the manager and the address region being accessed. If a peripheral is being accessed, the secure attribute of the peripheral is also used. For more information on the relationship between the address regions and peripheral security attributes please see [10.3.6 Configuring Peripherals](#)

If an exception is detected on a write the write will be ignored and the appropriate interrupt flag set. If an exception is detected on a read 0x0 will be returned and the appropriate interrupt flag set.

**Table 10.2. Secure Access Table**

| Manager Attribute | Address Attribute | Peripheral Attribute | Result    |
|-------------------|-------------------|----------------------|-----------|
| secure            | secure            | N/A                  | Success   |
| secure            | secure            | secure               | Success   |
| secure            | secure            | non-secure           | Exception |
| secure            | non-secure        | N/A                  | Exception |
| secure            | non-secure        | secure               | Exception |
| secure            | non-secure        | non-secure           | Success   |
| non-secure        | secure            | N/A                  | Exception |
| non-secure        | secure            | secure               | Exception |
| non-secure        | secure            | non-secure           | Exception |
| non-secure        | non-secure        | N/A                  | Success   |
| non-secure        | non-secure        | secure               | Exception |
| non-secure        | non-secure        | non-secure           | Success   |

#### 10.3.4 ARM TrustZone

ARM TrustZone is used to control what addresses are accessible by the CPU at any given time. There are two security states: secure and non-secure. In addition the MPU provides two privilege levels: privileged and unprivileged. This results in 4 possible states: secure-privileged, non-secure-privileged, secure-unprivileged and non-secure-unprivileged.

Non-secure code may not directly call secure code. To call secure code, non-secure code must first call a shim located in specially marked non-secure-callable memory. Unprivileged code may invoke privileged code and change the processor state to privileged by either issuing an SVC instruction or taking an interrupt. The processor is returned to unprivileged state when software manually reconfigures the security state or exits an interrupt.

For more information on secure/non-secure and privileged/unprivileged state transitions see the ARM Cortex®-M33 documentation.

There are two primary use cases for TrustZone and the MPU. The first is simply partitioning a monolithic application into the 4 states to protect some pieces of the system from bugs or attacks on others. The second is to use a RTOS to isolate several tasks from each other. In this case the RTOS itself normally consumes the privileged states with all other code running in the unprivileged states. Whenever a task switch occurs the RTOS can reconfigure the device so the new task has access to only the components it requires, protecting other tasks from interference.

In both use cases the TrustZone and MPU feature of the Cortex®-M33 both secures and accelerates mode transitions while the SMU provides the ability to configure the security and privilege attributes of peripherals and memory.

The core is in secure-privileged state after a reset.

#### 10.3.5 Configuring Managers

The SMU provides the ability to configure the current secure and privileged attribute of all bus managers except for the CPU which is controlled as described in [10.3.4 ARM TrustZone](#).

To configure the privileged attribute of a manager set the appropriate bit in SMU\_BMPUPATDn. To configure the secure attribute of a manager set the appropriate bit in SMU\_BMPUPSATDn.

#### 10.3.6 Configuring Peripherals

The SMU provides the ability to configure the current secure and privileged state of all peripherals. To configure the privileged attribute of a peripheral set the appropriate bit in SMU\_PPUPATDn.

Each peripheral is accessible at one of two addresses: A secure address and a non-secure address. Which address is valid depends on the security attribute of the peripheral configured in the SMU. When configured as secure a peripheral may only be accessed at its secure address and when configured as non-secure the peripheral may only be accessed at its non-secure address. This forces code to be aware of the security attribute of the peripheral being accessed, preventing secure code from accessing a non-secure peripheral unintentionally.

The device memory map contains 4 regions of fixed length and fixed security attribute to facilitate the secure access of peripherals and RF peripherals. There is one secure (0x40000000) and one non-secure (0x50000000) region for peripherals and one secure (0xA0000000) and non-secure (0xB0000000) region for the radio subsystem. While each peripheral can be configured independently the radio subsystem is configured as a unit.

To configure the security attribute of a peripheral set the appropriate bit in SMU\_PPUSATDn.

### 10.3.7 Configuring Memory

The SMU provides the ability to configure the security attribute of memory. There are 13 configurable regions in total. There are three regions in FLASH (0 - 2) and three in RAM (4-6) which have pre-determined secure attributes and user selectable sizes. Regions 3 and 11 cover the flash info page and ARM EPPB space respectively and have a fixed size. These regions can be configured as secure or non-secure by setting ESAUR3NS in SMU\_ESAURTYPES0 and ESAUR11NS in SMU\_ESAURTYPES1 respectively.

The size of the FLASH and RAM regions are controlled by the SMU\_ESAUMRBRxy registers as shown in [Table 10.3 Memory Configuration Regions on page 260](#). Region sizes are adjusted in 4 kB increments with the lower 12 bits of SMU\_ESAUMRBRxy ignored. The non-secure-callable regions may be set to size 0 but secure and non-secure regions must be at least 4 kB.

**Table 10.3. Memory Configuration Regions**

| Region | Memory                          | Attributes           | Start          | End              |
|--------|---------------------------------|----------------------|----------------|------------------|
| 0      | FLASH                           | secure               | 0x00000000     | SMU_ESAUMRBR01-1 |
| 1      | FLASH                           | non-secure-callable  | SMU_ESAUMRBR01 | SMU_ESAUMRBR12-1 |
| 2      | FLASH                           | non-secure           | SMU_ESAUMRBR12 | 0x0FFFFFFFFFFF   |
| 3      | FLASH (info page)               | secure or non-secure | 0x0FE00000     | 0x0FFFFFFF       |
| 4      | RAM                             | secure               | 0x20000000     | SMU_ESAUMRBR45-1 |
| 5      | RAM                             | non-secure-callable  | SMU_ESAUMRBR45 | SMU_ESAUMRBR56-1 |
| 6      | RAM                             | non-secure           | SMU_ESAUMRBR56 | 0x2FFFFFFF       |
| 7      | Peripherals                     | secure               | 0x40000000     | 0x4FFFFFFF       |
| 8      | Peripherals                     | non-secure           | 0x50000000     | 0x5FFFFFFF       |
| 9      | SEQRAM/FRCRAM                   | secure               | 0xA0000000     | 0xAFFFFFFF       |
| 10     | SEQRAM/FRCRAM                   | non-secure           | 0xB0000000     | 0xBFFFFFFF       |
| 11     | EPPB                            | secure or non-secure | 0xE0044000     | 0xE00FDFFF       |
| 12     | Cortex®-M33 Processor ROM table | exempt               | 0xE00FE000     | 0xE00FEFFF       |

### 10.3.8 Cortex®-M33 Integration

In addition to the SMU based access controls the Cortex®-M33 has additional security features for controlling both secure and privileged access.

The Security Attribution Unit (SAU) provides that ability to setup secure memory regions in addition to those configured by the SMU. To disable the SAU and rely entirely on the SMU for security management clear ENABLE and set ALLNS in the SAU CTRL register. To enable a combination of SMU and SAU control set ENABLE in the SAU CTRL register. If both ENABLE and ALLNS are cleared all Cortex®-M33 will treat all transactions as secure.

When both SAU and SMU are in use, a memory address is considered secure if either the SAU or SMU have it configured as secure. When enabled the SAU applies ONLY to access by the Cortex®-M33 and does not effect any other managers. For more information on the SAU refer to ARM documentation.

**Note:** It is highly recommended that systems avoid using the SAU unless necessary. Since the SAU does not affect any managers outside the Cortex®-M33, extreme care must be taken to ensure the SAU regions can not be trivially bypassed through use of another manager such as the DMA.

In addition to the Cortex®-M33 MPU provides the ability to control which regions of FLASH and RAM are marked as privileged and prevent execution of privileged code by a CPU in unprivileged state. For more information on the configuration and use of the MPU refer to ARM documentation.

### 10.3.9 Exception Handling

When a BMPU detects a non-secure manager attempting to access a secure address, the BMPUSECIF in SMU\_IF is set and the ID of the Manager block is written to SMU\_BMPUFS. If BMPUSECIEN is set and the SMU's Secure IRQ enabled, the CPU will be interrupted.

When a PPU detects an access to a secure peripheral at its non-secure address or an access to a non-secure peripheral at its secure address, PPUECIF in SMU\_IF is set and the ID of the peripheral being accessed is written to SMU\_PPUFS. If PPUECIEN is set and the SMU's Secure IRQ enabled, the CPU will be interrupted.

If a PPU detects an attempt to fetch an instruction from a peripheral, PPUINSTIF in SMU\_IF will be set and the ID of the peripheral being accessed is written to SMU\_PPUFS. If PPUINSTIEN is set and the SMU's Privileged IRQ enabled, the CPU will be interrupted.

If a PPU detects an attempt to access a privileged peripheral by an unprivileged manager, PPUPRIVIF in SMU\_IF will be set and the ID of the peripheral being accessed is written to SMU\_PPUFS. If PPUPRIVIEN is set and the SMU's Privileged IRQ enabled, the CPU will be interrupted.

When any IRQ is triggered the Cortex®-M33 is automatically placed in the privileged state. The security state is determined by configuration inside the Cortex®-M33. Refer to ARM's documentation for more details.

If the SMU is configured in an inconsistent way, the SMUPRGERR flag in SMU\_STATUS will be set. One example of an invalid configuration is setting SMU\_ESAUMRBR01 to a value larger than SMU\_ESAUMRBR23. SMUPRGERR should be checked after the SMU is configured.

### 10.3.10 SMU Lock

The SMU registers can be locked to prevent unintended modifications. SMULOCK in SMU\_STATUS indicates if the SMU is currently locked. To unlock the SMU write 0xACCE55 to the SMU\_LOCK register. To lock write any other value to SMU\_LOCK.

In addition to locking the SMU registers the SMU can prevent access to the Cortex®-M33 ASU, MPU, SMPU, VTOR and VTAIRCR registers. To lock access to one or more of these blocks set the corresponding bit in SMU\_M33CTRL.

#### 10.4 SMU Register Map

The offset register address is relative to the registers base address.

| Offset | Name              | Type        | Description               |
|--------|-------------------|-------------|---------------------------|
| 0x000  | SMU_IPVERSION     | R           | IP Version                |
| 0x004  | SMU_STATUS        | RH          | Status Register           |
| 0x008  | SMU_LOCK          | W           | Lock Register             |
| 0x00C  | SMU_IF            | RWH INTFLAG | Interrupt Flag Register   |
| 0x010  | SMU_IEN           | RW          | Interrupt Enable Register |
| 0x020  | SMU_M33CTRL       | RW          | M33 Control Settings      |
| 0x040  | SMU_PPUPATD0      | RW          | Privileged Access         |
| 0x044  | SMU_PPUPATD1      | RW          | Privileged Access         |
| 0x060  | SMU_PPUSATD0      | RW          | Secure Access             |
| 0x064  | SMU_PPUSATD1      | RW          | Secure Access             |
| 0x140  | SMU_PPUFS         | RH          | Fault Status              |
| 0x150  | SMU_BMPUPATD0     | RW          | Privileged Attribute      |
| 0x170  | SMU_BMPUSATD0     | RW          | Secure Attribute          |
| 0x250  | SMU_BMPUFS        | RH          | Fault Status              |
| 0x254  | SMU_BMPUFSADDR    | RH          | Fault Status Address      |
| 0x260  | SMU_ESAURTYPES0   | RW          | Region Types 0            |
| 0x264  | SMU_ESAURTYPES1   | RW          | Region Types 1            |
| 0x270  | SMU_ESAUMRB01     | RW          | Movable Region Boundary   |
| 0x274  | SMU_ESAUMRB12     | RW          | Movable Region Boundary   |
| 0x280  | SMU_ESAUMRB45     | RW          | Movable Region Boundary   |
| 0x284  | SMU_ESAUMRB56     | RW          | Movable Region Boundary   |
| 0x1000 | SMU_IPVERSION_SET | R           | IP Version                |
| 0x1004 | SMU_STATUS_SET    | RH          | Status Register           |
| 0x1008 | SMU_LOCK_SET      | W           | Lock Register             |
| 0x100C | SMU_IF_SET        | RWH INTFLAG | Interrupt Flag Register   |
| 0x1010 | SMU_IEN_SET       | RW          | Interrupt Enable Register |
| 0x1020 | SMU_M33CTRL_SET   | RW          | M33 Control Settings      |
| 0x1040 | SMU_PPUPATD0_SET  | RW          | Privileged Access         |
| 0x1044 | SMU_PPUPATD1_SET  | RW          | Privileged Access         |
| 0x1060 | SMU_PPUSATD0_SET  | RW          | Secure Access             |
| 0x1064 | SMU_PPUSATD1_SET  | RW          | Secure Access             |
| 0x1140 | SMU_PPUFS_SET     | RH          | Fault Status              |
| 0x1150 | SMU_BMPUPATD0_SET | RW          | Privileged Attribute      |
| 0x1170 | SMU_BMPUSATD0_SET | RW          | Secure Attribute          |
| 0x1250 | SMU_BMPUFS_SET    | RH          | Fault Status              |

| Offset | Name                                | Type        | Description               |
|--------|-------------------------------------|-------------|---------------------------|
| 0x1254 | <a href="#">SMU_BMPUFSADDR_SET</a>  | RH          | Fault Status Address      |
| 0x1260 | <a href="#">SMU_ESAURTYPES0_SET</a> | RW          | Region Types 0            |
| 0x1264 | <a href="#">SMU_ESAURTYPES1_SET</a> | RW          | Region Types 1            |
| 0x1270 | <a href="#">SMU_ESAUMRB01_SET</a>   | RW          | Movable Region Boundary   |
| 0x1274 | <a href="#">SMU_ESAUMRB12_SET</a>   | RW          | Movable Region Boundary   |
| 0x1280 | <a href="#">SMU_ESAUMRB45_SET</a>   | RW          | Movable Region Boundary   |
| 0x1284 | <a href="#">SMU_ESAUMRB56_SET</a>   | RW          | Movable Region Boundary   |
| 0x2000 | <a href="#">SMU_IPVERSION_CLR</a>   | R           | IP Version                |
| 0x2004 | <a href="#">SMU_STATUS_CLR</a>      | RH          | Status Register           |
| 0x2008 | <a href="#">SMU_LOCK_CLR</a>        | W           | Lock Register             |
| 0x200C | <a href="#">SMU_IF_CLR</a>          | RWH INTFLAG | Interrupt Flag Register   |
| 0x2010 | <a href="#">SMU_IEN_CLR</a>         | RW          | Interrupt Enable Register |
| 0x2020 | <a href="#">SMU_M33CTRL_CLR</a>     | RW          | M33 Control Settings      |
| 0x2040 | <a href="#">SMU_PPUPATD0_CLR</a>    | RW          | Privileged Access         |
| 0x2044 | <a href="#">SMU_PPUPATD1_CLR</a>    | RW          | Privileged Access         |
| 0x2060 | <a href="#">SMU_PPUSATD0_CLR</a>    | RW          | Secure Access             |
| 0x2064 | <a href="#">SMU_PPUSATD1_CLR</a>    | RW          | Secure Access             |
| 0x2140 | <a href="#">SMU_PPUFS_CLR</a>       | RH          | Fault Status              |
| 0x2150 | <a href="#">SMU_BMPUPATD0_CLR</a>   | RW          | Privileged Attribute      |
| 0x2170 | <a href="#">SMU_BMPUSATD0_CLR</a>   | RW          | Secure Attribute          |
| 0x2250 | <a href="#">SMU_BMPUFS_CLR</a>      | RH          | Fault Status              |
| 0x2254 | <a href="#">SMU_BMPUFSADDR_CLR</a>  | RH          | Fault Status Address      |
| 0x2260 | <a href="#">SMU_ESAURTYPES0_CLR</a> | RW          | Region Types 0            |
| 0x2264 | <a href="#">SMU_ESAURTYPES1_CLR</a> | RW          | Region Types 1            |
| 0x2270 | <a href="#">SMU_ESAUMRB01_CLR</a>   | RW          | Movable Region Boundary   |
| 0x2274 | <a href="#">SMU_ESAUMRB12_CLR</a>   | RW          | Movable Region Boundary   |
| 0x2280 | <a href="#">SMU_ESAUMRB45_CLR</a>   | RW          | Movable Region Boundary   |
| 0x2284 | <a href="#">SMU_ESAUMRB56_CLR</a>   | RW          | Movable Region Boundary   |
| 0x3000 | <a href="#">SMU_IPVERSION_TGL</a>   | R           | IP Version                |
| 0x3004 | <a href="#">SMU_STATUS_TGL</a>      | RH          | Status Register           |
| 0x3008 | <a href="#">SMU_LOCK_TGL</a>        | W           | Lock Register             |
| 0x300C | <a href="#">SMU_IF_TGL</a>          | RWH INTFLAG | Interrupt Flag Register   |
| 0x3010 | <a href="#">SMU_IEN_TGL</a>         | RW          | Interrupt Enable Register |
| 0x3020 | <a href="#">SMU_M33CTRL_TGL</a>     | RW          | M33 Control Settings      |
| 0x3040 | <a href="#">SMU_PPUPATD0_TGL</a>    | RW          | Privileged Access         |
| 0x3044 | <a href="#">SMU_PPUPATD1_TGL</a>    | RW          | Privileged Access         |
| 0x3060 | <a href="#">SMU_PPUSATD0_TGL</a>    | RW          | Secure Access             |

| Offset | Name                                | Type | Description             |
|--------|-------------------------------------|------|-------------------------|
| 0x3064 | <a href="#">SMU_PPUSATD1_TGL</a>    | RW   | Secure Access           |
| 0x3140 | <a href="#">SMU_PPUFS_TGL</a>       | RH   | Fault Status            |
| 0x3150 | <a href="#">SMU_BMPUPATD0_TGL</a>   | RW   | Privileged Attribute    |
| 0x3170 | <a href="#">SMU_BMPUSATD0_TGL</a>   | RW   | Secure Attribute        |
| 0x3250 | <a href="#">SMU_BMPUFS_TGL</a>      | RH   | Fault Status            |
| 0x3254 | <a href="#">SMU_BMPUFSADDR_TGL</a>  | RH   | Fault Status Address    |
| 0x3260 | <a href="#">SMU_ESAURTYPES0_TGL</a> | RW   | Region Types 0          |
| 0x3264 | <a href="#">SMU_ESAURTYPES1_TGL</a> | RW   | Region Types 1          |
| 0x3270 | <a href="#">SMU_ESAUMRB01_TGL</a>   | RW   | Movable Region Boundary |
| 0x3274 | <a href="#">SMU_ESAUMRB12_TGL</a>   | RW   | Movable Region Boundary |
| 0x3280 | <a href="#">SMU_ESAUMRB45_TGL</a>   | RW   | Movable Region Boundary |
| 0x3284 | <a href="#">SMU_ESAUMRB56_TGL</a>   | RW   | Movable Region Boundary |

## 10.5 SMU Register Description

### 10.5.1 SMU\_IPVERSION - IP Version

| Offset | Bit Position |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Reset  | 0x3          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access | R            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | IPVERSION    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit  | Name      | Reset | Access | Description       |
|------|-----------|-------|--------|-------------------|
| 31:0 | IPVERSION | 0x3   | R      | <b>IP Version</b> |

The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION.

**10.5.2 SMU\_STATUS - Status Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x004  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2  | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1     | SMUPRGERR | 0x0   | R      | <b>SMU Programming Error</b>                                                                                                                                                      |
|       |           |       |        | Indicates if SMU Registers were programmed incorrectly.                                                                                                                           |
| 0     | SMULOCK   | 0x0   | R      | <b>SMU Lock</b>                                                                                                                                                                   |
|       |           |       |        | Indicates if SMU Registers are locked.                                                                                                                                            |
| Value | Mode      |       |        | Description                                                                                                                                                                       |
| 0     | UNLOCKED  |       |        |                                                                                                                                                                                   |
| 1     | LOCKED    |       |        |                                                                                                                                                                                   |

**10.5.3 SMU\_LOCK - Lock Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x008  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit      | Name       | Reset | Access | Description                                                                                                                                                                       |
|----------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24    | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:0     | SMULOCKKEY | 0x0   | W      |                                                                                                                                                                                   |
|          |            |       |        | Write anything but UNLOCK to lock registers.                                                                                                                                      |
| Value    | Mode       |       |        | Description                                                                                                                                                                       |
| 11325013 | UNLOCK     |       |        | Unlocks Registers                                                                                                                                                                 |

## 10.5.4 SMU\_IF - Interrupt Flag Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |         |     |     |    |    |    |    |    |    |    |    |   |   |     |    |         |    |     |         |    |     |  |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---------|-----|-----|----|----|----|----|----|----|----|----|---|---|-----|----|---------|----|-----|---------|----|-----|--|---|---|
| 0x00C  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 0x0 | 17      | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6 | 5 | 4   | 3  | 2       | 1  | 0   |         |    |     |  |   |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | 0x0     |     |     |    |    |    |    |    |    |    |    |   |   | 0x0 | 2  |         | 1  | 0   |         |    |     |  |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | RW      | 0x0 |     |    |    |    |    |    |    |    |    |   |   |     | RW | 0x0     |    | 1   | 0       |    |     |  |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | BMPUSEC | RW  | 0x0 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6  | 5       | 4  | 3   | PPUINST | RW | 0x0 |  | 1 | 0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | PPUSEC  | RW  | 0x0 |    |    |    |    |    |    |    |    |   |   |     |    | PPUPRIV | RW | 0x0 |         | 1  | 0   |  |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17    | BMPUSEC  | 0x0   | RW     | <b>BMPU Security Interrupt Flag</b><br>Triggered when a security fault occurs in the Bus Manager Protection Unit                                                                  |
| 16    | PPUSEC   | 0x0   | RW     | <b>PPU Security Interrupt Flag</b><br>Triggered when a security fault occurs in the Peripheral Protection Unit                                                                    |
| 15:3  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2     | PPUINST  | 0x0   | RW     | <b>PPU Instruction Interrupt Flag</b><br>Triggered when a instruction fault occurs in the Peripheral Protection Unit                                                              |
| 1     | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0     | PPUPRIV  | 0x0   | RW     | <b>PPU Privilege Interrupt Flag</b><br>Triggered when a privilege fault occurs in the Peripheral Protection Unit                                                                  |

## 10.5.5 SMU\_IEN - Interrupt Enable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |     |    |        |    |     |    |         |    |     |    |         |    |     |    |         |    |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|-----|----|--------|----|-----|----|---------|----|-----|----|---------|----|-----|----|---------|----|-----|---|
| 0x010  | 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  |         |    |     |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     | RW | 0x0 | RW | 0x0    | RW | 0x0 | RW | 0x0     | RW | 0x0 | RW | 0x0     | RW | 0x0 | RW | 0x0     | RW |     |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     | RW | 0x0 | RW | 0x0    | RW | 0x0 | RW | 0x0     | RW | 0x0 | RW | 0x0     | RW | 0x0 | RW | 0x0     | RW |     |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BMPUSEC | RW | 0x0 | 17 | PPUSEC | RW | 0x0 | 16 | PPUINST | RW | 0x0 | 2  | PPUPRIV | RW | 0x0 | 0  | PPUPRIV | RW | 0x0 | 0 |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17    | BMPUSEC  | 0x0   | RW     | <b>BMPU Security Interrupt Enable</b>                                                                                                                                             |
|       |          |       |        | Set to enable the BMPUSECIF Interrupt                                                                                                                                             |
| 16    | PPUSEC   | 0x0   | RW     | <b>PPU Security Interrupt Enable</b>                                                                                                                                              |
|       |          |       |        | Set to enable the PPUECIF Interrupt                                                                                                                                               |
| 15:3  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2     | PPUINST  | 0x0   | RW     | <b>PPU Instruction Interrupt Enable</b>                                                                                                                                           |
|       |          |       |        | Set to enable the PPUINSTIF Interrupt                                                                                                                                             |
| 1     | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0     | PPUPRIV  | 0x0   | RW     | <b>PPU Privilege Interrupt Enable</b>                                                                                                                                             |
|       |          |       |        | Set to enable the PPUPRIVIF Interrupt                                                                                                                                             |

## 10.5.6 SMU\_M33CTRL - M33 Control Settings

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |           |           |            |              |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|-----------|-----------|------------|--------------|
| 0x020         | 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         |            |              |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 4         |           |            |              |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW      | 0x0       |           |            |              |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LOCKSAU | LOCKNSMPU | LOCKNSMPU | LOCKNSVTOR | LOCKSVTAIRCR |

| Bit  | Name         | Reset | Access | Description                                                                                                                                                                       |
|------|--------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | LOCKSAU      | 0x0   | RW     | <b>New BitField</b><br><br>Set to 1 lock security attribution unit                                                                                                                |
| 3    | LOCKNSMPU    | 0x0   | RW     | <b>New BitField</b><br><br>Set to 1 lock non-secure MPU configuration                                                                                                             |
| 2    | LOCKSMPU     | 0x0   | RW     | <b>New BitField</b><br><br>Set to 1 lock secure MPU configuration                                                                                                                 |
| 1    | LOCKNSVTOR   | 0x0   | RW     | <b>New BitField</b><br><br>Set to 1 lock non-secure VTOR                                                                                                                          |
| 0    | LOCKSVTAIRCR | 0x0   | RW     | <b>New BitField</b><br><br>Set to 1 lock secure VTAIRCR                                                                                                                           |

#### **10.5.7 SMU\_PPUPATD0 - Privileged Access**

| Offset | Bit Position |        |     |    |
|--------|--------------|--------|-----|----|
| Name   | Reset        | Access |     |    |
| 0x040  | SYSRTC       | RW     | 0x1 | 31 |
|        | EUSART1      | RW     | 0x1 | 30 |
|        | HOSTMAILBOX  | RW     | 0x1 | 29 |
|        | DCDC         | RW     | 0x1 | 28 |
|        | GPCRC        | RW     | 0x1 | 27 |
|        | BURAM        | RW     | 0x1 | 26 |
|        | SYSCFG       | RW     | 0x1 | 25 |
|        | SYSCFGGCFGNS | RW     | 0x1 | 24 |
|        | CHIPTESTCTRL | RW     | 0x1 | 23 |
|        | I2C1         | RW     | 0x1 | 22 |
|        | BURTC        | RW     | 0x1 | 21 |
|        | USART0       | RW     | 0x1 | 20 |
|        | TIMER4       | RW     | 0x1 | 19 |
|        | TIMER3       | RW     | 0x1 | 18 |
|        | TIMER2       | RW     | 0x1 | 17 |
|        | TIMER1       | RW     | 0x1 | 16 |
|        | TIMER0       | RW     | 0x1 | 15 |
|        | LDMAXBAR     | RW     | 0x1 | 14 |
|        | LDMA         | RW     | 0x1 | 13 |
|        | GPIO         | RW     | 0x1 | 12 |
|        | PRS          | RW     | 0x1 | 11 |
|        | ICACHE0      | RW     | 0x1 | 10 |
|        | MSC          | RW     | 0x1 | 9  |
|        | ULFRCO       | RW     | 0x1 | 8  |
|        | LFRCO        | RW     | 0x1 | 7  |
|        | LFXO         | RW     | 0x1 | 6  |
|        | DPLL0        | RW     | 0x1 | 5  |
|        | FSRCO        | RW     | 0x1 | 4  |
|        | HFRCC00      | RW     | 0x1 | 3  |
|        | CMU          | RW     | 0x1 | 2  |
|        | EMU          | RW     | 0x1 | 1  |
|        |              |        |     | 0  |

| Bit | Name         | Reset | Access | Description                           |
|-----|--------------|-------|--------|---------------------------------------|
| 31  | SYSRTC       | 0x1   | RW     | <b>SYSRTC Privileged Access</b>       |
|     |              |       |        | SYSRTC Privileged Access              |
| 30  | EUSART1      | 0x1   | RW     | <b>EUSART1 Privileged Access</b>      |
|     |              |       |        | EUSART1 Privileged Access             |
| 29  | HOSTMAILBOX  | 0x1   | RW     | <b>HOSTMAILBOX Privileged Access</b>  |
|     |              |       |        | HOSTMAILBOX Privileged Access         |
| 28  | DCDC         | 0x1   | RW     | <b>DCDC Privileged Access</b>         |
|     |              |       |        | DCDC Privileged Access                |
| 27  | GPCRC        | 0x1   | RW     | <b>GPCRC Privileged Access</b>        |
|     |              |       |        | GPCRC Privileged Access               |
| 26  | BURAM        | 0x1   | RW     | <b>BURAM Privileged Access</b>        |
|     |              |       |        | BURAM Privileged Access               |
| 25  | SYSCFG       | 0x1   | RW     | <b>SYSCFG Privileged Access</b>       |
|     |              |       |        | SYSCFG Privileged Access              |
| 24  | SYSCFGCFGNS  | 0x1   | RW     | <b>SYSCFGCFGNS Privileged Access</b>  |
|     |              |       |        | SYSCFGCFGNS Privileged Access         |
| 23  | CHIPTESTCTRL | 0x1   | RW     | <b>CHIPTESTCTRL Privileged Access</b> |
|     |              |       |        | CHIPTESTCTRL Privileged Access        |
| 22  | I2C1         | 0x1   | RW     | <b>I2C1 Privileged Access</b>         |
|     |              |       |        | I2C1 Privileged Access                |
| 21  | BURTC        | 0x1   | RW     | <b>BURTC Privileged Access</b>        |
|     |              |       |        | BURTC Privileged Access               |
| 20  | USART0       | 0x1   | RW     | <b>USART0 Privileged Access</b>       |
|     |              |       |        | USART0 Privileged Access              |
| 19  | TIMER4       | 0x1   | RW     | <b>TIMER4 Privileged Access</b>       |
|     |              |       |        | TIMER4 Privileged Access              |
| 18  | TIMER3       | 0x1   | RW     | <b>TIMER3 Privileged Access</b>       |
|     |              |       |        | TIMER3 Privileged Access              |

| Bit | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-----|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | TIMER3 Privileged Access   |       |        |                                                                                                                                                                                   |
| 17  | TIMER2                     | 0x1   | RW     | <b>TIMER2 Privileged Access</b>                                                                                                                                                   |
|     | TIMER2 Privileged Access   |       |        |                                                                                                                                                                                   |
| 16  | TIMER1                     | 0x1   | RW     | <b>TIMER1 Privileged Access</b>                                                                                                                                                   |
|     | TIMER1 Privileged Access   |       |        |                                                                                                                                                                                   |
| 15  | TIMER0                     | 0x1   | RW     | <b>TIMER0 Privileged Access</b>                                                                                                                                                   |
|     | TIMER0 Privileged Access   |       |        |                                                                                                                                                                                   |
| 14  | LDMAXBAR                   | 0x1   | RW     | <b>LDMAXBAR Privileged Access</b>                                                                                                                                                 |
|     | LDMAXBAR Privileged Access |       |        |                                                                                                                                                                                   |
| 13  | LDMA                       | 0x1   | RW     | <b>LDMA Privileged Access</b>                                                                                                                                                     |
|     | LDMA Privileged Access     |       |        |                                                                                                                                                                                   |
| 12  | GPIO                       | 0x1   | RW     | <b>GPIO Privileged Access</b>                                                                                                                                                     |
|     | GPIO Privileged Access     |       |        |                                                                                                                                                                                   |
| 11  | PRS                        | 0x1   | RW     | <b>PRS Privileged Access</b>                                                                                                                                                      |
|     | PRS Privileged Access      |       |        |                                                                                                                                                                                   |
| 10  | ICACHE0                    | 0x1   | RW     | <b>ICACHE0 Privileged Access</b>                                                                                                                                                  |
|     | ICACHE0 Privileged Access  |       |        |                                                                                                                                                                                   |
| 9   | MSC                        | 0x1   | RW     | <b>MSC Privileged Access</b>                                                                                                                                                      |
|     | MSC Privileged Access      |       |        |                                                                                                                                                                                   |
| 8   | ULFRCO                     | 0x1   | RW     | <b>ULFRCO Privileged Access</b>                                                                                                                                                   |
|     | ULFRCO Privileged Access   |       |        |                                                                                                                                                                                   |
| 7   | LFRCO                      | 0x1   | RW     | <b>LFRCO Privileged Access</b>                                                                                                                                                    |
|     | LFRCO Privileged Access    |       |        |                                                                                                                                                                                   |
| 6   | LFXO                       | 0x1   | RW     | <b>LFXO Privileged Access</b>                                                                                                                                                     |
|     | LFXO Privileged Access     |       |        |                                                                                                                                                                                   |
| 5   | DPLL0                      | 0x1   | RW     | <b>DPLL0 Privileged Access</b>                                                                                                                                                    |
|     | DPLL0 Privileged Access    |       |        |                                                                                                                                                                                   |
| 4   | FSRCO                      | 0x1   | RW     | <b>FSRCO Privileged Access</b>                                                                                                                                                    |
|     | FSRCO Privileged Access    |       |        |                                                                                                                                                                                   |
| 3   | HFRCO0                     | 0x1   | RW     | <b>HFRCO0 Privileged Access</b>                                                                                                                                                   |
|     | HFRCO0 Privileged Access   |       |        |                                                                                                                                                                                   |
| 2   | CMU                        | 0x1   | RW     | <b>CMU Privileged Access</b>                                                                                                                                                      |
|     | CMU Privileged Access      |       |        |                                                                                                                                                                                   |
| 1   | EMU                        | 0x1   | RW     | <b>EMU Privileged Access</b>                                                                                                                                                      |
|     | EMU Privileged Access      |       |        |                                                                                                                                                                                   |
| 0   | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 10.5.8 SMU\_PPUPATD1 - Privileged Access

| Offset | Bit Position |                                                                                                                                                                                   |           |                                    |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------------------------|-------|-------|------|-------|--------|------|-------|-------|---------|-------|-------|-------|----------|----------|-----|----------|------|---------|----|----|----|----|----|----|----|----|---|---|
| Reset  | 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 |
| Access | RW           | RW                                                                                                                                                                                | RW        | RW                                 | RW    | RW    | RW   | RW    | RW     | RW   | RW    | RW    | RW      | RW    | RW    | RW    | RW       | RW       | RW  | RW       | RW   | RW      | RW | RW | RW | RW | RW | RW | RW | RW |   |   |
| Name   | AHBRADIO     | MVP                                                                                                                                                                               | SEMAILBOX | EUSART0                            | WDOG1 | WDOG0 | I2C0 | HFXO0 | HFRCO1 | PCNT | VDAC1 | VDAC0 | AMUXCP0 | ACMP1 | ACMP0 | IADC0 | LETIMER0 | SMUCFGNS | SMU | RADIOAES | DMEM | KEYSCAN | RW |   |   |
| 31:22  | Reserved     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |           |                                    |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 21     | AHBRADIO     | 0x1                                                                                                                                                                               | RW        | <b>AHBRADIO Privileged Access</b>  |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 20     | MVP          | 0x1                                                                                                                                                                               | RW        | <b>MVP Privileged Access</b>       |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 19     | SEMAILBOX    | 0x1                                                                                                                                                                               | RW        | <b>SEMAILBOX Privileged Access</b> |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 18     | EUSART0      | 0x1                                                                                                                                                                               | RW        | <b>EUSART0 Privileged Access</b>   |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 17     | WDOG1        | 0x1                                                                                                                                                                               | RW        | <b>WDOG1 Privileged Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 16     | WDOG0        | 0x1                                                                                                                                                                               | RW        | <b>WDOG0 Privileged Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 15     | I2C0         | 0x1                                                                                                                                                                               | RW        | <b>I2C0 Privileged Access</b>      |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 14     | HFXO0        | 0x1                                                                                                                                                                               | RW        | <b>HFXO0 Privileged Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 13     | HFRCO1       | 0x1                                                                                                                                                                               | RW        | <b>HFRCO1 Privileged Access</b>    |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 12     | PCNT         | 0x1                                                                                                                                                                               | RW        | <b>PCNT Privileged Access</b>      |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 11     | VDAC1        | 0x1                                                                                                                                                                               | RW        | <b>VDAC1 Privileged Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 10     | VDAC0        | 0x1                                                                                                                                                                               | RW        | <b>VDAC0 Privileged Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |
| 9      | AMUXCP0      | 0x1                                                                                                                                                                               | RW        | <b>AMUXCP0 Privileged Access</b>   |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |   |   |

| Bit   | Name      | Reset                                                                                                                                                                             | Access | Description                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:22 | Reserved  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21    | AHBRADIO  | 0x1                                                                                                                                                                               | RW     | <b>AHBRADIO Privileged Access</b>  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20    | MVP       | 0x1                                                                                                                                                                               | RW     | <b>MVP Privileged Access</b>       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19    | SEMAILBOX | 0x1                                                                                                                                                                               | RW     | <b>SEMAILBOX Privileged Access</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18    | EUSART0   | 0x1                                                                                                                                                                               | RW     | <b>EUSART0 Privileged Access</b>   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17    | WDOG1     | 0x1                                                                                                                                                                               | RW     | <b>WDOG1 Privileged Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16    | WDOG0     | 0x1                                                                                                                                                                               | RW     | <b>WDOG0 Privileged Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15    | I2C0      | 0x1                                                                                                                                                                               | RW     | <b>I2C0 Privileged Access</b>      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14    | HFXO0     | 0x1                                                                                                                                                                               | RW     | <b>HFXO0 Privileged Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13    | HFRCO1    | 0x1                                                                                                                                                                               | RW     | <b>HFRCO1 Privileged Access</b>    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12    | PCNT      | 0x1                                                                                                                                                                               | RW     | <b>PCNT Privileged Access</b>      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11    | VDAC1     | 0x1                                                                                                                                                                               | RW     | <b>VDAC1 Privileged Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10    | VDAC0     | 0x1                                                                                                                                                                               | RW     | <b>VDAC0 Privileged Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9     | AMUXCP0   | 0x1                                                                                                                                                                               | RW     | <b>AMUXCP0 Privileged Access</b>   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit | Name     | Reset | Access | Description                                                     |
|-----|----------|-------|--------|-----------------------------------------------------------------|
| 8   | ACMP1    | 0x1   | RW     | <b>ACMP1 Privileged Access</b><br>ACMP1 Privileged Access       |
| 7   | ACMP0    | 0x1   | RW     | <b>ACMP0 Privileged Access</b><br>ACMP0 Privileged Access       |
| 6   | IADC0    | 0x1   | RW     | <b>IADC0 Privileged Access</b><br>IADC0 Privileged Access       |
| 5   | LETIMER0 | 0x1   | RW     | <b>LETIMER0 Privileged Access</b><br>LETIMER0 Privileged Access |
| 4   | SMUCFGNS | 0x1   | RW     | <b>SMUCFGNS Privileged Access</b><br>SMUCFGNS Privileged Access |
| 3   | SMU      | 0x1   | RW     | <b>SMU Privileged Access</b><br>SMU Privileged Access           |
| 2   | RADIOAES | 0x1   | RW     | <b>RADIOAES Privileged Access</b><br>RADIOAES Privileged Access |
| 1   | DMEM     | 0x1   | RW     | <b>DMEM Privileged Access</b><br>DMEM Privileged Access         |
| 0   | KEYSCAN  | 0x1   | RW     | <b>KEYSCAN Privileged Access</b><br>KEYSCAN Privileged Access   |

### **10.5.9 SMU\_PPUSATD0 - Secure Access**

| Offset | Bit Position |        |     |    |
|--------|--------------|--------|-----|----|
| Name   | Reset        | Access |     |    |
| 0x060  | SYSRTC       | RW     | 0x1 | 31 |
|        | EUSART1      | RW     | 0x1 | 30 |
|        | HOSTMAILBOX  | RW     | 0x1 | 29 |
|        | DCDC         | RW     | 0x1 | 28 |
|        | GPCRC        | RW     | 0x1 | 27 |
|        | BURAM        | RW     | 0x1 | 26 |
|        | SYSCFG       | RW     | 0x1 | 25 |
|        | SYSCFGGCFGNS | RW     | 0x1 | 24 |
|        | CHIPTESTCTRL | RW     | 0x1 | 23 |
|        | I2C1         | RW     | 0x1 | 22 |
|        | BURTC        | RW     | 0x1 | 21 |
|        | USART0       | RW     | 0x1 | 20 |
|        | TIMER4       | RW     | 0x1 | 19 |
|        | TIMER3       | RW     | 0x1 | 18 |
|        | TIMER2       | RW     | 0x1 | 17 |
|        | TIMER1       | RW     | 0x1 | 16 |
|        | TIMER0       | RW     | 0x1 | 15 |
|        | LDMAXBAR     | RW     | 0x1 | 14 |
|        | LDMA         | RW     | 0x1 | 13 |
|        | GPIO         | RW     | 0x1 | 12 |
|        | PRS          | RW     | 0x1 | 11 |
|        | ICACHE0      | RW     | 0x1 | 10 |
|        | MSC          | RW     | 0x1 | 9  |
|        | ULFRCO       | RW     | 0x1 | 8  |
|        | LFRCO        | RW     | 0x1 | 7  |
|        | LFXO         | RW     | 0x1 | 6  |
|        | DPLL0        | RW     | 0x1 | 5  |
|        | FSRCO        | RW     | 0x1 | 4  |
|        | HFRCC00      | RW     | 0x1 | 3  |
|        | CMU          | RW     | 0x1 | 2  |
|        | EMU          | RW     | 0x1 | 1  |
|        |              |        |     | 0  |

| Bit | Name                       | Reset | Access | Description                       |
|-----|----------------------------|-------|--------|-----------------------------------|
| 31  | SYSRTC                     | 0x1   | RW     | <b>SYSRTC Secure Access</b>       |
|     | SYSRTC Secure Access       |       |        |                                   |
| 30  | EUSART1                    | 0x1   | RW     | <b>EUSART1 Secure Access</b>      |
|     | EUSART1 Secure Access      |       |        |                                   |
| 29  | HOSTMAILBOX                | 0x1   | RW     | <b>HOSTMAILBOX Secure Access</b>  |
|     | HOSTMAILBOX Secure Access  |       |        |                                   |
| 28  | DCDC                       | 0x1   | RW     | <b>DCDC Secure Access</b>         |
|     | DCDC Secure Access         |       |        |                                   |
| 27  | GPCRC                      | 0x1   | RW     | <b>GPCRC Secure Access</b>        |
|     | GPCRC Secure Access        |       |        |                                   |
| 26  | BURAM                      | 0x1   | RW     | <b>BURAM Secure Access</b>        |
|     | BURAM Secure Access        |       |        |                                   |
| 25  | SYSCFG                     | 0x1   | RW     | <b>SYSCFG Secure Access</b>       |
|     | SYSCFG Secure Access       |       |        |                                   |
| 24  | SYSCFGCFGNS                | 0x1   | RW     | <b>SYSCFGCFGNS Secure Access</b>  |
|     | SYSCFGCFGNS Secure Access  |       |        |                                   |
| 23  | CHIPTESTCTRL               | 0x1   | RW     | <b>CHIPTESTCTRL Secure Access</b> |
|     | CHIPTESTCTRL Secure Access |       |        |                                   |
| 22  | I2C1                       | 0x1   | RW     | <b>I2C1 Secure Access</b>         |
|     | I2C1 Secure Access         |       |        |                                   |
| 21  | BURTC                      | 0x1   | RW     | <b>BURTC Secure Access</b>        |
|     | BURTC Secure Access        |       |        |                                   |
| 20  | USART0                     | 0x1   | RW     | <b>USART0 Secure Access</b>       |
|     | USART0 Secure Access       |       |        |                                   |
| 19  | TIMER4                     | 0x1   | RW     | <b>TIMER4 Secure Access</b>       |
|     | TIMER4 Secure Access       |       |        |                                   |
| 18  | TIMER3                     | 0x1   | RW     | <b>TIMER3 Secure Access</b>       |
|     | TIMER3 Secure Access       |       |        |                                   |

| Bit | Name                   | Reset | Access | Description                                                                                                                                                                       |
|-----|------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | TIMER3 Secure Access   |       |        |                                                                                                                                                                                   |
| 17  | TIMER2                 | 0x1   | RW     | <b>TIMER2 Secure Access</b>                                                                                                                                                       |
|     | TIMER2 Secure Access   |       |        |                                                                                                                                                                                   |
| 16  | TIMER1                 | 0x1   | RW     | <b>TIMER1 Secure Access</b>                                                                                                                                                       |
|     | TIMER1 Secure Access   |       |        |                                                                                                                                                                                   |
| 15  | TIMER0                 | 0x1   | RW     | <b>TIMER0 Secure Access</b>                                                                                                                                                       |
|     | TIMER0 Secure Access   |       |        |                                                                                                                                                                                   |
| 14  | LDMAXBAR               | 0x1   | RW     | <b>LDMAXBAR Secure Access</b>                                                                                                                                                     |
|     | LDMAXBAR Secure Access |       |        |                                                                                                                                                                                   |
| 13  | LDMA                   | 0x1   | RW     | <b>LDMA Secure Access</b>                                                                                                                                                         |
|     | LDMA Secure Access     |       |        |                                                                                                                                                                                   |
| 12  | GPIO                   | 0x1   | RW     | <b>GPIO Secure Access</b>                                                                                                                                                         |
|     | GPIO Secure Access     |       |        |                                                                                                                                                                                   |
| 11  | PRS                    | 0x1   | RW     | <b>PRS Secure Access</b>                                                                                                                                                          |
|     | PRS Secure Access      |       |        |                                                                                                                                                                                   |
| 10  | ICACHE0                | 0x1   | RW     | <b>ICACHE0 Secure Access</b>                                                                                                                                                      |
|     | ICACHE0 Secure Access  |       |        |                                                                                                                                                                                   |
| 9   | MSC                    | 0x1   | RW     | <b>MSC Secure Access</b>                                                                                                                                                          |
|     | MSC Secure Access      |       |        |                                                                                                                                                                                   |
| 8   | ULFRCO                 | 0x1   | RW     | <b>ULFRCO Secure Access</b>                                                                                                                                                       |
|     | ULFRCO Secure Access   |       |        |                                                                                                                                                                                   |
| 7   | LFRCO                  | 0x1   | RW     | <b>LFRCO Secure Access</b>                                                                                                                                                        |
|     | LFRCO Secure Access    |       |        |                                                                                                                                                                                   |
| 6   | LFXO                   | 0x1   | RW     | <b>LFXO Secure Access</b>                                                                                                                                                         |
|     | LFXO Secure Access     |       |        |                                                                                                                                                                                   |
| 5   | DPLL0                  | 0x1   | RW     | <b>DPLL0 Secure Access</b>                                                                                                                                                        |
|     | DPLL0 Secure Access    |       |        |                                                                                                                                                                                   |
| 4   | FSRCO                  | 0x1   | RW     | <b>FSRCO Secure Access</b>                                                                                                                                                        |
|     | FSRCO Secure Access    |       |        |                                                                                                                                                                                   |
| 3   | HFRCO0                 | 0x1   | RW     | <b>HFRCO0 Secure Access</b>                                                                                                                                                       |
|     | HFRCO0 Secure Access   |       |        |                                                                                                                                                                                   |
| 2   | CMU                    | 0x1   | RW     | <b>CMU Secure Access</b>                                                                                                                                                          |
|     | CMU Secure Access      |       |        |                                                                                                                                                                                   |
| 1   | EMU                    | 0x1   | RW     | <b>EMU Secure Access</b>                                                                                                                                                          |
|     | EMU Secure Access      |       |        |                                                                                                                                                                                   |
| 0   | Reserved               |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 10.5.10 SMU\_PPUSATD1 - Secure Access

| Offset | Bit Position |                                                                                                                                                                                   |           |                                |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------------|-------|-------|------|-------|--------|------|-------|-------|---------|-------|-------|-------|----------|----------|-----|----------|------|---------|----|----|----|----|----|----|----|----|----|----|----|
| Reset  | 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  |    |
| Access | RW           | RW                                                                                                                                                                                | RW        | RW                             | RW    | RW    | RW   | RW    | RW     | RW   | RW    | RW    | RW      | RW    | RW    | RW    | RW       | RW       | RW  | RW       | RW   | RW      | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW |
| Name   | AHBRADIO     | MVP                                                                                                                                                                               | SEMAILBOX | EUSART0                        | WDOG1 | WDOG0 | I2C0 | HFXO0 | HFRCO1 | PCNT | VDAC1 | VDAC0 | AMUXCP0 | ACMP1 | ACMP0 | IADC0 | LETIMER0 | SMUCFGNS | SMU | RADIOAES | DMEM | KEYSCAN | RW |    |
| 31:22  | Reserved     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |           |                                |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 21     | AHBRADIO     | 0x1                                                                                                                                                                               | RW        | <b>AHBRADIO Secure Access</b>  |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 20     | MVP          | 0x1                                                                                                                                                                               | RW        | <b>MVP Secure Access</b>       |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 19     | SEMAILBOX    | 0x1                                                                                                                                                                               | RW        | <b>SEMAILBOX Secure Access</b> |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 18     | EUSART0      | 0x1                                                                                                                                                                               | RW        | <b>EUSART0 Secure Access</b>   |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 17     | WDOG1        | 0x1                                                                                                                                                                               | RW        | <b>WDOG1 Secure Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 16     | WDOG0        | 0x1                                                                                                                                                                               | RW        | <b>WDOG0 Secure Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 15     | I2C0         | 0x1                                                                                                                                                                               | RW        | <b>I2C0 Secure Access</b>      |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 14     | HFXO0        | 0x1                                                                                                                                                                               | RW        | <b>HFXO0 Secure Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 13     | HFRCO1       | 0x1                                                                                                                                                                               | RW        | <b>HFRCO1 Secure Access</b>    |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 12     | PCNT         | 0x1                                                                                                                                                                               | RW        | <b>PCNT Secure Access</b>      |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 11     | VDAC1        | 0x1                                                                                                                                                                               | RW        | <b>VDAC1 Secure Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 10     | VDAC0        | 0x1                                                                                                                                                                               | RW        | <b>VDAC0 Secure Access</b>     |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |
| 9      | AMUXCP0      | 0x1                                                                                                                                                                               | RW        | <b>AMUXCP0 Secure Access</b>   |       |       |      |       |        |      |       |       |         |       |       |       |          |          |     |          |      |         |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Name      | Reset                                                                                                                                                                             | Access | Description                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:22 | Reserved  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21    | AHBRADIO  | 0x1                                                                                                                                                                               | RW     | <b>AHBRADIO Secure Access</b>  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20    | MVP       | 0x1                                                                                                                                                                               | RW     | <b>MVP Secure Access</b>       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19    | SEMAILBOX | 0x1                                                                                                                                                                               | RW     | <b>SEMAILBOX Secure Access</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18    | EUSART0   | 0x1                                                                                                                                                                               | RW     | <b>EUSART0 Secure Access</b>   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17    | WDOG1     | 0x1                                                                                                                                                                               | RW     | <b>WDOG1 Secure Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16    | WDOG0     | 0x1                                                                                                                                                                               | RW     | <b>WDOG0 Secure Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15    | I2C0      | 0x1                                                                                                                                                                               | RW     | <b>I2C0 Secure Access</b>      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14    | HFXO0     | 0x1                                                                                                                                                                               | RW     | <b>HFXO0 Secure Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13    | HFRCO1    | 0x1                                                                                                                                                                               | RW     | <b>HFRCO1 Secure Access</b>    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12    | PCNT      | 0x1                                                                                                                                                                               | RW     | <b>PCNT Secure Access</b>      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11    | VDAC1     | 0x1                                                                                                                                                                               | RW     | <b>VDAC1 Secure Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10    | VDAC0     | 0x1                                                                                                                                                                               | RW     | <b>VDAC0 Secure Access</b>     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9     | AMUXCP0   | 0x1                                                                                                                                                                               | RW     | <b>AMUXCP0 Secure Access</b>   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit | Name                   | Reset | Access | Description                   |
|-----|------------------------|-------|--------|-------------------------------|
| 8   | ACMP1                  | 0x1   | RW     | <b>ACMP1 Secure Access</b>    |
|     | ACMP1 Secure Access    |       |        |                               |
| 7   | ACMP0                  | 0x1   | RW     | <b>ACMP0 Secure Access</b>    |
|     | ACMP0 Secure Access    |       |        |                               |
| 6   | IADC0                  | 0x1   | RW     | <b>IADC0 Secure Access</b>    |
|     | IADC0 Secure Access    |       |        |                               |
| 5   | LETIMER0               | 0x1   | RW     | <b>LETIMER0 Secure Access</b> |
|     | LETIMER0 Secure Access |       |        |                               |
| 4   | SMUCFGNS               | 0x1   | RW     | <b>SMUCFGNS Secure Access</b> |
|     | SMUCFGNS Secure Access |       |        |                               |
| 3   | SMU                    | 0x1   | RW     | <b>SMU Secure Access</b>      |
|     | SMU Secure Access      |       |        |                               |
| 2   | RADIOAES               | 0x1   | RW     | <b>RADIOAES Secure Access</b> |
|     | RADIOAES Secure Access |       |        |                               |
| 1   | DMEM                   | 0x1   | RW     | <b>DMEM Secure Access</b>     |
|     | DMEM Secure Access     |       |        |                               |
| 0   | KEYSCAN                | 0x1   | RW     | <b>KEYSCAN Secure Access</b>  |
|     | KEYSCAN Secure Access  |       |        |                               |

### **10.5.11 SMU\_PPUFS - Fault Status**

| Bit  | Name          | Reset | Access | Description                                                                                                                                                                       |
|------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | PPUFSPERIPHID | 0x0   | R      | <b>Peripheral ID</b><br>ID of the peripheral that caused the fault.                                                                                                               |

## 10.5.12 SMU\_BMPUPATD0 - Privileged Attribute

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Reset  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  |    |
| Access | RW           | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit  | Name                                    | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved                                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8    | SEEXTDMA                                | 0x0   | RW     | <b>SEEXTDMA privileged mode</b>                                                                                                                                                   |
|      | SEEXTDMA privileged mode                |       |        |                                                                                                                                                                                   |
| 7    | RFECA1                                  | 0x0   | RW     | <b>RFECA1 privileged mode</b>                                                                                                                                                     |
|      | RFECA1 privileged mode                  |       |        |                                                                                                                                                                                   |
| 6    | RFECA0                                  | 0x0   | RW     | <b>RFECA0 privileged mode</b>                                                                                                                                                     |
|      | RFECA0 privileged mode                  |       |        |                                                                                                                                                                                   |
| 5    | MVPAHBDATA2                             | 0x1   | RW     | <b>MVPAHBDATA2 privileged mode</b>                                                                                                                                                |
|      | MVPAHBDATA2 privileged mode             |       |        |                                                                                                                                                                                   |
| 4    | MVPAHBDATA1                             | 0x1   | RW     | <b>MVPAHBDATA1 privileged mode</b>                                                                                                                                                |
|      | MVPAHBDATA1 privileged mode             |       |        |                                                                                                                                                                                   |
| 3    | MVPAHBDATA0                             | 0x1   | RW     | <b>MVPAHBDATA0 privileged mode</b>                                                                                                                                                |
|      | MVPAHBDATA0 privileged mode             |       |        |                                                                                                                                                                                   |
| 2    | LDMA                                    | 0x1   | RW     | <b>MCU LDMA privileged mode</b>                                                                                                                                                   |
|      | MCU LDMA privileged mode                |       |        |                                                                                                                                                                                   |
| 1    | RADIOSUBSYSTEM                          | 0x1   | RW     | <b>RADIO subsystem manager privileged mode</b>                                                                                                                                    |
|      | RADIO subsystem manager privileged mode |       |        |                                                                                                                                                                                   |
| 0    | RADIOAES                                | 0x1   | RW     | <b>RADIO AES DMA privileged mode</b>                                                                                                                                              |
|      | RADIO AES DMA privileged mode           |       |        |                                                                                                                                                                                   |

## 10.5.13 SMU\_BMPUSATD0 - Secure Attribute

| Offset         | Bit Position |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|--------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Reset          | 31           | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access         |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| SEEXTDMA       | RW           | 0x0 | 8  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RFECA1         | RW           | 0x0 | 7  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RFECA0         | RW           | 0x0 | 6  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| MVPAHBDATA2    | RW           | 0x1 | 5  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| MVPAHBDATA1    | RW           | 0x1 | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| MVPAHBDATA0    | RW           | 0x1 | 3  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| LDMA           | RW           | 0x1 | 2  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RADIOSUBSYSTEM | RW           | 0x1 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RADIOAES       | RW           | 0x1 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit  | Name                                | Reset | Access | Description                                                                                                                                                       |
|------|-------------------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved                            |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 8    | SEEXTDMA                            | 0x0   | RW     | <b>SEEXTDMA secure mode</b>                                                                                                                                       |
|      | SEEXTDMA secure mode                |       |        |                                                                                                                                                                   |
| 7    | RFECA1                              | 0x0   | RW     | <b>RFECA1 secure mode</b>                                                                                                                                         |
|      | RFECA1 secure mode                  |       |        |                                                                                                                                                                   |
| 6    | RFECA0                              | 0x0   | RW     | <b>RFECA0 secure mode</b>                                                                                                                                         |
|      | RFECA0 secure mode                  |       |        |                                                                                                                                                                   |
| 5    | MVPAHBDATA2                         | 0x1   | RW     | <b>MVPAHBDATA2 secure mode</b>                                                                                                                                    |
|      | MVPAHBDATA2 secure mode             |       |        |                                                                                                                                                                   |
| 4    | MVPAHBDATA1                         | 0x1   | RW     | <b>MVPAHBDATA1 secure mode</b>                                                                                                                                    |
|      | MVPAHBDATA1 secure mode             |       |        |                                                                                                                                                                   |
| 3    | MVPAHBDATA0                         | 0x1   | RW     | <b>MVPAHBDATA0 secure mode</b>                                                                                                                                    |
|      | MVPAHBDATA0 secure mode             |       |        |                                                                                                                                                                   |
| 2    | LDMA                                | 0x1   | RW     | <b>MCU LDMA secure mode</b>                                                                                                                                       |
|      | MCU LDMA secure mode                |       |        |                                                                                                                                                                   |
| 1    | RADIOSUBSYSTEM                      | 0x1   | RW     | <b>RADIO subsystem manager secure mode</b>                                                                                                                        |
|      | RADIO subsystem manager secure mode |       |        |                                                                                                                                                                   |
| 0    | RADIOAES                            | 0x1   | RW     | <b>RADIOAES DMA secure mode</b>                                                                                                                                   |
|      | RADIOAES DMA secure mode            |       |        |                                                                                                                                                                   |

## 10.5.14 SMU\_BMPUFS - Fault Status

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |                |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|----------------|---|---|---|---|
| 0x250  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0            |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | R              |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | BMPUFSMASTERID |   |   |   |   |

| Bit  | Name           | Reset | Access | Description                                                                                                                                                                       |
|------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | BMPUFSMASTERID | 0x0   | R      | <b>Bus Manager ID</b><br><br>ID of Bus Manager that triggered fault                                                                                                               |

## 10.5.15 SMU\_BMPUFSADDR - Fault Status Address

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |            |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|------------|---|---|---|---|
| 0x254  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0        |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | R          |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | BMPUFSADDR |   |   |   |   |

| Bit  | Name       | Reset | Access | Description                                                     |
|------|------------|-------|--------|-----------------------------------------------------------------|
| 31:0 | BMPUFSADDR | 0x0   | R      | <b>Fault Address</b><br><br>Access address that triggered fault |

#### **10.5.16 SMU\_ESAURTYPES0 - Region Types 0**

| Bit   | Name     | Reset                                        | Access | Description                                                                                                                                                                       |
|-------|----------|----------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | Reserved |                                              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | ESAUR3NS | 0x0                                          | RW     | <b>Region 3 Non-Secure</b>                                                                                                                                                        |
|       |          | Set to 1 to configure Region 3 as Non-secure |        |                                                                                                                                                                                   |
| 11:0  | Reserved |                                              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

#### **10.5.17 SMU\_ESAURTYPES1 - Region Types 1**

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | ESAUR11NS | 0x0   | RW     | <b>Region 11 Non-Secure</b>                                                                                                                                                       |
|       |           |       |        | Set to 1 to configure Region 11 as Non-secure                                                                                                                                     |
| 11:0  | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**10.5.18 SMU\_ESAUMRB01 - Movable Region Boundary**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x270  | 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 |
| Reset  | 0xA000       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name       | Reset  | Access | Description                                                                                                                                                                       |
|-------|------------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved   |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:12 | ESAUMLRB01 | 0xA000 | RW     | <b>Moveable Region Boundary</b><br><br>Moveable Region Boundary between Region 0 and Region 1. Address Represents the start of Region 1 at a 4kB offset.                          |
| 11:0  | Reserved   |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**10.5.19 SMU\_ESAUMRB12 - Movable Region Boundary**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x274  | 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 |
| Reset  | 0xC000       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name       | Reset  | Access | Description                                                                                                                                                                       |
|-------|------------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved   |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:12 | ESAUMLRB12 | 0xC000 | RW     | <b>Moveable Region Boundary</b><br><br>Moveable Region Boundary between Region 1 and Region 2. Address Represents the start of Region 2 at a 4kB offset.                          |
| 11:0  | Reserved   |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**10.5.20 SMU\_ESAUMRB45 - Movable Region Boundary**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x280  | 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 |
| Reset  | 0x2000       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | ESAUMRB45    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name      | Reset  | Access | Description                                                                                                                                                                       |
|-------|-----------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved  |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:12 | ESAUMRB45 | 0x2000 | RW     | <b>Moveable Region Boundary</b><br><br>Moveable Region Boundary between Regions 4 and 5. This represents the starting address of Region 5.                                        |
| 11:0  | Reserved  |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**10.5.21 SMU\_ESAUMRB56 - Movable Region Boundary**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x284  | 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 |
| Reset  | 0x4000       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | ESAUMRB56    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name      | Reset  | Access | Description                                                                                                                                                                       |
|-------|-----------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved  |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:12 | ESAUMRB56 | 0x4000 | RW     | <b>Moveable Region Boundary</b><br><br>Moveable Region Boundary between Regions 5 and 6. This represents the starting address of Region 6.                                        |
| 11:0  | Reserved  |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 11. SE - Secure Engine Subsystem



| Quick Facts                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b>                                                                                                                                                                                                                                                |
| The Secure Engine Subsystem encapsulates security peripherals providing both improved system security and ease of use.                                                                                                                                      |
| <b>Why?</b>                                                                                                                                                                                                                                                 |
| Isolation of security hardware from the Cortex®-M33 protects the SE system from exploits that target the main CPU. The subsystem also provides autonomous cryptographic operations allowing the main CPU to perform other tasks or enter EM1 to save power. |
| <b>How?</b>                                                                                                                                                                                                                                                 |
| Security peripherals are completely isolated from the main CPU and controlled with a processor internal to the SE subsystem.                                                                                                                                |

### 11.1 Introduction

The Secure Engine (SE) provides several security features and acts as a barrier protecting the security hardware from activity on the Cortex®-M33. It also enables autonomous operation of security features.

Available features include:

- Secure Boot with Root of Trust and Secure Loader (RTSL)
- Hardware Cryptographic Acceleration with DPA countermeasures for AES128/256, SHA-1, SHA-2 (up to 256-bit), ECC (up to 256-bit), ECDSA, ECDH and J-Pake
- True Random Number Generator (TRNG) compliant with NIST SP800-90 and AIS-31
- ARM® TrustZone®
- Secure Debug with lock/unlock

All Secure Engine functions are enabled by software. These functions are fully described in the Secure Engine emlib online documentation located at the following link:

<https://docs.silabs.com/mcu/latest/efr32mg21/group-SE>

### 11.2 Security Features

#### 11.2.1 Security Features Overview

- Acceleration of cryptographic functions
  - AES encryption and decryption with 128, 192, or 256-bit keys
  - Supported block cipher modes of operation for AES include: ECB, CTR, CBC, CFB, CBC-MAC, CMAC, CCM, GCM and GMAC.
  - ECC over GF(P) up to 256-bit
  - Supported ECC NIST recommended curves include P-192 and P-256
  - SHA-1 and SHA-2 up to 256-bit
- True Random Number Generation
  - Entropy Source complies to NIST 800-90B requirements
  - Online Health tests comply to NIST 800-90 and AIS31 requirements
  - Random Data Passes NIST 800-22 and NIST 800-90B test suites
- Secure Boot Loader (First Stage Boot Loader)

### 11.2.2 Secure Boot with Root of Trust and Secure Loader (RTSL)

The Secure Boot with RTSL authenticates a chain of trusted firmware that begins from an immutable memory (ROM).

It prevents malware injection, prevents rollback, ensures that only authentic firmware is executed, and protects Over The Air updates.

For more information about this feature, see [AN1218: Series 2 Secure Boot with RTSL](#).

### 11.2.3 Secure Debug

The SE provides a secure debug unlock function that allows users to grant debug access to locked devices on a device by device basis. To use this function the device must be programmed with a public Command key by the user. To unlock a device, a unique challenge (a device-unique persistent random set of bytes) must be read out and signed by the private key associated with public Command key creating an unlock token. The device can then be unlocked by providing the valid unlock token. The token can be used to unlock the device any number of times. There is also a command to force the device to update its challenge, which revokes the previously-generated token.

More information on Secure Debug can be found in the [AN1190: Secure Debug](#) application note.

**Note:** Secure debug locking a device will limit the capability for Silicon Labs to perform failure analysis on the device. Provide secure debug tokens for each device when submitting parts for failure analysis.

### 11.2.4 Cryptographic Accelerator

The Cryptographic Accelerator is an autonomous hardware accelerator with Differential Power Analysis (DPA) countermeasures to protect keys.

It supports AES encryption and decryption with 128/192/256-bit keys, ChaCha20 encryption, and Elliptic Curve Cryptography (ECC) to support public key operations, and hashes.

Supported block cipher modes of operation for AES include:

- ECB (Electronic Code Book)
- CTR (Counter Mode)
- CBC (Cipher Block Chaining)
- CFB (Cipher Feedback)
- GCM (Galois Counter Mode)
- CCM (Counter with CBC-MAC)
- CBC-MAC (Cipher Block Chaining Message Authentication Code)
- GMAC (Galois Message Authentication Code)

The Cryptographic Accelerator accelerates Elliptical Curve Cryptography and supports the NIST (National Institute of Standards and Technology) recommended curves including P-192, P-256, P-384, and P-521 for ECDH (Elliptic Curve Diffie-Hellman) key derivation, and ECDSA (Elliptic Curve Digital Signature Algorithm) sign and verify operations. Also supported is the non-NIST Curve25519 for ECDH and Ed25519 for EdDSA (Edwards-curve Digital Signature Algorithm) sign and verify operations.

Secure Vault also supports ECJ-PAKE (Elliptic Curve variant of Password Authenticated Key Exchange by Juggling) and PBKDF2 (Password-Based Key Derivation Function 2).

Supported hashes include SHA-1, SHA-2/256/384/512 and Poly1305.

This implementation provides a fast and energy efficient solution to state of the art cryptographic needs.

### 11.2.5 True Random Number Generation

The SE provides access to a non-deterministic random number generator based on a full hardware solution. The TRNG output passes the NIST 800-22 and AIS31 test suites. The TRNG module includes several built-in self tests to detect issues with the noise source, ensure entropy, and meet cryptography standards. The Repetition Count Test and Adaptive Proportion Test with window sizes of 64 and 4096 bits described in section 6.5.1.2 of NIST-800-90B are implemented in hardware and run continuously on the data.

<http://csrc.nist.gov/publications/drafts/800-90/draft-sp800-90b.pdf>

The AIS31 Online Test described in section 5.5.3 of AIS 31 is also implemented in hardware, and runs continuously on the data.

[https://www.bsi.bund.de/SharedDocs/Downloads/DE/BSI/Zertifizierung/Interpretationen/AIS\\_31\\_Functionality\\_classes\\_for\\_random\\_number\\_generators\\_e.pdf](https://www.bsi.bund.de/SharedDocs/Downloads/DE/BSI/Zertifizierung/Interpretationen/AIS_31_Functionality_classes_for_random_number_generators_e.pdf)

### 11.3 SE Mailbox

All communication with the Secure Engine Subsystem takes place through the SE Mailbox. Operations are performed by using the mailbox to sending a command and then receive the SE response. The mailbox is a bidirectional 64 word FIFO.

#### 11.3.1 Sending Commands

The TX FIFO has two status flags in SE\_TX\_STATUS register. TXFULL is set when the FIFO is full and TXINT is set if there is space in the FIFO for at least 16 words. If TXINTEN in SE\_CONFIGURATION is set an interrupt will be generated when TXINT is set.

Writing to any SE\_DATA<sub>n</sub> register will result in data being placed in the FIFO. For example, to write 16 words to the FIFO software may write SE\_DATA0 16 times, or may make a single write to each of the 16 SE\_DATA<sub>n</sub> registers. If the FIFO is written when no space is available, the CPU will be stalled until spaces becomes available and the write can be completed.

To send a command, first check TXINT to ensure that there is space available in the FIFO. Then write SE\_TX\_HEADER with the command length and protection bit. Finally, write the command data into the SE\_DATA<sub>n</sub> registers. While the command is being written, BYTERM in SE\_TX\_STATUS will contain the number of bytes remaining in the command. To ensure minimal performance impact, software should ensure that space exists in the FIFO before writing to it.

#### 11.3.2 Receiving Responses

The RX FIFO has two status flags in SE\_RX\_STATUS register. RXEMPTY is set when the FIFO is empty and RXINT is set if there are at least 4 words in the FIFO or if the final word of the message is present in the FIFO. If RXINTEN in SE\_CONFIGURATION is set, an interrupt will be generated when RXINT is set.

Reading from any SE\_DATA<sub>n</sub> register will result in data being read from the FIFO. For example, to read 16 words from the FIFO, software may read SE\_DATA0 16 times, or may make a single read from each of the 16 SE\_DATA<sub>n</sub> registers. If the FIFO is read when it is empty and no message is available, a 0x0 will be read. If the FIFO is read when empty and a message is being processed, the CPU will be stalled until data becomes available.

Software may check for responses by polling RXINT, RXEMPTY, or RXHEADER in SE\_RX\_STATUS. The RXINT interrupt may also be used to notify the CPU when data is available. To receive a response first read the response header from SE\_RX\_HEADER. Software may read the message size from SE\_RX\_HEADER, or use BYTERM in SE\_RX\_STATUS, which contains the number of words remaining in the response.

The command status is available in both SE\_RX\_STATUS and SE\_RX\_HEADER and indicates if the command completed successfully.

#### 11.3.3 MAILBOX Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type       | Description               |
|--------|---------------------|------------|---------------------------|
| 0x000  | MAILBOX_MSGPTRx     | RW         | Message Pointer           |
| 0x040  | MAILBOX_IF          | RW INTFLAG | Interrupt Flag Register   |
| 0x044  | MAILBOX_IEN         | RW         | Interrupt Enable Register |
| 0x1000 | MAILBOX_MSGPTRx_SET | RW         | Message Pointer           |
| 0x1040 | MAILBOX_IF_SET      | RW INTFLAG | Interrupt Flag Register   |
| 0x1044 | MAILBOX_IEN_SET     | RW         | Interrupt Enable Register |
| 0x2000 | MAILBOX_MSGPTRx_CLR | RW         | Message Pointer           |
| 0x2040 | MAILBOX_IF_CLR      | RW INTFLAG | Interrupt Flag Register   |
| 0x2044 | MAILBOX_IEN_CLR     | RW         | Interrupt Enable Register |
| 0x3000 | MAILBOX_MSGPTRx_TGL | RW         | Message Pointer           |
| 0x3040 | MAILBOX_IF_TGL      | RW INTFLAG | Interrupt Flag Register   |
| 0x3044 | MAILBOX_IEN_TGL     | RW         | Interrupt Enable Register |

#### 11.3.4 MAILBOX Register Description

#### 11.3.4.1 MAILBOX\_MSGPTRx - Message Pointer

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | PTR          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0x000  | 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                                | Name | Reset | Access | Description    |
|------------------------------------|------|-------|--------|----------------|
| 31:0                               | PTR  | 0x0   | RW     | <b>Pointer</b> |
| The Memory Address of the message. |      |       |        |                |

#### 11.3.4.2 MAILBOX\_IF - Interrupt Flag Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3    | MBOXIF3  | 0x0   | RW     | <b>Mailbox Interrupt Flag</b><br>When set, Mailbox Message Available.                                                                                                             |
| 2    | MBOXIF2  | 0x0   | RW     | <b>Mailbox Interrupt Flag</b><br>When set, Mailbox Message Available.                                                                                                             |
| 1    | MBOXIF1  | 0x0   | RW     | <b>Mailbox Interrupt Flag</b><br>When set, Mailbox Message Available.                                                                                                             |
| 0    | MBOXIF0  | 0x0   | RW     | <b>Mailbox Interrupt Flag</b><br>When set, Mailbox Message Available.                                                                                                             |

## 11.3.4.3 MAILBOX\_IEN - Interrupt Enable Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|
| 0x044         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3    | MBOXIEN3        | 0x0   | RW     | <b>Mailbox Interrupt Enable</b><br><br>Set to enable the MBOXIF Interrupt                                                                                                         |
| 2    | MBOXIEN2        | 0x0   | RW     | <b>Mailbox Interrupt Enable</b><br><br>Set to enable the MBOXIF Interrupt                                                                                                         |
| 1    | MBOXIEN1        | 0x0   | RW     | <b>Mailbox Interrupt Enable</b><br><br>Set to enable the MBOXIF Interrupt                                                                                                         |
| 0    | MBOXIEN0        | 0x0   | RW     | <b>Mailbox Interrupt Enable</b><br><br>Set to enable the MBOXIF Interrupt                                                                                                         |

## 12. EMU - Energy Management Unit



### Quick Facts

#### What?

The EMU (Energy Management Unit) handles the different low energy modes in EFR32xG24

#### Why?

The need for performance and peripheral functions varies over time in most applications. By efficiently scaling the available resources in real time to match the demands of the application, the energy consumption can be kept at a minimum.

#### How?

With a broad selection of energy modes, a high number of low-energy peripherals available even in EM2, and short wake-up time, applications can dynamically minimize energy consumption during program execution.

### 12.1 Introduction

The Energy Management Unit (EMU) manages all the low energy modes (EM) in EFR32xG24. Each energy mode manages whether the CPU and the various peripherals are available. The energy modes range from EM0 to EM4. EM0 mode provides the highest amount of features, enabling the CPU, Radio, and peripherals with the highest clock frequency. EM4 Mode provides the lowest power state, allowing the part to return to EM0 on a wake-up condition. The EMU also controls the internal regulators settings and voltage monitoring needed for optimal power configuration and protection.

## 12.2 Features

The primary features of the EMU are listed below:

- Energy Modes control
  - Entry into EM4
  - Configuration of regulators and clocks for each Energy Mode
  - Configuration of various EM4 wake-up conditions
  - Configuration of GPIO retention settings
- Power routing configurations
  - DCDC control and bypass
- Temperature sensor
- Brown Out Detection
- Supply voltage scaling
  - EM0 / EM1 voltage scaling
  - EM2 / EM3 voltage scaling
- Reset Management
  - Power-on Reset (POR)
  - Brown-out Detection (BOD) on the following power domains:
    - Analog Unregulated Power Domain AVDD
    - Digital Unregulated Power Domain DVDD
    - I/O Unregulated Power Domain IOVDDx
    - Regulated Digital Domain DECOUPLE (DEC)
  - RESETn pin reset
  - Watchdog (WDOG) reset
  - Software triggered reset (SYSRESETREQ)
  - Core LOCKUP condition
  - EM4 Detection
  - EM4 wakeup reset from GPIO pin
  - Configurable reset levels
  - A software readable register indicates the cause of the last reset

### 12.3 Functional Description

The EMU is responsible for managing the wide range of energy modes available in EFR32xG24. The block works in harmony with the entire platform to easily transition between energy modes in the most efficient manner possible. The following diagram [Figure 12.1 EMU Overview on page 290](#), shows the relative connectivity to the various blocks in the system.



**Figure 12.1. EMU Overview**

The EMU is available on the peripheral bus. The energy management state machine controls the internal voltage regulators, oscillators, memories, and interrupt system. Events, interrupts, and resets can trigger the energy management state machine to return to the active state. This is further described in the following sections.

### 12.3.1 Energy Modes

EFR32xG24 features five main energy modes, referred to as Energy Mode 0 (EM0) through Energy Mode 4 (EM4). The Cortex®-M33 is only available for program execution in EM0. In EM0 Active/EM1 Sleep any peripheral function can be enabled. EM2 through EM4, also referred to as low energy modes, provide a significantly reduced energy consumption while still allowing a rich set of peripheral functionality. The following [Table 12.1 table on page 291](#) shows the possible transitions between different energy modes.

**Table 12.1. Energy Mode Transitions**

| Current Mode | EM Transition Action |                                     |                                      |                                      |           |
|--------------|----------------------|-------------------------------------|--------------------------------------|--------------------------------------|-----------|
|              | Enter EM0            | Enter EM1                           | Enter EM2                            | Enter EM3                            | Enter EM4 |
| EM0          |                      | Sleep (WFI, WFE)                    | Deep Sleep (WFI, WFE)                | Deep Sleep (WFI, WFE)                | EM4 Entry |
| EM1          | IRQ                  |                                     | Peripheral wake up done <sup>1</sup> | Peripheral wake up done <sup>1</sup> |           |
| EM2          | IRQ                  | Peripheral wake up req <sup>1</sup> |                                      |                                      |           |
| EM3          | IRQ                  | Peripheral wake up req <sup>1</sup> |                                      |                                      |           |
| EM4          | Wake Up              |                                     |                                      |                                      |           |

**Note:**

1. Peripheral wake-up from EM2/3 to EM1 and then automatically back to EM2/3 when done.

Certain peripherals and timers in the radio subsystem have the ability to temporarily turn on additional logic in EM2 or EM3 to receive and transmit data or trigger LDMA transfers without intervention from the M33 core. The system automatically returns to the original energy mode when such operations are complete.

The Core can always request to go to EM1 with the WFI or WFE command during EM0. The core will be prevented from entering EM2 or EM3 if the radio is transferring data or if flash is programming or erasing.

An overview of supported energy modes and available functionality is shown in the following table. For each energy mode, the system will typically default to its lowest power configuration, with non-essential clocks and peripherals disabled. Functionality may be then selectively enabled by software.

Modules with EM2/3/4 capability exist in a Low Power Domain (e.g., PD0x or PDHV). Refer to [12.3.4 Power Domains](#) for more details.

**Table 12.2. Energy Modes**

|                                                                                | EM0 / EM1 | EM2 / EM3              | EM4 | Low Power Domain |
|--------------------------------------------------------------------------------|-----------|------------------------|-----|------------------|
| Cortex®-M33 Core Active                                                        | EM0 only  | -                      | -   | -                |
| Debug                                                                          | Available | Available <sup>1</sup> | -   | PD0D             |
| Digital logic and system RAM retained                                          | Yes       | Yes                    | -   | -                |
| Flash Memory Access                                                            | Available | -                      | -   | -                |
| LDMA (Linked DMA Controller)                                                   | Available | Available <sup>2</sup> | -   | -                |
| Radio Controller (RAC)                                                         | Available | Available <sup>3</sup> | -   | -                |
| High Frequency Clocks (BUSCLK, HCLK, PCLK, RA-DIOCLK, EM01GRPACLK, EM01RPCCLK) | Available | -                      | -   | -                |

|                                                                             | EM0 / EM1 | EM2 / EM3              | EM4                    | Low Power Domain                            |
|-----------------------------------------------------------------------------|-----------|------------------------|------------------------|---------------------------------------------|
| High Frequency Oscillator (HFXO)                                            | Available | -                      | -                      | PD0C                                        |
| High Frequency RC Oscillator (HFRCODPLL)                                    | Available | -                      | -                      | -                                           |
| ADC Clock (IADCCLK), VDAC0 Clock (VDAC0CLK), and VDAC1 Clock (VDAC1CLK)     | Available | Available <sup>4</sup> | -                      | -                                           |
| EM2/3 High Frequency RC Oscillator (HFRCOEM23)                              | Available | Available <sup>4</sup> | -                      | PD0C                                        |
| Fast Start-up RC Oscillator (FSRCO)                                         | Available | Available <sup>4</sup> | -                      | PD0A                                        |
| Low Frequency RC Oscillators (LFRCO)                                        | Available | EM2 Only               | Available <sup>5</sup> | PDHV (normal mode) or PD0C (precision mode) |
| Low Frequency Crystal Oscillator (LFXO)                                     | Available | EM2 Only               | Available <sup>5</sup> | PDHV                                        |
| Low Energy Clocks (EM23GRPACLK, WDOGnCLK, SYSRTCCCLK, PCNT0CLK, EUSART0CLK) | Available | Available <sup>6</sup> | -                      | -                                           |
| EM4 Clock (EM4GRPACLK)                                                      | Available | Available <sup>6</sup> | Available <sup>5</sup> | -                                           |
| ULFRCO (Ultra Low Frequency Oscillator)                                     | On        | On                     | Available <sup>5</sup> | PDHV                                        |
| GPCRC ( General Purpose Cyclic Redundancy Check)                            | Available | -                      | -                      | -                                           |
| BURTC                                                                       | Available | Available <sup>6</sup> | Available              | PDHV                                        |
| SYSRTC                                                                      | Available | Available <sup>6</sup> | -                      | PD0A                                        |
| BURAM                                                                       | Available | Available              | Available              | PDHV                                        |
| MVP                                                                         | Available | -                      | -                      | -                                           |
| USART (UART/SPI)                                                            | Available | -                      | -                      | -                                           |
| I <sup>2</sup> C0                                                           | Available | Available <sup>8</sup> | -                      | PD0D                                        |
| I <sup>2</sup> C1                                                           | Available | -                      | -                      | -                                           |
| EUSART0                                                                     | Available | Available <sup>9</sup> | -                      | PD0D                                        |
| EUSART1                                                                     | Available | -                      | -                      | -                                           |
| TIMER (Timer/Counter)                                                       | Available | -                      | -                      | -                                           |
| LETIMER (Low Energy Timer)                                                  | Available | Available <sup>6</sup> | -                      | PD0B                                        |
| WDOG (Watchdog)                                                             | Available | Available <sup>6</sup> | -                      | PD0D                                        |
| ACMP (Analog Comparator)                                                    | Available | Available <sup>7</sup> | -                      | PD0B                                        |
| IADC (Analog to Digital Converter)                                          | Available | Available <sup>2</sup> | -                      | PD0B                                        |
| VDAC (Digital-to-Analog Converter)                                          | Available | Available <sup>2</sup> | -                      | PD0B                                        |

|                                 | <b>EM0 / EM1</b> | <b>EM2 / EM3</b>        | <b>EM4</b>              | <b>Low Power Domain</b> |
|---------------------------------|------------------|-------------------------|-------------------------|-------------------------|
| PCNT (Pulse Counter)            | Available        | Available <sup>2</sup>  | -                       | PD0B                    |
| KEYSCAN                         | Available        | Available <sup>10</sup> | -                       | PD0E                    |
| DC-DC                           | Available        | Available               | -                       | PD0A                    |
| EMU Temperature Sensor          | Available        | Available               | -                       | PD0A                    |
| Brown-Out Detect/Power-on Reset | Available        | Available               | Available               | -                       |
| Pin Reset                       | Available        | Available               | Available               | -                       |
| PRS (Peripheral Reflex System)  | Available        | Available               | -                       | PD0E                    |
| GPIO Pin Interrupts             | Available        | Available               | Available <sup>11</sup> | -                       |
| GPIO Pin State Retention        | Yes              | Yes                     | Available <sup>12</sup> | -                       |

**Note:**

1. Leaving the debugger connected when in EM2 or EM3 will cause the system to enter a higher power EM2 mode in which the high frequency clocks are still enabled and certain core functionality is still powered-up in order to maintain debug-functionality.
2. The LDMA can be used with some low power peripherals (e.g., IADC) in EM2/3. Features required by the LDMA which are not supported in EM2/3 (e.g., HCLK), will be automatically enabled prior to the LDMA transfer and then automatically disabled afterwards.
3. EM2 Only. The RAC can be woken via a PRS interrupt to EM1 to transfer data. Once complete, the system will return to EM2.
4. Default off, but kept active if used by the IADC or VDAC.
5. Default off, but kept active if used by the BURTC
6. Must use ULFRCO in EM3 (LFRCO & LFXO not available in EM3)
7. ACMP functionality in EM2/3 limited to edge interrupt
8. I2C functionality limited to receive address recognition in EM2/3. Not supported on all GPIO Ports.
9. EUSART functionality limited to low-frequency UART or SPI secondary in EM2/3. Not supported on all GPIO Ports.
10. Wake on any key press supported in EM2/3. Full key scanning operates in EM0/1.
11. Pin wake-up in EM4 supported only on GPIO\_EM4WUx pins. Consult data sheet for complete list of pins.
12. If enabled in EMU->EM4CTRL.EM4IORETMODE.

The different energy modes are summarized in the following sections.

### 12.3.1.1 EM0

EM0 provides all system features.

- Cortex®-M33 is executing code
- Radio functionality is available
- High and low frequency clock trees are active
- All oscillators are available
- All peripheral functionality is available

### 12.3.1.2 EM1

EM1 disables the core but leaves the remaining system fully available.

- Cortex®-M33 is in sleep mode. Clocks to the core are off
- Radio functionality is available
- High and low frequency clock trees are active
- All oscillators are available
- All peripheral functionality is available

### 12.3.1.3 EM1P

EM1P is a subset of EM1 which allows the radio to operate while the core and high-speed peripherals are shut down to save energy. It is entered when the radio is active and software requests to enter EM2.

- Cortex®-M33 is in sleep mode. Clocks to the core and all high-speed peripherals are off
- HFXO and radio (RX mode only) remain active
- All peripherals and oscillators capable of EM2, EM3 or EM4 operation are available

### 12.3.1.4 EM2

This is the first level into the low power energy modes. Most of the high frequency peripherals are disabled or have reduced functionality. Memory and registers retain their values.

- Cortex®-M33 is in sleep mode. Clocks to the core are off.
- Radio inactive
- High frequency clock tree is inactive
- Low frequency clock tree is active
- The following oscillators are available
  - LFRCO, LFXO, ULFRCO
  - On-demand if used by peripherals: FSRCO, HFRCOEM23
- The following low frequency peripherals are available
  - SYSRTC, BURTC, WDOG, LETIMER, PCNT, I2C0, EUSART0 (UART or SPI secondary only), and KEYS defence
- The following analog peripherals are available (with potential limitations on functionality)
  - ACMP, IADC, VDAC
- Wake-up to EM0 through
  - Peripheral interrupt, reset pin, power on reset, asynchronous pin interrupt, I2C0 address recognition
- Wake-up to EM1 through
  - Peripheral data transfer request
  - Part returns to EM2 when transfers are complete
- RAM and register values are preserved
  - RAM blocks may be optionally powered down for lower power
- GPIO pin state is retained
- Debug connectivity is unavailable by default to reduce current consumption. Debug connectivity can be enabled by setting the EM2DBGGEN bit in the EMU\_CTRL register, and will consume about 0.5 uA extra supply current.

### 12.3.1.5 EM3

In this low energy mode, all low frequency oscillators (LFXO, LFRCO) and all low frequency clocks derived from them are stopped, as well as all high frequency clocks. Most peripherals are disabled or have reduced functionality. Memory and registers retain their values.

- Cortex®-M33 is in sleep mode. Clocks to the core are off.
- Radio inactive
- High frequency clock tree is inactive
- All low frequency clock trees derived from the low frequency oscillators (LFXO, LFRCO) are inactive
- The following oscillators are available
  - ULFRCO
  - On-demand if used by peripherals: FSRCO, HFRCOEM23
- The following low frequency peripherals are available if clocked by the ULFRCO (with potential limitations on functionality)
  - SYSRTC, BURTC, WDOG, LETIMER, PCNT, I2C0, EUSART0 (SPI secondary only), and KEYS SCAN
- The following analog peripherals are available (with potential limitations on functionality)
  - ACMP, IADC, VDAC
- Wake-up to EM0 through
  - Peripheral interrupt, reset pin, power on reset, asynchronous pin interrupt, I2C0 address recognition
- Wake-up to EM1 through
  - Peripheral data transfer request
  - Part returns to EM3 when transfers are complete
- RAM and register values are preserved
  - RAM blocks may be optionally powered down for lower power
- GPIO pin state is retained
- Debug connectivity is unavailable by default to reduce current consumption. Debug connectivity can be enabled by setting the EM2DBGEN bit in the EMU\_CTRL register, and will consume about 0.5 uA extra supply current.

### 12.3.1.6 EM4

EM4 is the lowest energy mode of the part. There is no retention except for GPIO PAD state and BURAM values. Wake-up from EM4 requires a reset to the system, returning it back to EM0

- Cortex®-M33 is off
- Radio is off
- High frequency clock tree is off
- Low frequency clock tree may be active
- No RAM or register values are retained, except for the BURAM.
- The following oscillators are on if used by the BURTC:
  - LFRCO, LFXO, ULFRCO
- The following low frequency peripherals are available
  - BURTC
- Wake-up to EM0 through
  - BURTC interrupt, reset pin, power on reset, asynchronous pin interrupt (on GPIO\_EM4WUX pins only)
- GPIO pin state may be retained (depending on EMU->EM4CTRL.EM4IORETMODE configuration)

## 12.3.2 Entering Low Energy Modes

The following sections describe the requirements for entering the various energy modes.

### 12.3.2.1 Entry Into EM1

Energy mode EM1 is entered when the Cortex®-M33 executes the Wait For Interrupt (WFI) or Wait For Event (WFE) instruction while the SLEEPDEEP bit in the Cortex®-M33 System Control Register is cleared. The MCU can re-enter sleep automatically out of an Interrupt Service Routine (ISR) if the SLEEPONEXIT bit in the Cortex®-M33 System Control Register is set. Refer to ARM documentation on entering Sleep modes.

Alternatively, EM1 can be entered from either EM2 or EM3 due to certain peripheral wake-up requests, allowing transfers from the peripheral to system RAM. The system will return back to EM2 or EM3 once the peripheral has completed its transfers and processing.

### 12.3.2.2 Entry Into EM2 or EM3

Energy mode EM2 or EM3 may be entered when **all** of the following conditions are true:

- Radio state machine is in OFF state
- Cortex®-M33 (if present) is in DEEPSLEEP state
- Flash Program/Erase Inactive
- DMA done with all current requests
- A debugger is not currently connected.

**Note:** The device will still enter a sleep state which emulates the behavior of EM2 or EM3 when an active debug connection is present, but it will draw more than the specified sleep current.

Energy mode EM2 is entered from EM0 when the Cortex®-M33 executes the Wait For Interrupt (WFI) or Wait For Event (WFE) instruction while the SLEEPDEEP bit in the Cortex®-M33 System Control Register is set. The MCU can re-enter DeepSleep automatically out of an Interrupt Service Routine (ISR) if the SLEEPONEXIT bit in the Cortex®-M33 System Control Register is set. Refer to ARM documentation on entering Sleep modes.

Alternately, EM2 or EM3 is entered from EM1 upon the completion of a Peripheral Wake-Up Request from capable peripherals if no EM0 wake-up happens in the meantime.

When entering EM2 or EM3, if any peripheral on an auxiliary low power domain (PD0B, PD0C, etc.) is enabled, that auxiliary low power domain will be powered, causing higher current draw. Otherwise, the auxiliary power domain will be powered down. See [12.3.4 Power Domains](#) for more information.

### 12.3.2.3 Entry Into EM4

Energy mode EM4 is entered through register access.

Software must ensure no modules are active, such as the Radio, when entering EM4.

Software may enter EM4 from EM0 by writing the sequence 2,3,2,3,2,3,2,3,2 to EM4CTRL->EM4ENTRY bit field. If the EM4BLOCK bit in WDOGn\_CTRL is set, the CPU will be prevented from entering EM4 by software request.

An active debugger connection will prevent entry into EM4.

### 12.3.3 Exiting a Low Energy Mode

A system in EM2 and EM3 can be woken up to EM0 through regular interrupt requests from active peripherals. Since state and RAM retention is available, the EFR32 Series 2 is fully restored and can continue to operate as before it went into the Low Energy Mode.

Wake-up from EM4 is performed through a reset. Wake-up from a specific module must be enabled in that module's EM4WUEN register.

Enabled interrupts that can cause wake-up from EM2, EM3, and EM4 are shown in the following table. The wake-up triggers always return the device to EM0. Additionally, any reset source will return to EM0.

**Table 12.3. Wake-Up Triggers from Low Energy Modes**

| Peripheral             | Wake-Up Trigger                                                      | EM2              | EM3              | EM4                |
|------------------------|----------------------------------------------------------------------|------------------|------------------|--------------------|
| LETIMER                | Any enabled interrupt                                                | Yes              | -                | -                  |
| LFXO                   | Ready Interrupt                                                      | Yes              | -                | -                  |
| LFRCO                  | Ready Interrupt                                                      | Yes              | -                | -                  |
| WDOG                   | Any enabled interrupt                                                | Yes              | Yes              | -                  |
| I <sup>2</sup> C0      | Receive address recognition                                          | Yes              | Yes              | -                  |
| EUSART0                | Any enabled interrupt                                                | Yes              | -                | -                  |
| IADC                   | SCAN and SINGLE FIFO events, Window comparator events                | Yes              | Yes              |                    |
| ACMP                   | Any enabled edge interrupt                                           | Yes              | Yes              | -                  |
| VDAC                   | Any enabled interrupt except ABUS conflict and allocation interrupts | Yes              | Yes              |                    |
| SYSRTC                 | Any enabled interrupt                                                | Yes              | Yes              | -                  |
| BURTC                  | Timeout                                                              | Yes              | Yes              | Yes <sup>1</sup>   |
| EMU Temperature Sensor | Measured temperature outside the defined limits                      | Yes              | Yes              | -                  |
| Pin Interrupts         | Transition                                                           | Yes <sup>2</sup> | Yes <sup>2</sup> | Yes <sup>1,3</sup> |
| Reset Pin              | Assertion                                                            | Yes              | Yes              | Yes                |
| Power                  | Cycle Off/On                                                         | Yes              | Yes              | Yes                |

**Note:**

1. Corresponding bit in the module's EM4WUEN must be set.
2. Available on Port A, Port B, and all EM4WU pins.
3. Only available on EM4WU pins.

#### 12.3.4 Power Domains

Peripherals may exist on one of several independent power domains which are powered down to minimize supply current when not in use. Power domains are managed automatically by the EMU.

The lowest-energy power domain is the "high-voltage" power domain (PDHV), which supports extremely low-energy infrastructure and peripherals. Circuits powered from PDHV are always on and available in all energy modes down to EM4.

The next power domain is the low power domain (PD0), which is further divided to power subsets of peripherals. All PD0 power domains are shut down in EM4. Circuits powered from PD0 power domains may be available in EM0, EM1, EM2, and EM3.

Low power domain A (PD0A) is the base power domain for EM2 and EM3 and will always remain on in EM0-EM3. It powers the most commonly-used EM2 and EM3-capable peripherals and infrastructure required to operate in EM2 and EM3. Auxiliary PD0 power domains (PD0B, PD0C, PD0D, PD0E) power additional EM2 and EM3-capable peripherals on demand. If any peripherals on one of the auxiliary power domains is enabled, that power domain will be active in EM2 and EM3. Otherwise, the auxiliary PD0 power domains will be shut down to reduce current.

**Note:** Power domain PD0E is also turned on when peripherals on PD0B, PD0C, or PD0D are used.

The active power domain (PD1) powers the rest of the device circuitry, including the CPU core and EM0 / EM1 peripherals. PD1 is always powered on in EM0 and EM1. PD1 is always shut down in EM2, EM3, and EM4.

[Table 12.4 Peripheral Power Subdomains on page 298](#) shows the peripherals on the PDHV and PD0x domains. Any peripheral not listed is on PD1.

**Table 12.4. Peripheral Power Subdomains**

| Always On in EM2/EM3       |        | Selectively On in EM2/3 |                                    |                   |         |
|----------------------------|--------|-------------------------|------------------------------------|-------------------|---------|
| PDHV <sup>1</sup>          | PD0A   | PD0B <sup>2</sup>       | PD0C <sup>2</sup>                  | PD0D <sup>2</sup> | PD0E    |
| LFRCO (Non-precision Mode) | SYSRTC | LETIMER0                | LFRCO (Precision Calibration Mode) | DEBUG             | GPIO    |
| LFXO                       | FSRCO  | IADC0                   | HFRCOEM23                          | WDOG0/1           | KEYSCAN |
| BURTC                      |        | PCNT0                   | HFXO                               | EUSART0           | PRS     |
| BURAM                      |        | ACMP0/1                 |                                    | I2C0              |         |
| ULFRCO                     |        | VDAC0/1                 |                                    |                   |         |

**Note:**

- 1. Peripherals on PDHV are also available in EM4.
- 2. If any of PD0B, PD0C, or PD0D are enabled, PD0E will also be automatically enabled.

#### 12.3.5 Voltage Scaling

The EFR32xG24 supports supply voltage scaling for the LDO powering DECOUPLE. Voltage scaling helps to optimize the energy efficiency of the system by operating at lower voltages when possible. Three supply voltage operating points are available:

**Table 12.5. Voltage Scaling Options**

| VSCALE Setting | DECOUPLE Voltage | Operating Conditions                          |
|----------------|------------------|-----------------------------------------------|
| VSCALE2        | 1.1 V            | EM0/EM1 Operation up to 80 MHz<br>EM2 and EM3 |
| VSCALE1        | 1.0 V            | EM0/EM1 Operation up to 40 MHz<br>EM2 and EM3 |
| VSCALE0        | 0.9 V            | EM2 and EM3 Only                              |

### 12.3.5.1 Voltage Scaling in EM0 and EM1

In EM0 and EM1, the voltage scaling value should be set according to the desired operating frequency. The system defaults to VSCALE2 out of reset. To operate above 40 MHz, VSCALE2 should always be used. If the system will operate below 40 MHz, VSCALE1 may be used to save energy.

The voltage scaling value for EM0 and EM1 is changed via software command bits in the EMU\_CMD register. Setting EMU\_CMD\_EM01VSCALE1 will switch to VSCALE1, and setting EMU\_CMD\_EM01VSCALE2 will switch to VSCALE2.

The command initiates a voltage change operation, but some time is needed before the new supply voltage is reached. When changing between VSCALE values in EM0, it takes approximately 150 us to ramp the voltage down and approximately 32 us to ramp the voltage up to the new values (see the data sheet specifications for exact numbers). During this time, SRAM access is prohibited by the hardware and any accesses to SRAM from the CPU or DMA will be blocked until the operation is complete. The EMU\_STATUS\_VSCALEBUSY bit indicates when a voltage scale change is in progress. When the operation is complete the EMU\_IF\_VSCALEDONEIF flag will be set.

**Note:** Because SRAM access is blocked during a voltage scaling operation, it is recommended to configure the desired EM0 / EM1 voltage scaling once during initial boot-up for systems operating at VSCALE1.

The current VSCALE setting can be read at any time from the EMU\_STATUS\_VSCALE field.

### 12.3.5.2 Voltage Scaling in EM2 and EM3

A separate voltage scaling value is used during EM2 and EM3. This allows the core to run at a higher voltage when in EM0 / EM1 and reduce the voltage in EM2 and EM3 for power savings, or maintain the same voltage for faster wakeup. The voltage scale level for EM2 and EM3 is defined by the EMU\_CTRL\_EMU23VSCALE field. The new voltage scaling level will be applied when the system is in EM2 or EM3, and return to the EM0 / EM1 voltage scaling level automatically when the system exits the low energy mode.

Hardware will only allow the VSCALE level to remain the same or be reduced when entering EM2 and EM3. If EMU\_CTRL\_EMU23VSCALE is set to a higher VSCALE setting than the current EM0 / EM1 VSCALE level, the DECOUPLE voltage will remain the same as the EM0 / EM1 setting.

If the voltage scaling level for EM2 / EM3 is lower than the level set for EM0 / EM1, additional time is needed to wake up from the low powered state (see the device data sheet for specific timing). The lowest current during sleep will be obtained by setting EMU23VSCALE to VSCALE0, and the fastest wake times will be obtained when EMU23VSCALE is equal to or higher than the EM0 / EM1 voltage scaling value.

### 12.3.6 EM0 / EM1 Peripheral Register Retention

When the device enters EM2 or EM3, all peripherals will retain their register configurations by default. Retention for peripherals on the PD1 power domain (i.e. those which do not operate in EM2 and EM3), can optionally be disabled by setting bit 0 of the EMU\_PD1PARETCTRL\_PD1PARETDIS field. Disabling retention reduces the supply current in EM2 and EM3 slightly. However, the peripheral register interfaces will be reset upon exit to EM0.

**Important:** This feature is not currently supported by Silicon Labs software stacks. It is the responsibility of the user software to re-configure any peripherals as necessary when the device wakes to EM0.

### 12.3.7 Power Configurations

In order to provide the lowest power solutions, the EFR32xG24 comes with a DC-DC module to power internal circuits. The EFR32xG24 may be operated with or without the DC-DC. When used, the DC-DC requires an external inductor and capacitor (refer to the data sheet for recommended values).

The EFR32xG24 has multiple power supply rails: a DC-DC regulator input (VREGVDD), IO Supply (IOVDD), Analog (AVDD), RF Analog Supply (RFVDD), RF Power Amplifier Supply (PAVDD), Digital LDO and flash (DVDD), and Low Voltage Digital Supply (DECOPLE). Additional detail for each configuration and option is given in the following sections.

Due to on-chip circuitry (e.g., diodes), some power supply pins have a dependent relationship with one or more other power supply pins. These internal relationships between the external voltages applied to the various EFR32 supply pins are defined below. Exceeding the below constraints can result in damage to the device and/or increased current draw.

- VREGVDD  $\geq$  DVDD

**Note:** In systems not using the DC-DC converter, VREGVDD must be shorted to DVDD external to the device.

- PAVDD  $\geq$  RFVDD
- DVDD  $\geq$  DECOUPLE
- AVDD, IOVDD: No supply sequencing dependency. Additional leakage may occur if DVDD remains unpowered with power applied to these supplies.

Additionally, there are other system-level considerations when assigning power supplies.

- The usable range for analog signals connected to GPIO (such as IADC inputs) will be limited to the lower of AVDD and IOVDD.
- The RESETn pin has an internal pullup to the DVDD supply. If RESETn is driven by external circuitry above DVDD, additional current may flow into the pin due to this pullup.

### 12.3.7.1 Power Configuration 0: STARTUP

Upon power-on reset (POR), the system is configured in a safe Startup Configuration that supports all of the available Power Configurations. The Startup Configuration is shown in the simplified diagram below.

In the Startup configuration the DC-DC converter's Bypass switch is ON (i.e., the VREGVDD pin is shorted internally to the DVDD pin).

After power on, firmware can elect to turn on the DC-DC if the external hardware configuration supports it.



Figure 12.2. Startup Power Configuration

### **12.3.7.2 Power Configuration 1: No DC-DC**

In Power Configuration 1, the DC-DC converter is unused, and all power is supplied by external sources. The DVDD pin must be shorted to VREGVDD.

Other supplies may be supplied by the same supply as VREGIN and DVDD (as shown in 12.3.7.2 Power Configuration 1: No DC-DC), or they may be powered from a separate source.

VREGSW must be left disconnected in this configuration.



**Figure 12.3. DC-DC Off Power Configuration**

### 12.3.7.3 Power Configuration 2: DC-DC

For the lowest power applications, the DC-DC converter can be used to power the rest of the supplies on the device. When the DC-DC converter is used to regulate the voltage at DVDD, the maximum supply voltage may be limited by the operating temperature and/or the average lifetime load conditions. Refer to the device datasheet for additional details.

In Power Configuration 2, the DC-DC Output ( $V_{DCDC}$ ) is connected to DVDD and optionally, to all the other supplies on the chip. In the configuration shown in [Figure 12.4 DC-DC Power Configuration on page 303](#), the AVDD and IOVDD supplies are connected to the main supply to support higher voltage external interfaces.



**Figure 12.4. DC-DC Power Configuration**

As the Main Supply voltage approaches the DC-DC output voltage, it eventually reaches a point where becomes inefficient (or impossible) for the DC-DC module to regulate  $V_{DCDC}$ . At this point, firmware can enable bypass mode, which effectively disables the DC-DC and shorts the Main Supply voltage directly to the DC-DC output. If and when sufficient voltage margin on the Main Supply returns, the system can be switched back into DC-DC regulation mode.

#### 12.3.7.4 Power Configuration 3: DC-DC With Separate PAVDD

For power-conscious applications that require higher RF transmitter output power ( $> 14$  dBm), PAVDD may be powered from the system supply, while the DC-DC converter can be used to power other supplies on the device. This situation is very similar to [12.3.7.3 Power Configuration 2: DC-DC](#), but PAVDD has been separated out to achieve higher transmitter power.



**Figure 12.5. DC-DC Power Configuration With Separate PAVDD**

#### 12.3.8 Buck DC-DC Interface

The EFR32xG24 devices feature a DC-DC buck converter which requires a single external inductor and a single external capacitor. The input supply is the VREGVDD pin, and the DC-DC converter will produce a nominal 1.8 V output at the DVDD pin to power radio and MCU functions. The DC-DC converter is an efficient PFM (Pulse Frequency Modulation) architecture. In addition, the DC-DC converter supports an unregulated bypass mode, in which the input voltage is directly shorted to the DC-DC output. An integrated programmable supply monitor and dedicated interrupt allows software to enable the bypass switch when the VREGVDD supply voltage is below the minimum allowable voltage for the output current load.

The input supply VREGVDD has a maximum range between 1.8 V and 3.8 V, but is limited by application parameters, including transient current load, operating junction temperature, and the lifetime average current load.

Refer to the device datasheet for more details on the input supply voltage range.

### 12.3.8.1 Buck DC-DC Mode Bypass and VREGVDD Comparator

The buck DC-DC converter implements a bypass mode which shorts the VREGVDD input voltage directly to the DC-DC converter output through an internal switch. Bypass mode is enabled automatically during a power-on-reset. Bypass mode can also be enabled and disabled through software, using the DCDC\_CTRL\_MODE field. When set to BYPASS, the bypass switch is enabled and DC-DC regulation will be disabled. Consult the data sheet for the bypass switch impedance specification.

The EFR32xG24 includes a supply comparator circuit to help software determine when the VREGVDD supply is high enough to enable the buck DC-DC, or when to change to bypass mode. The THRESSEL field in the EMU\_VREGVDDCMPCTRL register sets the comparator threshold between 2.0 and 2.3 V, and the VREGINCMPEN bit is used to enable the supply comparator. When the VREGVDD comparator is used, DCDC\_STATUS\_VREGIN can be read by software to determine whether VREGVDD is above or below the established threshold.

The VREGVDD comparator can also generate interrupt events when the input supply is above or below the specified threshold. The VREGINHIGHIEN and VREGINLOWIEN bits in DCDC\_IEN are used to enable the above / below threshold interrupts, respectively. The VREGVDD comparator will be active and generate interrupts in EM0 and EM1 only.

The VREGVDD Comparator status is always captured and stored in RMURSTCAUSE.VREGIN on any reset event, even if the reset is not caused by VREGVDD being too low. At startup, the firmware should determine if the last reset was caused by a low VREGVDD condition by checking the following:

```
EMU_RSTCAUSE_VREGIN & (EMU_RMURSTCAUSE_DVDBOD | EMU_RMURSTCAUSE_DVDBOD)
```

If true, the part should remain in bypass mode with the DCDC disabled.

### 12.3.8.2 Buck DC-DC Startup

Out of power-on-reset (POR), the DC-DC converter defaults to bypass mode and the DC-DC block is disabled. Before enabling the DC-DC, software should first configure and enable the VREGVDD comparator. Once the thresholds for the VREGVDD comparator have been configured and the comparator enabled, the DCDC\_STATUS.VREGIN bit should be checked to ensure that the input supply is above the threshold. When the input supply is sufficient, the DC-DC may be configured and enabled. The following steps outline this procedure:

1. Set VREGVDD comparator threshold with EMU\_VREGVDDCMPCTRL.THRESSEL
2. Enable VREGVDD comparator with EMU\_VREGVDDCMPCTRL.VREGINCMPEN
3. Check DCDC\_STATUS.VREGIN:
  - If low, VREGIN is above the programmed threshold and it is safe to enter DC-DC mode
  - If high, VREGIN is below the programmed threshold and firmware should remain in bypass mode
4. Enable the DC-DC module with DCDC\_EN\_EN = 1
5. Configure the IPKVAL and DRVSPEED settings in DCDC\_EM01CTRL0 and DCDC\_EM23CTRL0.
6. Enable any required interrupts via DCDC\_IEN.
7. Start the DC-DC by setting DCDC\_CTRL.MODE to DCDCREGULATION.

The DC-DC will enter a warmup phase for approximately 100 us, then disable the bypass switch and begin using the DC-DC core to regulate the output voltage. The DCDC\_IF.RUNNINGIF interrupt flag will indicate when the switch from bypass to DC-DC is complete, however this does not indicate that the output is regulated. Until the output capacitor discharges due to normal current draw from the system, the voltage may be higher than 1.8 V. The DCDC\_IF.REGULATIONIF interrupt flag will indicate when the DC-DC has reached regulation and is providing the desired output voltage.

If the VREGINLOWIF interrupt occurs, software should immediately switch back to bypass mode by clearing DCDC\_CTRL.MODE to BYPASS.

### 12.3.8.3 Buck DC-DC Recommended Configuration Settings

Certain DC-DC parameters are adjustable for fine-tuning of performance, but the majority of applications will not need to use any other than the recommended settings. All datasheet parameters are specified using the recommended settings detailed in this section. The configuration settings must be set before DC-DC regulation is started, and must not be changed while the DC-DC is active.

The DCDC\_EM01CTRL0 and DCDC\_EM23CTRL0 registers each have an IPKVAL field to adjust the maximum peak / load current, and a DRVSPEED field to adjust the driver speed. DCDC\_EM01CTRL0 sets the configuration for EM0 and EM1 operation while DCDC\_EM23CTRL0 sets the configuration for EM2 and EM3 operation. The DCDC\_CTRL.IPKTMAXCTRL field adjusts the maximum time for peak current detection, which impacts the voltage ripple at the DC-DC output. The recommended settings are shown in [Table 12.6 DRVSPEED, IPKVAL, and IPKMAXCTRL Recommended Settings for buck DC-DC on page 306](#).

**Table 12.6. DRVSPEED, IPKVAL, and IPKMAXCTRL Recommended Settings for buck DC-DC**

| Bit Field               | Recommended Setting |
|-------------------------|---------------------|
| DCDC_EM01CTRL0.IPKVAL   | 9 (LOAD60MA)        |
| DCDC_EM01CTRL0.DRVSPEED | 1 (DEFAULT_SETTING) |
| DCDC_EM23CTRL0.IPKVAL   | 3 (LOAD5MA)         |
| DCDC_EM23CTRL0.DRVSPEED | 1 (DEFAULT_SETTING) |
| DCDC_CTRL.IPKTMAXCTRL   | 16 (1.19 us)        |

### 12.3.8.4 Buck DC-DC EM4 Entry

The buck DC-DC is available in all energy modes except for EM4. If the system wants to enter EM4, the DC-DC converter must first be turned off and switched over to bypass mode. The system will not enter EM4 if the DC-DC is active. If an attempt is made to go into EM4 with DC-DC active, it will be blocked, and the DCDC\_IF\_EM4ERR flag will be set.

### 12.3.9 EFP01 Communication

The EFP01 Energy Friendly Power Management IC (PMIC) is an extremely flexible, highly efficient, multi-output power management IC, providing complete system power and primary cell battery Coulomb counting for EFR32xG24 devices. The dual-DCDC converter outputs available on certain EFP01 OPNs can, for example, provide power to both the 1.8 V supplies (e.g., DVDD/AVDD/IOVDD) as well as the 1.1/1.0/0.9 V supply (DECOUPLE) for improved efficiency. EFP01 uses an I<sup>2</sup>C interface for communication and also has a unidirectional, open-drain IRQ# output to indicate status flag changes. Consult EFP01 Datasheet for more detailed information and available OPNs.

The EFR32xG24 has additional built-in hardware support for the EFP01 Energy Friendly PMICs, including:

- Direct Mode Energy Mode transition supporting all energy modes (including EM4) on dedicated pins (PC1 / PC2)
- Hardware IRQ with (dedicated IRQ vector) in all energy modes (included EM4) on dedicated pin (PC5)

EFR32xG24's EFP01 hardware support must be enabled by setting one (or both) of the EFPDRVDECOUPLE or the EFPDRVDVDD bits in the EMU\_CTRL register:

1. EFPDRVDECOUPLE: Set this bit if EFP01's DCDC output will be powering EFR32xG24's DECOUPLE supply. Once set, EFR32xG24's internal LDOs will be disabled, and any voltage changes (due to voltage-scaling and/or energy mode transitions) will be managed by EFP01. Note that because this bit disables the internal LDO's powering the core, it should be set until after EFP01's DECOUPLE output has been configured and enabled.
2. EFPDRVDVDD: Set this bit if EFP01's DCDC output is powering EFR32xG24's DVDD supply (or DVDD along with other 1.8V supply inputs). This mode assumes that EFR32xG24's internal DCDC is not being used, so the EFR32xG24 VREGVDD and PAVDD pins should be shorted together on the PCB.

EFR32xG24 provides a dedicated hardware IRQ vector for the EFP01's IRQ output. To use the EFR32xG24's hardware support for EFP01's IRQ output:

1. The PC5 pin should be configured as an input with no pull-up/pull-down enabled and connected on the PCB to EFP01's IRQ pin. Note that although this pin exists on Port C, which typically doesn't support EM2/3 operation, when used as a EFP01 IRQ input the PC5 pin can operate in EM2/3. In addition, the PC5 pin can operate in EM4, without the need to be configured as a EM4WakeUp.
2. EFP01 Hardware support must be enabled by setting either the EFPDRVDECOUPLE or the EFPDRVDVDD bits as described above.

Once enabled, the EFP01 interrupt flag in the EMU\_EFPIF register will be set whenever the EFP01 IRQ line goes low. A processor interrupt can be generated to the EMUEFP\_IRQHandler() by setting the EFPIEN bit in the EMU\_EFPIEN register.

EFR32xG24 includes hardware support for EFP01's optional Direct Mode interface to allow fast-energy mode transitions into and out of all energy modes (EM0/1, EM2/3, EM4). Ordinarily, I<sup>2</sup>C transactions are used to manage EFP01's energy mode state - however, a single I<sup>2</sup>C transaction can take over 100 us. In Direct Mode, the EFR32xG24 retasks the I<sup>2</sup>C pins as push-pull outputs with pull-ups disabled to control the EFP01's energy mode state directly, allowing much faster energy mode transitions. State definitions are defined in [Table 12.7 Direct Mode Energy Mode States on page 307](#). Because the Direct Mode feature is non-I<sup>2</sup>C compliant, it should be enabled only during periods when no communication between EFR32xG24 and EFP01 is required (e.g. an energy mode transition from EM0 to EM2/4), and it is recommended that EFP01 be the only I<sup>2</sup>C device on the bus. It is also recommended for firmware to wait for the I<sup>2</sup>C STOP interrupt ensure no I<sup>2</sup>C transaction is in progress before switching to Direct Mode.

**Table 12.7. Direct Mode Energy Mode States**

| Direct Mode State                | I <sup>2</sup> C SCL Level | I <sup>2</sup> C SDA Level | Allowed State Transitions                                                                         |
|----------------------------------|----------------------------|----------------------------|---------------------------------------------------------------------------------------------------|
| EM0                              | 1                          | 1                          | <ul style="list-style-type: none"> <li>• EM2</li> <li>• I<sup>2</sup>C Start Condition</li> </ul> |
| EM2                              | 0                          | 1                          | <ul style="list-style-type: none"> <li>• EM0</li> <li>• EM4</li> </ul>                            |
| EM4                              | 0                          | 0                          | <ul style="list-style-type: none"> <li>• EM2<sup>2</sup></li> </ul>                               |
| I <sup>2</sup> C Start Condition | 1                          | 0                          |                                                                                                   |

1. Direct mode transitions between EM0 and EM4 are not allowed. The system must briefly go through the EM2 state on EM4 exit or entrance.
2. Direct mode transitions between EM0 and EM4 are not allowed. The system must briefly go through the EM2 state on EM4 exit or entrance.

To enable Direct Mode:

1. The I2C1 module must be used to communicate with EFP01. I2C0 is not supported.
2. The I2C1\_SDA function must be routed to the PC1 pin and connected on the PCB to EFP01's I2C\_SDA pin.
3. The I2C1\_SCL function must be routed to the PC2 pin and connected on the PCB to EFP01's I2C\_SCL pin.
4. Direct Mode must be enabled by setting the EFPDIRECTMODE bit in the EMU\_CTRL register. The EMU will automatically disable the I2C1 internal pull-ups when in Direct Mode
5. EFP01 Hardware support must be enabled by setting either the EFPDRVDECOUPLE or the EFPDRVDVDD bits as described above.

#### 12.3.10 Brown Out Detector (BOD)

Brown out detectors ensure that the minimum supply required for the chip to operate properly and safely is provided to the EFR32xG24. Once triggered, a BOD will generate a system reset.

All BODs detect when the supply falls below a programmed threshold except DECOVMBOD (Over Voltage Monitoring), which detects when the supply goes above a predefined threshold.

All BODs except DVDBBOD and DVDDLEBOD can be individually enabled by firmware.

**Table 12.8. EFR32xG24 BODs**

| BOD       | Control Register | Supported Energy Modes | Function                                                                                                                                                                                             |
|-----------|------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DVDBBOD   | n/a              | EM0/1                  | Monitors the DVDD supply in EM0 and EM1. Hardware enables this BOD automatically in EM0/EM1 and disables it in EM2/EM3/EM4                                                                           |
| DVDDLEBOD | n/a              | EM2/3/4                | Low Energy BOD monitors the DVDD supply in EM2/EM3/ EM4. DVDDLEBOD is automatically masked by hardware for ~100us after it is enabled to allow it to settle                                          |
| DEC BOD   | EMU_DEC BOD      | EM0/1/2/3              | Monitors the DECOUPLE supply. DEC BOD is automatically masked by hardware for ~20us after it is enabled to allow it to settle.                                                                       |
| DECOVMBOD | EMU_DEC BOD      | EM0/1/2/3              | Monitors the DECOUPLE supply Over Voltage by detecting DECOUPLE going over a specified threshold. DECOVMBOD is automatically masked by hardware for ~20us after it is enabled to allow it to settle. |
| AVDBBOD   | EMU_BOD3SENSE    | EM0/1/2/3/4            | Monitors the AVDD supply. Automatically masked by hardware for ~100us after it is enabled to allow it to settle.                                                                                     |
| IOVDBBOD  | EMU_BOD3SENSE    | EM0/1/2/3/4            | Monitors the IOVDD supply. Automatically masked by hardware for ~100us after it is enabled to allow it to settle. (Note that some devices may have multiple IOVDD supplies.)                         |

### 12.3.11 Reset Management Unit

EMU RMU (Reset Management Unit) ensures correct reset operation. It is responsible for connecting the different reset sources to the reset lines of the EFR32xG24. After reset, the M33 loads the stack pointer and program entry point from memory and start execution.



**Figure 12.6. Reset Tree**

There are two types of reset:

- HARD resets. Resets the entire chip. After a hard reset, the EFR32xG24 goes through its power up sequence. For reset timing specifications, please refer to the device datasheet.
- SOFT resets. Resets only some of the digital low voltage logic. Resets the MCU subsystems and peripherals but doesn't affect digital HV logic (e.g., Power control, BURTC). For reset timing specifications, please refer to the device datasheet.

**EFR32xG24 Reset sources**

- Power-on Reset (POR)
  - The POR ensures that EFR32xG24 does not start up before the supply voltage DVDD has reached the threshold voltage VPORthr (see Device Datasheet Electrical Characteristics for details). Before the threshold voltage is reached, EFR32xG24 is kept in reset state.
- RESET pin Reset
  - The RESETn pin includes an on-chip pull-up resistor to the DVDD supply, and can therefore be left unconnected if no external reset source is needed. Also connected to the RESETn line is a filter which prevents glitches from resetting the EFR32xG24.
- EM4 wakeup
  - System reset following EM4 exit.
- Watchdog reset
  - The Watchdog circuit is a timer which (when enabled) must be cleared by software regularly. If software does not clear it, a Watchdog reset is activated. This functionality provides recovery from a software stalemate. Refer to the Watchdog section for specifications and description.
- Core lockup condition
  - A MCU lockup is the result of the core being locked up because of an unrecoverable exception following the activation of the processor's built-in system state protection hardware.
- Software triggered reset
  - Software may initiate a reset (e.g. if it finds itself in a non-recoverable state). By asserting the SYSRESETREQ in the Application Interrupt and Reset Control Register, a reset is issued.
- Brown-Out Detection (BOD)
  - EFR32xG24 has multiple built in Brown-out detection (BOD) circuits, which monitor supply voltage level during operation. BOD circuits compare supply voltage to a programmed threshold level and issue a reset request when triggered.
- Secure Engine Tamper detection
  - Secure Engine may issue a system reset request upon tamper detection.

Whether a reset source trigger event lead to a system reset can be controlled via EMU\_RMUCTRL register.  
EMU\_RSTCAUSE register

User can determine the cause of the last reset by querying the EMU\_RSTCAUSE register. Once read, EMU\_RSTCAUSE should be cleared via EMU\_CMD\_RCCLR.

**Table 12.9. Reset Sources Summary**

| RSTCAUSE Bit | Name      | Type | Can be Disabled? | Description           |
|--------------|-----------|------|------------------|-----------------------|
| 0            | POR       | Hard | No               | Power On Reset.       |
| 1            | PIN       | Hard | No               | Pin Reset.            |
| 2            | EM4       | Soft | No               | EM4 Wakeup            |
| 3            | WDOG0     | Soft | Yes              | Watchdog 0            |
| 5            | LOCKUP    | Soft | Yes              | M33 Lockup            |
| 6            | SYSREQ    | Soft | Yes              | M33 Core System Reset |
| 7            | DVDBBOD   | Hard | No               | DVDD BOD              |
| 8            | DVDDLEBOD | Hard | No               | DVDD LEBOD            |
| 9            | DEC BOD   | Hard | Yes              | DECOUPLE BOD          |
| 10           | AVDBBOD   | Soft | Yes              | AVDD BOD              |
| 11           | IOVDBBOD  | Soft | Yes              | IOVDD 0 BOD           |

### 12.3.12 Temperature Sensor

EMU provides a low energy periodic temperature measurement. A temperature measurement is taken once every 250 ms, with the 9-bit result stored in TEMP bit-field in EMU\_TEMP register. The temperature value is expressed in degrees Kelvin. EMU\_TEMP\_TEMPLSB represents the measured temperature fractional part (in  $\frac{1}{4}$  degree Kelvin).

**Note:** The EMU temperature sensor is always periodically taking single temperature measurements, except in EM4 (shutoff) mode.

To obtain better noise resolution, the temperature sensor also implements a hardware averaging function, and averaged results can be requested using the EMU\_CMD\_TEMPAVGREQ command. When TEMPAVGREQ is set by software, the temperature sensor will take 16 or 64 samples as quickly as possible. The TEMPAVGNUM field in EMU\_CTRL determines how many temperature measurements will be averaged. The averaged result is stored in the 11-bit field EMU\_TEMP\_TEMPAVG, which represents the full temperature with resolution of  $\frac{1}{4}$  degree Kelvin.

The EMU provides the following features around temperature changes:

- Interrupt when temperature is updated (EMU\_IF\_TEMP)
- Interrupt when averaged temperature result is updated (EMU\_IF\_TEMPAVG)
- Interrupt from LOW level trip (generate interrupt EMU\_IF\_TEMPLOWIF when measured temperature in EMU\_TEMP\_TEMP is below programmed threshold EMU\_TEMPLIMITS\_TEMPLOW)
- Interrupt from HIGH level trip (generate interrupt EMU\_IF\_TEMPHIGHIF when measured temperature in EMU\_TEMP\_TEMP is above programmed threshold EMU\_TEMPLIMITS\_TEMPHI)

High and Low thresholds are specified as 9-bit degree Kelvin values and compared against the single temperature result (EMU\_IF\_TEMP).

Measured temperature can be converted to degrees Celsius by subtracting 273.15 ( $T_{\text{Celsius}} = T_{\text{Kelvin}} - 273.15$ ).

#### 12.3.12.1 Linearization, Offset Correction, and Calibration

The raw value reported by the EMU temperature sensor follows a predictable curve. The output may be linearized and the systematic offset removed to achieve die temperature readings with better than +/- 2.5 degrees C accuracy over the full operating temperature range. Further accuracy can be achieved using in-system calibration.

To linearize the measurement and correct for the systematic offset, a second or third-order polynomial equation representing the nominal curve is used. For example, a third-order correction equation takes the form:

$$T_{\text{corr}} = a*x^3 + b*x^2 + c*x^1 + d$$

Where:

- $T_{\text{corr}}$  is the corrected temperature (in degrees Celsius)
- $x$  is the measured temperature (in degrees Celsius)
- $a$  is the  $x^3$  term
- $b$  is the  $x^2$  term
- $c$  is the  $x^1$  term
- $d$  is the  $x^0$  term

Polynomial coefficients for both third and second-order polynomials are shown in [Table 12.10 Polynomial Coefficients on page 311](#). Note that the polynomial coefficients provided assume the raw output (in Kelvin) has been converted to Celsius prior to linearization.

**Table 12.10. Polynomial Coefficients**

| Polynomial Order | $x^3$ Term | $x^2$ Term | $x^1$ Term | $x^0$ Term |
|------------------|------------|------------|------------|------------|
| Third Order      | -9.939E-7  | -1.526E-4  | 1.040      | -3.577     |
| Second Order     | n/a        | -2.849E-4  | 1.040      | -3.374     |

Additional accuracy may be achieved by performing an in-system calibration at known temperatures and operating conditions after linearization.

### 12.3.13 Register Locks

EMU EMU\_LOCK (for user accessible registers) can be used to control access to the EMU\_RMUCTRL, EMU\_CTRL, and EMU\_DEC-BOD registers. The DCDC\_LOCK register can be used to control access to the DC-DC registers.

## 12.4 EMU Register Map

The offset register address is relative to the registers base address.

| Offset | Name                   | Type        | Description                               |
|--------|------------------------|-------------|-------------------------------------------|
| 0x010  | EMU_DECBOD             | RW          | DECOPLE LVBOD Control Register            |
| 0x020  | EMU_BOD3SENSE          | RW          | BOD3SENSE Control Register                |
| 0x03C  | EMU_VREGVDDCMPCTRL     | RW          | DC-DC VREGVDD Comparator Control Register |
| 0x040  | EMU_PD1PARETCTRL       | RW          | PD1 Partial Retention Control             |
| 0x05C  | EMU_IPVERSION          | R           | IP Version                                |
| 0x060  | EMU_LOCK               | W           | EMU Configuration Lock Register           |
| 0x064  | EMU_IF                 | RWH INTFLAG | Interrupt Flags                           |
| 0x068  | EMU_IEN                | RW          | Interrupt Enables                         |
| 0x06C  | EMU_EM4CTRL            | RW          | EM4 Control                               |
| 0x070  | EMU_CMD                | W           | EMU Command Register                      |
| 0x074  | EMU_CTRL               | RW          | EMU Control Register                      |
| 0x078  | EMU_TEMPLIMITS         | RW          | EMU Temperature Thresholds                |
| 0x084  | EMU_STATUS             | RH          | EMU Status Register                       |
| 0x088  | EMU_TEMP               | RH          | Temperature                               |
| 0x090  | EMU_RSTCTRL            | RW          | Reset Management Control Register         |
| 0x094  | EMU_RSTCAUSE           | RH          | Reset Cause                               |
| 0x098  | EMU_TAMPERRSTCAUSE     | RH          | Tamper Reset Cause                        |
| 0x0A0  | EMU_DGIF               | RWH INTFLAG | Interrupt Flags Debug                     |
| 0x0A4  | EMU_DGIEN              | RW          | Interrupt Enables Debug                   |
| 0x100  | EMU_EFPIF              | RWH INTFLAG | EFP Interrupt Register                    |
| 0x104  | EMU_EFPIEN             | RW          | EFP Interrupt Enable Register             |
| 0x1010 | EMU_DECBOD_SET         | RW          | DECOPLE LVBOD Control Register            |
| 0x1020 | EMU_BOD3SENSE_SET      | RW          | BOD3SENSE Control Register                |
| 0x103C | EMU_VREGVDDCMPCTRL_SET | RW          | DC-DC VREGVDD Comparator Control Register |
| 0x1040 | EMU_PD1PARETCTRL_SET   | RW          | PD1 Partial Retention Control             |
| 0x105C | EMU_IPVERSION_SET      | R           | IP Version                                |
| 0x1060 | EMU_LOCK_SET           | W           | EMU Configuration Lock Register           |
| 0x1064 | EMU_IF_SET             | RWH INTFLAG | Interrupt Flags                           |
| 0x1068 | EMU_IEN_SET            | RW          | Interrupt Enables                         |
| 0x106C | EMU_EM4CTRL_SET        | RW          | EM4 Control                               |
| 0x1070 | EMU_CMD_SET            | W           | EMU Command Register                      |
| 0x1074 | EMU_CTRL_SET           | RW          | EMU Control Register                      |
| 0x1078 | EMU_TEMPLIMITS_SET     | RW          | EMU Temperature Thresholds                |
| 0x1084 | EMU_STATUS_SET         | RH          | EMU Status Register                       |

| Offset | Name                                    | Type        | Description                               |
|--------|-----------------------------------------|-------------|-------------------------------------------|
| 0x1088 | <a href="#">EMU_TEMP_SET</a>            | RH          | Temperature                               |
| 0x1090 | <a href="#">EMU_RSTCTRL_SET</a>         | RW          | Reset Management Control Register         |
| 0x1094 | <a href="#">EMU_RSTCAUSE_SET</a>        | RH          | Reset Cause                               |
| 0x1098 | <a href="#">EMU_TAMPERRSTCAUSE_SET</a>  | RH          | Tamper Reset Cause                        |
| 0x10A0 | <a href="#">EMU_DGIF_SET</a>            | RWH INTFLAG | Interrupt Flags Debug                     |
| 0x10A4 | <a href="#">EMU_DGIEN_SET</a>           | RW          | Interrupt Enables Debug                   |
| 0x1100 | <a href="#">EMU_EFPIF_SET</a>           | RWH INTFLAG | EFP Interrupt Register                    |
| 0x1104 | <a href="#">EMU_EFPIEN_SET</a>          | RW          | EFP Interrupt Enable Register             |
| 0x2010 | <a href="#">EMU_DECBOB_CLR</a>          | RW          | DECOPLE LVBOD Control Register            |
| 0x2020 | <a href="#">EMU_BOD3SENSE_CLR</a>       | RW          | BOD3SENSE Control Register                |
| 0x203C | <a href="#">EMU_VREGVDDCMPCTRL_CL_R</a> | RW          | DC-DC VREGVDD Comparator Control Register |
| 0x2040 | <a href="#">EMU_PD1PARETCTRL_CLR</a>    | RW          | PD1 Partial Retention Control             |
| 0x205C | <a href="#">EMU_IPVERSION_CLR</a>       | R           | IP Version                                |
| 0x2060 | <a href="#">EMU_LOCK_CLR</a>            | W           | EMU Configuration Lock Register           |
| 0x2064 | <a href="#">EMU_IF_CLR</a>              | RWH INTFLAG | Interrupt Flags                           |
| 0x2068 | <a href="#">EMU_IEN_CLR</a>             | RW          | Interrupt Enables                         |
| 0x206C | <a href="#">EMU_EM4CTRL_CLR</a>         | RW          | EM4 Control                               |
| 0x2070 | <a href="#">EMU_CMD_CLR</a>             | W           | EMU Command Register                      |
| 0x2074 | <a href="#">EMU_CTRL_CLR</a>            | RW          | EMU Control Register                      |
| 0x2078 | <a href="#">EMU_TEMPLIMITS_CLR</a>      | RW          | EMU Temperature Thresholds                |
| 0x2084 | <a href="#">EMU_STATUS_CLR</a>          | RH          | EMU Status Register                       |
| 0x2088 | <a href="#">EMU_TEMP_CLR</a>            | RH          | Temperature                               |
| 0x2090 | <a href="#">EMU_RSTCTRL_CLR</a>         | RW          | Reset Management Control Register         |
| 0x2094 | <a href="#">EMU_RSTCAUSE_CLR</a>        | RH          | Reset Cause                               |
| 0x2098 | <a href="#">EMU_TAMPER-RSTCAUSE_CLR</a> | RH          | Tamper Reset Cause                        |
| 0x20A0 | <a href="#">EMU_DGIF_CLR</a>            | RWH INTFLAG | Interrupt Flags Debug                     |
| 0x20A4 | <a href="#">EMU_DGIEN_CLR</a>           | RW          | Interrupt Enables Debug                   |
| 0x2100 | <a href="#">EMU_EFPIF_CLR</a>           | RWH INTFLAG | EFP Interrupt Register                    |
| 0x2104 | <a href="#">EMU_EFPIEN_CLR</a>          | RW          | EFP Interrupt Enable Register             |
| 0x3010 | <a href="#">EMU_DECBOB_TGL</a>          | RW          | DECOPLE LVBOD Control Register            |
| 0x3020 | <a href="#">EMU_BOD3SENSE_TGL</a>       | RW          | BOD3SENSE Control Register                |
| 0x303C | <a href="#">EMU_VREGVDDCMPCTRL_TG_L</a> | RW          | DC-DC VREGVDD Comparator Control Register |
| 0x3040 | <a href="#">EMU_PD1PARETCTRL_TGL</a>    | RW          | PD1 Partial Retention Control             |
| 0x305C | <a href="#">EMU_IPVERSION_TGL</a>       | R           | IP Version                                |
| 0x3060 | <a href="#">EMU_LOCK_TGL</a>            | W           | EMU Configuration Lock Register           |

| Offset | Name                                   | Type        | Description                       |
|--------|----------------------------------------|-------------|-----------------------------------|
| 0x3064 | <a href="#">EMU_IF_TGL</a>             | RWH INTFLAG | Interrupt Flags                   |
| 0x3068 | <a href="#">EMU_IEN_TGL</a>            | RW          | Interrupt Enables                 |
| 0x306C | <a href="#">EMU_EM4CTRL_TGL</a>        | RW          | EM4 Control                       |
| 0x3070 | <a href="#">EMU_CMD_TGL</a>            | W           | EMU Command Register              |
| 0x3074 | <a href="#">EMU_CTRL_TGL</a>           | RW          | EMU Control Register              |
| 0x3078 | <a href="#">EMU_TEMPLIMITS_TGL</a>     | RW          | EMU Temperature Thresholds        |
| 0x3084 | <a href="#">EMU_STATUS_TGL</a>         | RH          | EMU Status Register               |
| 0x3088 | <a href="#">EMU_TEMP_TGL</a>           | RH          | Temperature                       |
| 0x3090 | <a href="#">EMU_RSTCTRL_TGL</a>        | RW          | Reset Management Control Register |
| 0x3094 | <a href="#">EMU_RSTCAUSE_TGL</a>       | RH          | Reset Cause                       |
| 0x3098 | <a href="#">EMU_TAMPERRSTCAUSE_TGL</a> | RH          | Tamper Reset Cause                |
| 0x30A0 | <a href="#">EMU_DGIF_TGL</a>           | RWH INTFLAG | Interrupt Flags Debug             |
| 0x30A4 | <a href="#">EMU_DGIEN_TGL</a>          | RW          | Interrupt Enables Debug           |
| 0x3100 | <a href="#">EMU_EFPIF_TGL</a>          | RWH INTFLAG | EFP Interrupt Register            |
| 0x3104 | <a href="#">EMU_EFPIEN_TGL</a>         | RW          | EFP Interrupt Enable Register     |

## 12.5 EMU Register Description

### 12.5.1 EMU\_DECBOD - DECOUPLE LVBOD Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 0x010  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |

| Bit  | Name          | Reset | Access | Description                                                                                                                                                                       |
|------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | DEC0VMBODMASK | 0x1   | RW     | <b>Over Voltage Monitor Mask</b><br>DECOUPLE BOD Over Voltage Monitor Mask                                                                                                        |
| 4    | DEC0VMBODEN   | 0x0   | RW     | <b>Over Voltage Monitor enable</b><br>DECOUPLE BOD Over Voltage Monitor enable. Enables LVBOD below vref high. BOD is masked for 20us after enable                                |
| 3:2  | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | DEC0BDMASK    | 0x1   | RW     | <b>DEC0BOD Mask</b><br>DECOUPLE BOD Mask                                                                                                                                          |
| 0    | DEC0BODEN     | 0x0   | RW     | <b>DEC0BOD enable</b><br>DECOUPLE BOD enable. Enables LVBOD above vref low. BOD is masked for 20us after enable                                                                   |

## 12.5.2 EMU\_BOD3SENSE - BOD3SENSE Control Register

| Offset      | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|-------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 0x020       | 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 |  |  |  |  |
| Reset       |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Access      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Name        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| VDDIO1BODEN | 0x0          | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| VDDIO0BODEN | 0x0          | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| AVDDBODEN   | 0x0          | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                       |
|------|-------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 2    | VDDIO1BODEN | 0x0   | RW     | <b>VDDIO1 BOD enable</b><br><br>BOD output is automatically masked for 100us by HW after enable is set                                                            |
| 1    | VDDIO0BODEN | 0x0   | RW     | <b>VDDIO0 BOD enable</b><br><br>BOD output is automatically masked for 100us by HW after enable is set                                                            |
| 0    | AVDDBODEN   | 0x0   | RW     | <b>AVDD BOD enable</b><br><br>BOD output is automatically masked for 100us by HW after enable is set                                                              |

## 12.5.3 EMU\_VREGVDDCMPCTRL - DC-DC VREGVDD Comparator Control Register

| Offset     | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| 0x03C      | 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 |  |  |  |  |  |
| Reset      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| Access     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| Name       |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| THRESSEL   | 0x3          | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| VREGINCPEN | 0x0          | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |

| Bit  | Name       | Reset | Access | Description                                                                                                                                                       |
|------|------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 2:1  | THRESSEL   | 0x3   | RW     | <b>VREGVDD comparator threshold programming</b><br><br>VREGVDD comparator threshold programming: 2.0->2.3V, 0.1V/step                                             |
| 0    | VREGINCPEN | 0x0   | RW     | <b>VREGVDD comparator enable</b><br><br>VREGVDD comparator enable. Output is masked for 5us after enabled. Automatically disabled in EM2.                         |

## 12.5.4 EMU\_PD1PARETCTRL - PD1 Partial Retention Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |             |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|-------------|---|---|---|---|---|---|
| 0x040  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |             |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW  |             |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | PD1PARETDIS |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Name           | Reset                                                                    | Access | Description                                                                                                                                                       |       |      |             |   |                |                                           |   |               |                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|----------------|-------------------------------------------|---|---------------|--------------------------------------------------------------------------|
| 31:16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reserved       |                                                                          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |       |      |             |   |                |                                           |   |               |                                                                          |
| 15:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PD1PARETDIS    | 0x0                                                                      | RW     | <b>Disable PD1 Partial Retention</b>                                                                                                                              |       |      |             |   |                |                                           |   |               |                                                                          |
| Select PD1 register groups that are NOT retained in EM2/EM3. Each bit controls a register group. MCU core group is always retained. Bit[0]: Disables PD1 retention for MCU Peripherals group. Bit[1]: Disables PD1 retention for RADIO group (only on devices with a radio). Bit [15:2]: Unused. Setting PD1 retention for MCU Peripherals group will also allow PD0B/C/D power domains to be turned OFF in EM23 if all peripherals on those power domains are turned off on EM23 entry |                |                                                                          |        |                                                                                                                                                                   |       |      |             |   |                |                                           |   |               |                                                                          |
| <table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>1</td> <td>PERIPHNORETAIN</td> <td>Retain associated registers when in EM2/3</td> </tr> <tr> <td>2</td> <td>RADIONORETAIN</td> <td>Bit[1]. When set, do not retain RADIO associated registers when in EM2/3</td> </tr> </tbody> </table>                                                                                                                              |                |                                                                          |        |                                                                                                                                                                   | Value | Mode | Description | 1 | PERIPHNORETAIN | Retain associated registers when in EM2/3 | 2 | RADIONORETAIN | Bit[1]. When set, do not retain RADIO associated registers when in EM2/3 |
| Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Mode           | Description                                                              |        |                                                                                                                                                                   |       |      |             |   |                |                                           |   |               |                                                                          |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PERIPHNORETAIN | Retain associated registers when in EM2/3                                |        |                                                                                                                                                                   |       |      |             |   |                |                                           |   |               |                                                                          |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RADIONORETAIN  | Bit[1]. When set, do not retain RADIO associated registers when in EM2/3 |        |                                                                                                                                                                   |       |      |             |   |                |                                           |   |               |                                                                          |

## 12.5.5 EMU\_IPVERSION - IP Version

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |           |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|-----------|---|---|---|---|---|---|
| 0x05C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x3 |           |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R   |           |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | IPVERSION |   |   |   |   |   |   |

| Bit  | Name       | Reset | Access | Description       |
|------|------------|-------|--------|-------------------|
| 31:0 | IPVERSION  | 0x3   | R      | <b>IP Version</b> |
|      | IP Version |       |        |                   |

## 12.5.6 EMU\_LOCK - EMU Configuration Lock Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 0x060         | 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 |  |  |  |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bit   | Name                                               | Reset  | Access              | Description                                                                                                                                                                       |
|-------|----------------------------------------------------|--------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved                                           |        |                     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | LOCKKEY                                            | 0xADE8 | W                   | <b>Lock Key</b>                                                                                                                                                                   |
|       | Write any other value than the unlock code to lock |        |                     |                                                                                                                                                                                   |
|       | Value                                              | Mode   | Description         |                                                                                                                                                                                   |
|       | 44520                                              | UNLOCK | Unlock EMU register |                                                                                                                                                                                   |

### **12.5.7 EMU IF - Interrupt Flags**

| Offset | Bit Position |     |     |            |     |    |            |     |
|--------|--------------|-----|-----|------------|-----|----|------------|-----|
| Reset  | 0x0          | 31  | 0x0 | 30         | 0x0 | 29 | 0x0        | 28  |
| Access | RW           | 0x0 | 27  | RW         | 0x0 | 26 | RW         | 0x0 |
| Name   | TEMPHIGH     | 0x0 | 31  | VSCALEDONE | 0x0 | 25 | EM23WAKEUP | 0x0 |
|        | TEMPLOW      | 0x0 | 30  |            | 0x0 | 24 |            | 0x0 |
|        | TEMP         | 0x0 | 29  |            | 0x0 | 23 |            | 0x0 |
|        | TEMPAVG      | 0x0 | 27  |            | 0x0 | 22 |            | 0x0 |
|        |              |     |     |            | 0x0 | 21 |            | 0x0 |
|        |              |     |     |            | 0x0 | 20 |            | 0x0 |
|        |              |     |     |            | 0x0 | 19 |            | 0x0 |
|        |              |     |     |            | 0x0 | 18 |            | 0x0 |
|        |              |     |     |            | 0x0 | 17 | IOVDD0BOD  | 0x0 |
|        |              |     |     |            | 0x0 | 16 | AVDDBOD    | 0x0 |

| Bit   | Name       | Reset                                                                                                                                                                             | Access | Description                                                                    |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------|
| 31    | TEMPHIGH   | 0x0                                                                                                                                                                               | RW     | <b>Temperature high Interrupt flag</b><br>Measured temperature above threshold |
| 30    | TEMPLOW    | 0x0                                                                                                                                                                               | RW     | <b>Temperature low Interrupt flag</b><br>Measured temperature below threshold  |
| 29    | TEMP       | 0x0                                                                                                                                                                               | RW     | <b>Temperature Interrupt flag</b><br>Temperature Update                        |
| 28    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                |
| 27    | TEMPAVG    | 0x0                                                                                                                                                                               | RW     | <b>Temperature Average Interrupt flag</b><br>Averaged Temperature Update       |
| 26    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                |
| 25    | VSCALEDONE | 0x0                                                                                                                                                                               | RW     | <b>Vscale done Interrupt flag</b><br>Voltage scaling completed. EM0 only.      |
| 24    | EM23WAKEUP | 0x0                                                                                                                                                                               | RW     | <b>EM23 Wake up Interrupt flag</b><br>EM23 wake up                             |
| 23:18 | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                |
| 17    | IOVDD0BOD  | 0x0                                                                                                                                                                               | RW     | <b>VDDIO0 BOD Interrupt flag</b><br>IOVDD0 BOD triggered                       |
| 16    | AVDDBOD    | 0x0                                                                                                                                                                               | RW     | <b>AVDD BOD Interrupt flag</b><br>AVDD BOD triggered                           |
| 15:0  | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                |

### 12.5.8 EMU IEN - Interrupt Enables

| Offset | Bit Position |    |     |    |  |  |  |  |
|--------|--------------|----|-----|----|--|--|--|--|
| Reset  | TEMPHIGH     | RW | 0x0 | 31 |  |  |  |  |
| Access | TEMPLOW      | RW | 0x0 | 30 |  |  |  |  |
|        | TEMP         | RW | 0x0 | 29 |  |  |  |  |
|        |              |    |     | 28 |  |  |  |  |
| Name   | TEMPAVG      | RW | 0x0 | 27 |  |  |  |  |
|        |              |    |     | 26 |  |  |  |  |
|        | VSCALEDONE   | RW | 0x0 | 25 |  |  |  |  |
|        | EM23WAKEUP   | RW | 0x0 | 24 |  |  |  |  |
|        |              |    |     | 23 |  |  |  |  |
|        |              |    |     | 22 |  |  |  |  |
|        |              |    |     | 21 |  |  |  |  |
|        |              |    |     | 20 |  |  |  |  |
|        |              |    |     | 19 |  |  |  |  |
|        |              |    |     | 18 |  |  |  |  |
|        | IOVDD0BOD    | RW | 0x0 | 17 |  |  |  |  |
|        | AVDDBOD      | RW | 0x0 | 16 |  |  |  |  |
|        |              |    |     | 15 |  |  |  |  |
|        |              |    |     | 14 |  |  |  |  |
|        |              |    |     | 13 |  |  |  |  |
|        |              |    |     | 12 |  |  |  |  |
|        |              |    |     | 11 |  |  |  |  |
|        |              |    |     | 10 |  |  |  |  |
|        |              |    |     | 9  |  |  |  |  |
|        |              |    |     | 8  |  |  |  |  |
|        |              |    |     | 7  |  |  |  |  |
|        |              |    |     | 6  |  |  |  |  |
|        |              |    |     | 5  |  |  |  |  |
|        |              |    |     | 4  |  |  |  |  |
|        |              |    |     | 3  |  |  |  |  |
|        |              |    |     | 2  |  |  |  |  |
|        |              |    |     | 1  |  |  |  |  |
|        |              |    |     | 0  |  |  |  |  |

| Bit   | Name       | Reset                                                                                                                                                                             | Access | Description                                                                                       |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------|
| 31    | TEMPHIGH   | 0x0                                                                                                                                                                               | RW     | <b>Temperature high Interrupt enable</b><br>Measured temperature above threshold Interrupt enable |
| 30    | TEMPLOW    | 0x0                                                                                                                                                                               | RW     | <b>Temperature low Interrupt enable</b><br>Measured temperature below threshold Interrupt enable  |
| 29    | TEMP       | 0x0                                                                                                                                                                               | RW     | <b>Temperature Interrupt enable</b><br>Temperature Update Interrupt enable                        |
| 28    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                   |
| 27    | TEMPAVG    | 0x0                                                                                                                                                                               | RW     | <b>Temperature Interrupt enable</b><br>Averaged Temperature Interrupt enable                      |
| 26    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                   |
| 25    | VSCALEDONE | 0x0                                                                                                                                                                               | RW     | <b>Vscale done Interrupt enable</b><br>Voltage scaling completed Interrupt enable. EM0 only.      |
| 24    | EM23WAKEUP | 0x0                                                                                                                                                                               | RW     | <b>EM23 Wake up Interrupt enable</b><br>EM23 wake up Interrupt enable                             |
| 23:18 | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                   |
| 17    | IOVDD0BOD  | 0x0                                                                                                                                                                               | RW     | <b>VDDIO0 BOD Interrupt enable</b><br>IOVDD0 BOD Interrupt enable                                 |
| 16    | AVDDBOD    | 0x0                                                                                                                                                                               | RW     | <b>AVDD BOD Interrupt enable</b><br>AVDD BOD Interrupt enable                                     |
| 15:0  | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                   |

## 12.5.9 EMU\_EM4CTRL - EM4 Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              |     |   |   |          |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------|-----|---|---|----------|---|---|---|
| 0x06C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0          | 0x0 |   |   |          |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW           |     |   |   |          |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | EM4IORETMODE |     |   |   | EM4ENTRY |   |   |   |

| Bit  | Name           | Reset     | Access | Description                                                                                                                                                           |
|------|----------------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved       |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>     |
| 8    | BOD3SENSEEM4WU | 0x0       | RW     | <b>Set BOD3SENSE as EM4 wakeup</b><br><br>Enable BOD3SENSE as EM4 wakeup source                                                                                       |
| 7:6  | Reserved       |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>     |
| 5:4  | EM4IORETMODE   | 0x0       | RW     | <b>EM4 IO retention mode</b><br><br>Determine when IO retention will be applied and removed                                                                           |
|      | Value          | Mode      |        | Description                                                                                                                                                           |
|      | 0              | DISABLE   |        | No Retention: Pads enter reset state when entering EM4                                                                                                                |
|      | 1              | EM4EXIT   |        | Retention through EM4: Pads enter reset state when exiting EM4                                                                                                        |
|      | 2              | SWUNLATCH |        | Retention through EM4 and Wakeup: software writes UNLATCH register to remove retention                                                                                |
| 3:2  | Reserved       |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>     |
| 1:0  | EM4ENTRY       | 0x0       | RW     | <b>EM4 entry request</b><br><br>This field is used to enter the Energy Mode 4 sequence. Writing the sequence 2,3,2,3,2,3,2,3,2 will enter the part into Energy Mode 4 |

## 12.5.10 EMU\_CMD - EMU Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x070  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 18    | TAMPERRCCLR | 0x0   | W(nB)  | <b>Tamper Reset Cause Clear</b><br><br>Set this bit to clear the TAMPERRSTCAUSE register. Root access only                                                                        |
| 17    | RSTCAUSECLR | 0x0   | W(nB)  | <b>Reset Cause Clear</b><br><br>Set this bit to clear the RMURSTCAUSE register                                                                                                    |
| 16:12 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11    | EM01VSCALE2 | 0x0   | W(nB)  | <b>Scale voltage to Vscale2</b><br><br>EM01 Voltage Scale Command to scale to Voltage Scale Level 2                                                                               |
| 10    | EM01VSCALE1 | 0x0   | W(nB)  | <b>Scale voltage to Vscale1</b><br><br>EM01 Voltage Scale Command to scale to Voltage Scale Level 1                                                                               |
| 9:5   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4     | TEMPAVGREQ  | 0x0   | W(nB)  | <b>Temperature Average Request</b><br><br>Request for Averaged Temperature Measurement                                                                                            |
| 3:2   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1     | EM4UNLATCH  | 0x0   | W(nB)  | <b>EM4 unlatch</b><br><br>GPIO unlatch request after EM4 wakeup. Only valid when EM4IORETMODE== SWUNLATCH                                                                         |
| 0     | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

### 12.5.11 EMU\_CTRL - EMU Control Register

| Bit   | Name               | Reset   | Access | Description                                                                                                                                                                                                    |
|-------|--------------------|---------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | EFPDRV DVDD        | 0x0     | RW     | <b>EFP drives DVDD</b><br><br>EFP01 Drives DVDD. EFP IRQ is enabled on PC5. VREGVDD and DVDD pins should be shorted together on the PCB.                                                                       |
| 30    | EFPDRV DECOUPLE    | 0x0     | RW     | <b>EFP drives DECOUPLE</b><br><br>EFP01 Drives DECOUPLE. Internal LDOs are disabled, EMU voltage scaling is done through EFP01, and EFP IRQ is enabled on PC5.                                                 |
| 29    | EFPDIRECTMODEEN    | 0x0     | RW     | <b>EFP Direct Mode Enable</b><br><br>EFP01 Direct mode enable. EMU drive I2C lines to transition EFP01 between energy modes. Firmware must use I2C1 module with SDA routed to PC1 and SCL routed to SC2.       |
| 28:17 | Reserved           |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 16    | FLASHPWRUPONDEMAND | 0x0     | RW     | <b>Enable flash on demand wakeup</b><br><br>When set, during wake up, Flash will be in power down mode until either incoming Flash data fetch or when software issue powerup command to IMEM->MSC_CMD register |
| 15:10 | Reserved           |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 9:8   | EM23VSCALE         | 0x2     | RW     | <b>EM2/EM3 Vscale</b><br><br>Set VSCALE value for EM2/EM3 mode                                                                                                                                                 |
|       | Value              | Mode    |        | Description                                                                                                                                                                                                    |
|       | 0                  | VSCALE0 |        | VSCALE0. 0.9v                                                                                                                                                                                                  |
|       | 1                  | VSCALE1 |        | VSCALE1. 1.0v                                                                                                                                                                                                  |
|       | 2                  | VSCALE2 |        | VSCALE2. 1.1v                                                                                                                                                                                                  |
| 7:4   | Reserved           |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 3     | TEMPAVGNUM         | 0x0     | RW     | <b>Averaged Temperature samples num</b><br><br>Number of samples taken for Averaged Temperature Measurement                                                                                                    |

| Bit | Name      | Reset | Access | Description                                                                                                                                                                       |
|-----|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Value     | Mode  |        | Description                                                                                                                                                                       |
| 0   |           | N16   |        | 16 measurements                                                                                                                                                                   |
| 1   |           | N64   |        | 64 measurements                                                                                                                                                                   |
| 2:1 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0   | EM2DBGGEN | 0x0   | RW     | <b>Enable debugging in EM2</b>                                                                                                                                                    |
|     |           |       |        | Force debug power domain to stay on on EM2 entry. This allows debugger to remain connected in EM2.                                                                                |

### 12.5.12 EMU\_TEMPLIMITS - EMU Temperature Thresholds

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x078  | 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 |
| Reset  | 0x1FF        |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    | RW      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | TEMPHIGH     |    |    |    |    |    |    |    |    |    |    |    |    |    | TEMPLOW |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 24:16 | TEMPHIGH | 0x1FF | RW     | <b>Temp High limit</b>                                                                                                                                                            |
|       |          |       |        | Temp threshold in degree Kelvin. The TEMPHIGH interrupt flag is set when a periodic temperature measurement is equal to or higher than this value.                                |
| 15:9  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8:0   | TEMPLOW  | 0x0   | RW     | <b>Temp Low limit</b>                                                                                                                                                             |
|       |          |       |        | Temp threshold in degree Kelvin. The TEMPLOW interrupt flag is set when a periodic temperature measurement is equal to or lower than this value.                                  |

## 12.5.13 EMU\_STATUS - EMU Status Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |     |               |    |            |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|-----|---------------|----|------------|----|
| 0x084         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         | 15  | 14            | 13 | 12         | 11 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R          | 0x0 | 10            |    |            |    |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R          | 0x0 | 9             | R  | 0x0        |    |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R          | 0x2 | 6             | R  | 0x0        |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EM2ENTERED |     | VSCALEFAILED  |    | VSCALEBUSY |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EM4IORET   |     | TEMPAVGACTIVE |    | TEMPACTIVE |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RACACTIVE  |     | FIRSTTEMPDONE |    | LOCK       |    |

| Bit   | Name            | Reset   | Access | Description                                                                                                                                                                       |
|-------|-----------------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | <b>Reserved</b> |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 10    | EM2ENTERED      | 0x0     | R      | <b>EM2 entered</b><br><br>Confirm chip entered EM2 state. EM2 Entry request can be delayed or denied by peripherals.                                                              |
| 9     | EM4IORET        | 0x0     | R      | <b>EM4 IO retention status</b><br><br>The status of IO retention. Will be set upon EM4 entry based on EM4IORETMODE in EMU_EM4CTRL. Cleared by setting EM4UNLATCH in EMU_CMD       |
| 8     | RACACTIVE       | 0x0     | R      | <b>RAC active</b><br><br>This bit indicates the status of the RAC state machine. System can not enter EM2 or lower if set.                                                        |
| 7:6   | VSCALE          | 0x2     | R      | <b>Vscale status</b><br><br>Current Voltage Scale Value                                                                                                                           |
|       | Value           | Mode    |        | Description                                                                                                                                                                       |
|       | 0               | VSCALE0 |        | Voltage scaling set to 0.9v                                                                                                                                                       |
|       | 1               | VSCALE1 |        | Voltage scaling set to 1.0v                                                                                                                                                       |
|       | 2               | VSCALE2 |        | Voltage scaling set to 1.1v                                                                                                                                                       |
| 5     | VSCALEFAILED    | 0x0     | R      | <b>Vscale failed</b><br><br>Voltage scaling failed. (Time out)                                                                                                                    |
| 4     | VSCALEBUSY      | 0x0     | R      | <b>Vscale busy</b><br><br>Voltage Scaling busy                                                                                                                                    |
| 3     | TEMPAVGACTIVE   | 0x0     | R      | <b>Temp Average active</b><br><br>Average Temperature Measurement active                                                                                                          |
| 2     | TEMPACTIVE      | 0x0     | R      | <b>Temp active</b><br><br>Temperature Measurement active                                                                                                                          |
| 1     | FIRSTTEMPDONE   | 0x0     | R      | <b>First Temp done</b><br><br>First Temperatue mesaurement completed                                                                                                              |
| 0     | LOCK            | 0x0     | R      | <b>Lock status</b><br><br>Indicates the current status of EMU Lock                                                                                                                |

| Bit | Name  | Reset    | Access | Description                              |
|-----|-------|----------|--------|------------------------------------------|
|     | Value | Mode     |        | Description                              |
| 0   |       | UNLOCKED |        | All EMU lockable registers are unlocked. |
| 1   |       | LOCKED   |        | All EMU lockable registers are locked.   |

#### 12.5.14 EMU\_TEMP - Temperature

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |     |    |         |    |    |    |    |    |    |    |    |   |     |      |   |   |   |   |   |   |         |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|-----|----|---------|----|----|----|----|----|----|----|----|---|-----|------|---|---|---|---|---|---|---------|---|--|
| 0x088  | 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       |   |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    | 0x0 |    |         |    |    |    |    |    |    |    |    |   | 0x0 |      |   |   |   |   |   |   |         |   |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |     | R  |         |    |    |    |    |    |    |    |    |   |     | R    |   |   |   |   |   |   |         |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |     |    | TEMPAVG |    |    |    |    |    |    |    |    |   |     | TEMP |   |   |   |   |   |   | TEMPLSB | R |  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 26:16 | TEMPAVG  | 0x0   | R      | <b>Averaged Temperature</b><br><br>Averaged Temperature Measurement. Temperature in Kelvin. 9 integer bits and 2 decimal bits (0.25 Degree resolution)                            |
| 15:11 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 10:2  | TEMP     | 0x0   | R      | <b>Temperature measured</b><br><br>Temperature in Kelvin. Value of last periodic temperature measurement. Value is asynchronously updated.                                        |
| 1:0   | TEMPLSB  | 0x0   | R      | <b>Temperature measured decimal part</b><br><br>Temperature decimal part                                                                                                          |

### 12.5.15 EMU\_RSTCTRL - Reset Management Control Register

| Bit   | Name           | Reset                                                | Access | Description                                                                                                                                                                                                                                                                                      |       |      |             |   |          |                          |   |         |                                                      |
|-------|----------------|------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|----------|--------------------------|---|---------|------------------------------------------------------|
| 31:11 | Reserved       |                                                      |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                |       |      |             |   |          |                          |   |         |                                                      |
| 10    | DECBODRMODE    | 0x1                                                  | RW     | <b>Enable DECBOD reset</b><br><br>LVBOD Reset Mode. DECOUPLE monitoring. BOD must be trimmed before it is used as a reset source.                                                                                                                                                                |       |      |             |   |          |                          |   |         |                                                      |
|       |                |                                                      |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLED</td><td>Reset request is blocked</td></tr> <tr> <td>1</td><td>ENABLED</td><td>The entire device is reset</td></tr> </tbody> </table>                           | Value | Mode | Description | 0 | DISABLED | Reset request is blocked | 1 | ENABLED | The entire device is reset                           |
| Value | Mode           | Description                                          |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 0     | DISABLED       | Reset request is blocked                             |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 1     | ENABLED        | The entire device is reset                           |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 9:8   | Reserved       |                                                      |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                |       |      |             |   |          |                          |   |         |                                                      |
| 7     | IOVDD0BODRMODE | 0x0                                                  | RW     | <b>Enable VDDIO0 BOD reset</b><br><br>LEBOD2 Reset Mode. IOVDD0 monitoring. BOD must be trimmed before it is used as a reset source.                                                                                                                                                             |       |      |             |   |          |                          |   |         |                                                      |
|       |                |                                                      |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLED</td><td>Reset request is blocked</td></tr> <tr> <td>1</td><td>ENABLED</td><td>The entire device is reset except some EMU registers</td></tr> </tbody> </table> | Value | Mode | Description | 0 | DISABLED | Reset request is blocked | 1 | ENABLED | The entire device is reset except some EMU registers |
| Value | Mode           | Description                                          |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 0     | DISABLED       | Reset request is blocked                             |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 1     | ENABLED        | The entire device is reset except some EMU registers |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 6     | AVDDBODRMODE   | 0x0                                                  | RW     | <b>Enable AVDD BOD reset</b><br><br>LEBOD1 Reset Mode. AVDD monitoring. BOD must be trimmed before it is used as a reset source.                                                                                                                                                                 |       |      |             |   |          |                          |   |         |                                                      |
|       |                |                                                      |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLED</td><td>Reset Request is block</td></tr> <tr> <td>1</td><td>ENABLED</td><td>The entire device is reset except some EMU registers</td></tr> </tbody> </table>   | Value | Mode | Description | 0 | DISABLED | Reset Request is block   | 1 | ENABLED | The entire device is reset except some EMU registers |
| Value | Mode           | Description                                          |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 0     | DISABLED       | Reset Request is block                               |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 1     | ENABLED        | The entire device is reset except some EMU registers |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 5:4   | Reserved       |                                                      |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                |       |      |             |   |          |                          |   |         |                                                      |
| 3     | LOCKUPRMODE    | 0x0                                                  | RW     | <b>Enable M33 Lockup reset</b><br><br>Core LOCKUP Reset Mode                                                                                                                                                                                                                                     |       |      |             |   |          |                          |   |         |                                                      |
|       |                |                                                      |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLED</td><td>Reset Request is Block</td></tr> </tbody> </table>                                                                                                     | Value | Mode | Description | 0 | DISABLED | Reset Request is Block   |   |         |                                                      |
| Value | Mode           | Description                                          |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |
| 0     | DISABLED       | Reset Request is Block                               |        |                                                                                                                                                                                                                                                                                                  |       |      |             |   |          |                          |   |         |                                                      |

| Bit | Name       | Reset                                                                                                                                                                             | Access | Description                                                    |
|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------|
|     | 1          | ENABLED                                                                                                                                                                           |        | The entire device is reset except some EMU registers           |
| 2   | SYSRMODE   | 0x1                                                                                                                                                                               | RW     | <b>Enable M33 System reset</b><br><br>Core Sysreset Reset Mode |
|     | Value      | Mode                                                                                                                                                                              |        | Description                                                    |
|     | 0          | DISABLED                                                                                                                                                                          |        | Reset request is blocked                                       |
|     | 1          | ENABLED                                                                                                                                                                           |        | Device is reset except some EMU registers                      |
| 1   | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                |
| 0   | WDOG0RMODE | 0x1                                                                                                                                                                               | RW     | <b>Enable WDOG0 reset</b><br><br>WDOG0 Reset Mode              |
|     | Value      | Mode                                                                                                                                                                              |        | Description                                                    |
|     | 0          | DISABLED                                                                                                                                                                          |        | Reset request is blocked                                       |
|     | 1          | ENABLED                                                                                                                                                                           |        | The entire device is reset except some EMU registers           |

## 12.5.16 EMU\_RSTCAUSE - Reset Cause

| Offset    | Bit Position |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------|--------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x094     | 31           | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 |
| Reset     | 0x0          |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access    | R            |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name      | VREGIN       |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|           |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| SETAMPER  | R            | 0x0 | 13 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| IOVDD0BOD | R            | 0x0 | 11 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| AVDDBOD   | R            | 0x0 | 10 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| DEC BOD   | R            | 0x0 | 9  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| DVDDLEBOD | R            | 0x0 | 8  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| DVDBBOD   | R            | 0x0 | 7  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| SYSREQ    | R            | 0x0 | 6  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| LOCKUP    | R            | 0x0 | 5  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WDQG1     | R            | 0x0 | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WDQG0     | R            | 0x0 | 3  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| EM4       | R            | 0x0 | 2  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| PIN       | R            | 0x0 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| POR       | R            | 0x0 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | VREGIN    | 0x0   | R      | <b>DCDC VREGIN comparator</b><br><br>DCDC VREGIN comparator below threshold. For Information only, not a direct source for reset. Should be used to determine whether the previous reset was caused by DCDC input being too low to support current load. In this case it is advised to keep the chip in BYPASS mode and check battery level before re-enabling integrated DCDC |
| 30:14 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                              |
| 13    | SETAMPER  | 0x0   | R      | <b>SE Tamper event Reset</b><br><br>Last reset was a SE Tamper event reset                                                                                                                                                                                                                                                                                                     |
| 12    | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                              |
| 11    | IOVDD0BOD | 0x0   | R      | <b>LEBOD2 Reset</b><br><br>Brown Out Detector monitoring IOVDD0                                                                                                                                                                                                                                                                                                                |
| 10    | AVDDBOD   | 0x0   | R      | <b>LEBOD1 Reset</b><br><br>Brown Out Detector monitoring AVDD                                                                                                                                                                                                                                                                                                                  |
| 9     | DEC BOD   | 0x0   | R      | <b>LVBOD Reset</b><br><br>Brown Out Detector monitoring DECOUPLE                                                                                                                                                                                                                                                                                                               |
| 8     | DVDDLEBOD | 0x0   | R      | <b>LEBOD Reset</b><br><br>Brown Out Detector monitoring DVDD in EM2/3                                                                                                                                                                                                                                                                                                          |
| 7     | DVDBBOD   | 0x0   | R      | <b>HVBOD Reset</b><br><br>Brown Out Detector monitoring DVDD in EM0/1                                                                                                                                                                                                                                                                                                          |
| 6     | SYSREQ    | 0x0   | R      | <b>M33 Core Sys Reset</b><br><br>Last Reset was as M33 Core System reset                                                                                                                                                                                                                                                                                                       |
| 5     | LOCKUP    | 0x0   | R      | <b>M33 Core Lockup Reset</b><br><br>Last Reset was as M33 Core Lockup reset                                                                                                                                                                                                                                                                                                    |
| 4     | WDQG1     | 0x0   | R      | <b>Watchdog 1 Reset</b><br><br>Last reset was a Watchdog 1 reset                                                                                                                                                                                                                                                                                                               |
| 3     | WDQG0     | 0x0   | R      | <b>Watchdog 0 Reset</b><br><br>Last reset was a Watchdog 0 reset                                                                                                                                                                                                                                                                                                               |
| 2     | EM4       | 0x0   | R      | <b>EM4 Wakeup Reset</b>                                                                                                                                                                                                                                                                                                                                                        |

| Bit                             | Name | Reset | Access | Description           |
|---------------------------------|------|-------|--------|-----------------------|
| Last reset was a EM4 Wakeup     |      |       |        |                       |
| 1                               | PIN  | 0x0   | R      | <b>Pin Reset</b>      |
| Last reset was a Pin reset      |      |       |        |                       |
| 0                               | POR  | 0x0   | R      | <b>Power On Reset</b> |
| Last reset was a Power On Reset |      |       |        |                       |

**12.5.17 EMU\_TAMPERRSTCAUSE - Tamper Reset Cause**

| Offset | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x098  | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0x0                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access | R                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | TAMPERRST                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit                                                                                                                                             | Name      | Reset | Access | Description                |
|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|----------------------------|
| 31:0                                                                                                                                            | TAMPERRST | 0x0   | R      | <b>Tamper reset vector</b> |
| Tamper reset vector. Reset cause indicator defining which tamper response index triggered the previous tamper reset.<br>Cleared with TAMPERCCLR |           |       |        |                            |

### **12.5.18 EMU\_DGIF - Interrupt Flags Debug**

| Bit   | Name           | Reset                                                                                                                                                                      | Access | Description                                                                    |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------|
| 31    | TEMPHIGHDGF    | 0x0                                                                                                                                                                        | RW     | <b>Temperature high Interrupt flag</b><br>Measured temperature above threshold |
| 30    | TEMPLOWDGIF    | 0x0                                                                                                                                                                        | RW     | <b>Temperature low Interrupt flag</b><br>Measured temperature below threshold  |
| 29    | TEMPDGIF       | 0x0                                                                                                                                                                        | RW     | <b>Temperature Interrupt flag</b><br>Temperature Update                        |
| 28:25 | Reserved       | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                |
| 24    | EM23WAKEUPDGIF | 0x0                                                                                                                                                                        | RW     | <b>EM23 Wake up Interrupt flag</b><br>EM23 wake up                             |
| 23:0  | Reserved       | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                |

## 12.5.19 EMU\_DGIEN - Interrupt Enables Debug

| Offset | Bit Position  |              |           |     |    |     |    |    |    |    |    |     |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|---------------|--------------|-----------|-----|----|-----|----|----|----|----|----|-----|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0A4  | 31            | 0x0          | 30        | 0x0 | 29 | 0x0 | 28 | 27 | 26 | 25 | 24 | 0x0 | 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reset  |               |              |           |     |    |     |    |    |    |    |    |     |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |               | RW           |           | RW  |    | RW  |    |    |    |    |    |     |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | TEMPHIGHDGIEN | TEMPLOWDGIEN | TEMPDGien |     |    |     |    |    |    |    |    |     | EM23WAKEUPDGIEN | RW |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | TEMPHIGHDGIEN   | 0x0   | RW     | <b>Temperature high interrupt enable</b><br><br>Measured temperature above threshold                                                                                              |
| 30    | TEMPLOWDGIEN    | 0x0   | RW     | <b>Temperature low interrupt enable</b><br><br>Measured temperature below threshold                                                                                               |
| 29    | TEMPDGien       | 0x0   | RW     | <b>Temperature interrupt enable</b><br><br>Temperature Update                                                                                                                     |
| 28:25 | Reserved        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 24    | EM23WAKEUPDGIEN | 0x0   | RW     | <b>EM23 Wake up interrupt enable</b><br><br>EM23 wake up                                                                                                                          |
| 23:0  | Reserved        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 12.5.20 EMU\_EFPIF - EFP Interrupt Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 0x100  | 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 |  |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | EFPIF    | 0x0   | RW     | <b>EFP interrupt flag</b><br><br>EFP interrupt                                                                                                                                    |

#### **12.5.21 EMU\_EFPIEN - EFP Interrupt Enable Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |    |        |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|----|--------|------|
| Reset  | 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 | 0x0 | RW | EFPIEN | Name |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |    |        |      |
| Offset | 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 | 0x0 | RW | EFPIEN | Name |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | EFPIEN   | 0x0   | RW     | <b>EFP Interrupt enable</b>                                                                                                                                                       |

Enable EFP Interrupt

## 12.6 DCDC Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description              |
|--------|---------------------|-------------|--------------------------|
| 0x000  | DCDC_IPVERSION      | R           | IPVERSION                |
| 0x004  | DCDC_CTRL           | RW SYNC     | Control                  |
| 0x008  | DCDC_EM01CTRL0      | RW SYNC     | EM01 Control             |
| 0x010  | DCDC_EM23CTRL0      | RW SYNC     | EM23 Control             |
| 0x020  | DCDC_PFMXCTRL       | RW SYNC     | PFMX Control Register    |
| 0x028  | DCDC_IF             | RWH INTFLAG | Interrupt Flags          |
| 0x02C  | DCDC_IEN            | RW          | Interrupt Enable         |
| 0x030  | DCDC_STATUS         | RH          | Status Register          |
| 0x034  | DCDC_SYNCBUSY       | RH          | Syncbusy Status Register |
| 0x040  | DCDC_LOCK           | W           | Lock Register            |
| 0x044  | DCDC_LOCKSTATUS     | RH          | Lock Status Register     |
| 0x1000 | DCDC_IPVERSION_SET  | R           | IPVERSION                |
| 0x1004 | DCDC_CTRL_SET       | RW SYNC     | Control                  |
| 0x1008 | DCDC_EM01CTRL0_SET  | RW SYNC     | EM01 Control             |
| 0x1010 | DCDC_EM23CTRL0_SET  | RW SYNC     | EM23 Control             |
| 0x1020 | DCDC_PFMXCTRL_SET   | RW SYNC     | PFMX Control Register    |
| 0x1028 | DCDC_IF_SET         | RWH INTFLAG | Interrupt Flags          |
| 0x102C | DCDC_IEN_SET        | RW          | Interrupt Enable         |
| 0x1030 | DCDC_STATUS_SET     | RH          | Status Register          |
| 0x1034 | DCDC_SYNCBUSY_SET   | RH          | Syncbusy Status Register |
| 0x1040 | DCDC_LOCK_SET       | W           | Lock Register            |
| 0x1044 | DCDC_LOCKSTATUS_SET | RH          | Lock Status Register     |
| 0x2000 | DCDC_IPVERSION_CLR  | R           | IPVERSION                |
| 0x2004 | DCDC_CTRL_CLR       | RW SYNC     | Control                  |
| 0x2008 | DCDC_EM01CTRL0_CLR  | RW SYNC     | EM01 Control             |
| 0x2010 | DCDC_EM23CTRL0_CLR  | RW SYNC     | EM23 Control             |
| 0x2020 | DCDC_PFMXCTRL_CLR   | RW SYNC     | PFMX Control Register    |
| 0x2028 | DCDC_IF_CLR         | RWH INTFLAG | Interrupt Flags          |
| 0x202C | DCDC_IEN_CLR        | RW          | Interrupt Enable         |
| 0x2030 | DCDC_STATUS_CLR     | RH          | Status Register          |
| 0x2034 | DCDC_SYNCBUSY_CLR   | RH          | Syncbusy Status Register |
| 0x2040 | DCDC_LOCK_CLR       | W           | Lock Register            |
| 0x2044 | DCDC_LOCKSTATUS_CLR | RH          | Lock Status Register     |
| 0x3000 | DCDC_IPVERSION_TGL  | R           | IPVERSION                |
| 0x3004 | DCDC_CTRL_TGL       | RW SYNC     | Control                  |

| Offset | Name                | Type        | Description              |
|--------|---------------------|-------------|--------------------------|
| 0x3008 | DCDC_EM01CTRL0_TGL  | RW SYNC     | EM01 Control             |
| 0x3010 | DCDC_EM23CTRL0_TGL  | RW SYNC     | EM23 Control             |
| 0x3020 | DCDC_PFMXCTRL_TGL   | RW SYNC     | PFMX Control Register    |
| 0x3028 | DCDC_IF_TGL         | RWH INTFLAG | Interrupt Flags          |
| 0x302C | DCDC_IEN_TGL        | RW          | Interrupt Enable         |
| 0x3030 | DCDC_STATUS_TGL     | RH          | Status Register          |
| 0x3034 | DCDC_SYNCBUSY_TGL   | RH          | Syncbusy Status Register |
| 0x3040 | DCDC_LOCK_TGL       | W           | Lock Register            |
| 0x3044 | DCDC_LOCKSTATUS_TGL | RH          | Lock Status Register     |

## 12.7 DCDC Register Description

### 12.7.1 DCDC\_IPVERSION - IPVERSION

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x2          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name             | Reset | Access | Description |
|------|------------------|-------|--------|-------------|
| 31:0 | IPVERSION        | 0x2   | R      | IPVERSION   |
|      | IPVERSION number |       |        |             |

## 12.7.2 DCDC\_CTRL - Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|---|---|---|---|---|---|--|--|--|
| 0x004  | 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 |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x10        |   |   |   |   |   |   |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW          |   |   |   |   |   |   |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | IPKTMAXCTRL |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MODE        |   |   |   |   |   |   |  |  |  |

| Bit   | Name        | Reset          | Access | Description                                                                                                                                                                                                                                                |
|-------|-------------|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9  | Reserved    |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                          |
| 8:4   | IPKTMAXCTRL | 0x10           | RW     | <b>Ton_max timeout control</b><br><br>Ton_max = (ipk_tmax_ctrl + 1)*0.07us; specifies the timeout duration when attempting to hit programmed peak current; TMAX interrupt flag gives user information whether timeout was hit before reaching peak current |
| 3:1   | Reserved    |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                          |
| 0     | MODE        | 0x0            | RW     | <b>DCDC/Bypass Mode Control</b><br><br>Used to switch between bypass and dc当地 regulation, this triggers a sequence of controls. IF/STATUS registers can be used to check the true status of DCDC regulator/bypass switch                                   |
| <hr/> |             |                |        |                                                                                                                                                                                                                                                            |
| Value |             | Mode           |        | Description                                                                                                                                                                                                                                                |
| 0     |             | BYPASS         |        | DCDC is OFF, bypass switch is enabled                                                                                                                                                                                                                      |
| 1     |             | DCDCREGULATION |        | Request DCDC regulation, bypass switch disabled                                                                                                                                                                                                            |
| <hr/> |             |                |        |                                                                                                                                                                                                                                                            |

## 12.7.3 DCDC\_EM01CTRL0 - EM01 Control

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |         |   |   |   |   |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|---|---|---|---|--------|
| 0x008  | 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 |        |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x1     |   |   |   |   | 0x9    |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW      |   |   |   |   | RW     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | DRVSPED |   |   |   |   | IPKVAL |

| Bit   | Name     | Reset                                                                                                           | Access          | Description                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|----------|-----------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:10 | Reserved |                                                                                                                 |                 | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9:8   | DRVSPED  | 0x1                                                                                                             | RW              | <b>EM01 Drive Speed Setting</b>                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | Used to configure drive speed for tradeoff between EMI and Efficiency                                           |                 |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | Value                                                                                                           | Mode            | Description                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 0                                                                                                               | BEST_EMI        | Not recommended for use (no benefit to this setting)                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 1                                                                                                               | DEFAULT_SETTING | Recommended for use for best efficiency and low EMI                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 2                                                                                                               | INTERMEDIATE    | Not recommended for use (no benefit to this setting)                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 3                                                                                                               | BEST EFFICIENCY | Not recommended for use (no benefit to this setting)                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7:4   | Reserved |                                                                                                                 |                 | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3:0   | IPKVAL   | 0x9                                                                                                             | RW              | <b>EM01 Peak Current Setting</b>                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | Used to configure for required peak/load current in EM01; Max load current is approximately $0.4 \times I_{pk}$ |                 |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | Value                                                                                                           | Mode            | Description                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 3                                                                                                               | LOAD36MA        | $I_{peak} = 90\text{mA}$ , $I_{load} = 36\text{mA}$                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 4                                                                                                               | LOAD40MA        | $I_{peak} = 100\text{mA}$ , $I_{load} = 40\text{mA}$                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 5                                                                                                               | LOAD44MA        | $I_{peak} = 110\text{mA}$ , $I_{load} = 44\text{mA}$                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 6                                                                                                               | LOAD48MA        | $I_{peak} = 120\text{mA}$ , $I_{load} = 48\text{mA}$                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 7                                                                                                               | LOAD52MA        | $I_{peak} = 130\text{mA}$ , $I_{load} = 52\text{mA}$                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 8                                                                                                               | LOAD56MA        | $I_{peak} = 140\text{mA}$ , $I_{load} = 56\text{mA}$                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       |          | 9                                                                                                               | LOAD60MA        | $I_{peak} = 150\text{mA}$ , $I_{load} = 60\text{mA}$                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 12.7.4 DCDC\_EM23CTRL0 - EM23 Control

| Offset  | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |   |   |   |   |
|---------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------|---|---|---|---|
| 0x010   | 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 |
| Reset   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x1    |   |   |   |   |
| Access  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x3    |   |   |   |   |
| Name    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW     |   |   |   |   |
| DRVSPED |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | IPKVAL |   |   |   |   |

| Bit   | Name                                                     | Reset                                                                 | Access | Description                                                                                                                                                       |
|-------|----------------------------------------------------------|-----------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                                                 |                                                                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | DRVSPED                                                  | 0x1                                                                   | RW     | <b>EM23 Drive Speed Setting</b>                                                                                                                                   |
|       |                                                          | Used to configure drive speed for tradeoff between EMI and Efficiency |        |                                                                                                                                                                   |
|       | Value                                                    | Mode                                                                  |        | Description                                                                                                                                                       |
|       | 0                                                        | BEST_EMI                                                              |        | Not recommended for use (no benefit to this setting)                                                                                                              |
|       | 1                                                        | DEFAULT_SETTING                                                       |        | Recommended for use for best efficiency and low EMI                                                                                                               |
|       | 2                                                        | INTERMEDIATE                                                          |        | Not recommended for use (no benefit to this setting)                                                                                                              |
|       | 3                                                        | BEST EFFICIENCY                                                       |        | Not recommended for use (no benefit to this setting)                                                                                                              |
| 7:4   | Reserved                                                 |                                                                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | IPKVAL                                                   | 0x3                                                                   | RW     | <b>EM23 Peak Current Setting</b>                                                                                                                                  |
|       | Used to configure for required peak/load current in EM23 |                                                                       |        |                                                                                                                                                                   |
|       | Value                                                    | Mode                                                                  |        | Description                                                                                                                                                       |
|       | 3                                                        | LOAD5MA                                                               |        | Ipeak = 90mA, Iload = 5 mA                                                                                                                                        |
|       | 9                                                        | LOAD10MA                                                              |        | Ipeak = 150mA, Iload = 10 mA                                                                                                                                      |

## 12.7.5 DCDC\_PFMXCTRL - PFMX Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--------|
| 0x020  | 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 |  |  |        |
| Reset  | 0xC          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |        |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |        |
| Name   | IPKTMAXCTRL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  | IPKVAL |

| Bit   | Name                                                          | Reset                                                                                                                                                                      | Access | Description                           |
|-------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------|
| 31:13 | Reserved                                                      | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                       |
| 12:8  | IPKTMAXCTRL                                                   | 0xC                                                                                                                                                                        | RW     | <b>Ton_max timeout control</b>        |
| 7:4   | Reserved                                                      | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                       |
| 3:0   | IPKVAL                                                        | 0xC                                                                                                                                                                        | RW     | <b>PFMX mode Peak Current Setting</b> |
|       | Used to configure for required peak/load current in PFMX mode |                                                                                                                                                                            |        |                                       |
| Value | Mode                                                          | Description                                                                                                                                                                |        |                                       |
| 3     | LOAD50MA                                                      | Ipeak = 90 mA, Iload = 50 mA                                                                                                                                               |        |                                       |
| 4     | LOAD65MA                                                      | Ipeak = 100 mA, Iload = 65 mA                                                                                                                                              |        |                                       |
| 5     | LOAD73MA                                                      | Ipeak = 110 mA, Iload = 73 mA                                                                                                                                              |        |                                       |
| 6     | LOAD80MA                                                      | Ipeak = 120 mA, Iload = 80 mA                                                                                                                                              |        |                                       |
| 7     | LOAD86MA                                                      | Ipeak = 130 mA, Iload = 86 mA                                                                                                                                              |        |                                       |
| 8     | LOAD93MA                                                      | Ipeak = 140 mA, Iload = 93 mA                                                                                                                                              |        |                                       |
| 9     | LOAD100MA                                                     | Ipeak = 150 mA, Iload = 100 mA                                                                                                                                             |        |                                       |
| 10    | LOAD106MA                                                     | Ipeak = 160 mA, Iload = 106 mA                                                                                                                                             |        |                                       |
| 11    | LOAD113MA                                                     | Ipeak = 170 mA, Iload = 113 mA                                                                                                                                             |        |                                       |
| 12    | LOAD120MA                                                     | Ipeak = 180 mA, Iload = 120 mA                                                                                                                                             |        |                                       |

## 12.7.6 DCDC\_IF - Interrupt Flags

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |           |         |      |            |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|-----------|---------|------|------------|
| 0x028         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14         | 13        | 12      | 11   | 10         |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | 0x0       | 9       | 8    |            |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | RW        | 0x0     | 7    |            |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | PFMXMODE  | EM4ERR  | TMAX | REGULATION |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | VREGINHIGH | VREGINLOW | RUNNING | WARM | BYPSW      |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         | 0x0       | 6       | 0x0  | 5          |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0        | 4         | 0x0     | 3    | 0x0        |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         | 0x0       | 2       | 0x0  | 1          |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0        | 0         | 0x0     | 0    | 0x0        |

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                                         |
|-------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                   |
| 9     | PFMXMODE        | 0x0   | RW     | <b>Entered PFMX mode</b><br><br>Entered PFMX mode                                                                                                                                                   |
| 8     | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                   |
| 7     | EM4ERR          | 0x0   | RW     | <b>EM4 Entry Request Error</b><br><br>EM4 entry error - software requesting EM4 entry when bypass switch is disabled                                                                                |
| 6     | TMAX            | 0x0   | RW     | <b>Ton_max Timeout Reached</b><br><br>Ton_max timeout was reached before peak current could be achieved                                                                                             |
| 5     | REGULATION      | 0x0   | RW     | <b>DCDC in regulation</b><br><br>DCDC in regulation, output voltage is in range of target voltage                                                                                                   |
| 4     | VREGINHIGH      | 0x0   | RW     | <b>VREGIN above threshold</b><br><br>VREGIN/VBAT above threshold                                                                                                                                    |
| 3     | VREGINLOW       | 0x0   | RW     | <b>VREGIN below threshold</b><br><br>VREGIN/VBAT below threshold                                                                                                                                    |
| 2     | RUNNING         | 0x0   | RW     | <b>DCDC Running</b><br><br>biasen, vcmpen, buckmodeen=1, bypass switch has been turned off.. Note that DCDC might not be in regulation yet. ie output voltage may not be in range of target voltage |
| 1     | WARM            | 0x0   | RW     | <b>DCDC Warmup Time Done</b><br><br>100us DCDC warmup time since biasen=1 and ddcvcmpen=1 complete                                                                                                  |
| 0     | BYPSW           | 0x0   | RW     | <b>Bypass Switch Enabled</b><br><br>Bypass Switch Enabled                                                                                                                                           |

## 12.7.7 DCDC\_IEN - Interrupt Enable

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |     |     |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|-----|-----|----|
| 0x02C         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13         | 12  | 11  | 10 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0        | 9   | 8   |    |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         | 0x0 | 7   |    |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PFMXMODE   |     |     |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EM4ERR     | RW  | 0x0 |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TMAX       | RW  | 0x0 |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REGULATION | RW  | 0x0 |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | VREGINHIGH | RW  | 0x0 |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | VREGINLOW  | RW  | 0x0 |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RUNNING    | RW  | 0x0 |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WARM       | RW  | 0x0 |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BYPSW      | RW  | 0x0 |    |

| Bit   | Name                                     | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | <i>Reserved</i>                          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9     | PFMXMODE                                 | 0x0   | RW     | <b>PFMX Mode Interrupt Enable</b>                                                                                                                                                 |
|       | PFMX Mode Interrupt Enable               |       |        |                                                                                                                                                                                   |
| 8     | <i>Reserved</i>                          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7     | EM4ERR                                   | 0x0   | RW     | <b>EM4 Entry Req Interrupt Enable</b>                                                                                                                                             |
|       | EM4 Entry Request Error Interrupt Enable |       |        |                                                                                                                                                                                   |
| 6     | TMAX                                     | 0x0   | RW     | <b>Ton_max Timeout Interrupt Enable</b>                                                                                                                                           |
|       | Ton_max Timeout Interrupt Enable         |       |        |                                                                                                                                                                                   |
| 5     | REGULATION                               | 0x0   | RW     | <b>DCDC in Regulation Interrupt Enable</b>                                                                                                                                        |
|       | DCDC in Regulation Interrupt Enable      |       |        |                                                                                                                                                                                   |
| 4     | VREGINHIGH                               | 0x0   | RW     | <b>VREGIN above threshold Interrupt Enable</b>                                                                                                                                    |
|       | VREGIN above threshold Interrupt Enable  |       |        |                                                                                                                                                                                   |
| 3     | VREGINLOW                                | 0x0   | RW     | <b>VREGIN below threshold Interrupt Enable</b>                                                                                                                                    |
|       | VREGIN below threshold Interrupt Enable  |       |        |                                                                                                                                                                                   |
| 2     | RUNNING                                  | 0x0   | RW     | <b>DCDC Running Interrupt Enable</b>                                                                                                                                              |
|       | DCDC Running Interrupt Enable            |       |        |                                                                                                                                                                                   |
| 1     | WARM                                     | 0x0   | RW     | <b>DCDC Warmup Time Done Interrupt Enable</b>                                                                                                                                     |
|       | DCDC Warmup Time Done Interrupt Enable   |       |        |                                                                                                                                                                                   |
| 0     | BYPSW                                    | 0x0   | RW     | <b>Bypass Switch Enabled Interrupt Enable</b>                                                                                                                                     |
|       | Bypass Switch Enabled Interrupt Enable   |       |        |                                                                                                                                                                                   |

## 12.7.8 DCDC\_STATUS - Status Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|
| 0x030  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 4 |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 3 |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 2 |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 1 |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |   |

| Bit   | Name                                                             | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                                                         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9     | PFMXMODE                                                         | 0x0   | R      | <b>DCDC in PFMX mode</b>                                                                                                                                                          |
|       | DCDC in pfmx mode                                                |       |        |                                                                                                                                                                                   |
| 8:5   | Reserved                                                         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4     | BYPCMOUT                                                         | 0x0   | R      | <b>Bypass Comparator Output</b>                                                                                                                                                   |
|       | Bypass Comparator Output                                         |       |        |                                                                                                                                                                                   |
| 3     | VREGIN                                                           | 0x0   | R      | <b>VREGVDD comparator status</b>                                                                                                                                                  |
|       | 0: VREGVDD above threshold, 1: VREGVDD below threshold           |       |        |                                                                                                                                                                                   |
| 2     | RUNNING                                                          | 0x0   | R      | <b>DCDC is running</b>                                                                                                                                                            |
|       | DCDC is running (buckmodeen=1, ddcvcvcmpen=1, biasen=1, bypsw=0) |       |        |                                                                                                                                                                                   |
| 1     | WARM                                                             | 0x0   | R      | <b>DCDC Warmup Done</b>                                                                                                                                                           |
|       | 100us DCDC warmup time since biasen=1 and ddcvcvcmpen=1 complete |       |        |                                                                                                                                                                                   |
| 0     | BYPSW                                                            | 0x0   | R      | <b>Bypass Switch is currently enabled</b>                                                                                                                                         |
|       | Bypass switch is currently enabled                               |       |        |                                                                                                                                                                                   |

## 12.7.9 DCDC\_SYNCBUSY - Syncbusy Status Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |     |   |     |           |     |     |     |           |   |     |   |           |   |     |   |      |   |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|-----|---|-----|-----------|-----|-----|-----|-----------|---|-----|---|-----------|---|-----|---|------|---|-----|---|
| 0x034  | 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   |     |           |   |     |   |           |   |     |   |      |   |     |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |     |   |     |           |     |     |     |           |   |     |   |           |   |     |   |      |   |     |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | R        | 0x0 | R | 0x0 | R         | 0x0 | R   | 0x0 | R         |   |     |   |           |   |     |   |      |   |     |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PFMXCTRL |     |   |     | EM23CTRL0 | R   | 0x0 | 3   | EM01CTRL1 | R | 0x0 | 2 | EM01CTRL0 | R | 0x0 | 1 | CTRL | R | 0x0 | 0 |

| Bit  | Name                       | Reset | Access | Description                                                                                                                                                                       |
|------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7    | PFMXCTRL                   | 0x0   | R      | <b>PFMXCTRL Sync Busy Status</b>                                                                                                                                                  |
|      | PFMXCTRL Sync Busy Status  |       |        |                                                                                                                                                                                   |
| 6:4  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3    | EM23CTRL0                  | 0x0   | R      | <b>EM23CTRL0 Sync Busy Status</b>                                                                                                                                                 |
|      | EM23CTRL0 Sync Busy Status |       |        |                                                                                                                                                                                   |
| 2    | EM01CTRL1                  | 0x0   | R      | <b>EM01CTRL1 Sync Bust Status</b>                                                                                                                                                 |
|      | EM01CTRL1 Sync Bust Status |       |        |                                                                                                                                                                                   |
| 1    | EM01CTRL0                  | 0x0   | R      | <b>EM01CTRL0 Sync Busy Status</b>                                                                                                                                                 |
|      | EM01CTRL0 Sync Busy Status |       |        |                                                                                                                                                                                   |
| 0    | CTRL                       | 0x0   | R      | <b>CTRL Sync Busy Status</b>                                                                                                                                                      |
|      | CTRL Sync Busy Status      |       |        |                                                                                                                                                                                   |

**12.7.10 DCDC\_LOCK - Lock Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| 0x040         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W       |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LOCKKEY |   |   |   |   |   |   |   |

| Bit                                                                   | Name     | Reset     | Access      | Description                                                                                                                                                                       |
|-----------------------------------------------------------------------|----------|-----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                 | Reserved |           |             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                  | LOCKKEY  | 0x0       | W           | <b>Configuration Lock Key</b>                                                                                                                                                     |
| Write any other value than the unlock code to lock all DCDC registers |          |           |             |                                                                                                                                                                                   |
| Value                                                                 |          | Mode      | Description |                                                                                                                                                                                   |
| 43981                                                                 |          | UNLOCKKEY |             |                                                                                                                                                                                   |

**12.7.11 DCDC\_LOCKSTATUS - Lock Status Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 <td data-kind="ghost"></td> |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------------|---|---|---|---|---|---|---|
| 0x044         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R                               |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LOCK                            |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                 |   |   |   |   |   |   |   |

| Bit                            | Name     | Reset    | Access         | Description                                                                                                                                                                       |
|--------------------------------|----------|----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1                           | Reserved |          |                | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0                              | LOCK     | 0x0      | R              | <b>Lock Status</b>                                                                                                                                                                |
| Lock Status Read-Only Register |          |          |                |                                                                                                                                                                                   |
| Value                          |          | Mode     | Description    |                                                                                                                                                                                   |
| 0                              |          | UNLOCKED | Unlocked State |                                                                                                                                                                                   |
| 1                              |          | LOCKED   | LOCKED STATE   |                                                                                                                                                                                   |

## 13. PRS - Peripheral Reflex System



### Quick Facts

#### What?

The PRS (Peripheral Reflex System) allows configurable, fast, and autonomous communication between peripherals.

#### Why?

Events and signals from one peripheral can be used as input signals to trigger actions in other peripherals. PRS reduces latency and ensures predictable timing by reducing software overhead and thus current consumption.

#### How?

Without CPU intervention the peripherals can send reflex signals to each other in single- or chained steps. The peripherals can be set up to perform actions based on the incoming reflex signals. This results in improved system performance and reduced energy consumption.

### 13.1 Introduction

The Peripheral Reflex System is a signal routing network allowing direct communication between different peripheral modules without involving the CPU. Peripheral modules which send out reflex signals to the PRS are called producers, and modules accepting reflex signals are called consumers. The PRS routes the reflex signals from producer to consumer peripherals, which perform actions depending on the reflex signals received.

### 13.2 Features

#### 16 configurable asynchronous channels

- Each channel can be connected to any producer
- Consumers can be configured to listen to any asynchronous channel
- Can generate events to the CPU and the DMA
- Software controlled channel output using the SWPULSE and SWLEVEL registers
- Configurable logic to implement combinational functions between channels; multiple channels may be cascaded to produce more complex functions

#### 4 configurable synchronous channels

- Special set of channels for high speed signalling between IADC and TIMER blocks

### 13.3 Functional Description

The PRS contains 16 asynchronous and 4 synchronous reflex channels. An overview of an asynchronous PRS reflex channel is shown in [Figure 13.1 PRS Asynchronous Channel Overview on page 347](#). Synchronous channels are similar but do not include the configurable logic block or SWLEVEL / SWPULSE features. Asynchronous channels can be connected to any signal offered by the producers while the synchronous channels are restricted to special signals from the TIMER, IADC, and VDAC modules.

Similarly on the consumer side, all the peripherals can listen to asynchronous channels while only the TIMER, IADC, and VDAC modules can listen to synchronous channels. The consumers of a channel (synchronous or asynchronous) can choose which PRS channel to listen to and perform actions based on the reflex signals routed through that channel. Synchronous channels are only available in EM0 and EM1 while asynchronous channels are available in EM0, EM1, EM2 and EM3.



**Figure 13.1. PRS Asynchronous Channel Overview**

#### 13.3.1 Asynchronous Channel Functions

Different functions can be applied to a reflex signal within the PRS. The asynchronous PRS channels can be manually triggered by writing to PRS\_ASYNC\_SWPULSE or PRS\_ASYNC\_SWLEVEL. SWLEVEL[n] is a programmable level for each asynchronous channel and holds the value it is programmed to. Setting SWPULSE[n] will cause the asynchronous channel to output a high pulse that is one EM01GRPACLK clock cycle wide. The SWLEVEL[n] and SWPULSE[n] signals are then XOR'ed with the output from the configurable logic block to form the output signal and is sent to the channel selection logic for every consumer signal. For example, when SWLEVEL[n] is set, if configurable logic produces a signal of 1, this will cause a channel output of 0.

### 13.3.2 Configurable Logic

The configurable logic feature enables a PRS channel to perform logic operations on the signal coming from the selected producer. Every asynchronous channel has a configurable logic block that can be programmed using the FNSEL field in the asynchronous channel control register. The configurable logic block for each channel has two inputs. Input A is the signal from the selected producer determined by SOURCESEL and SIGSEL of PRS\_ASYNCHn\_CTRL. Input B may be selected from the output of any other asynchronous PRS channel using the ASYNC\_CHx\_AUXSEL field. This allows for more complex logic functions to be created using multiple PRS channels.

**Table 13.1. Configurable Logic Look up Table**

| A | B | FNSEL    |
|---|---|----------|
| 0 | 0 | FNSEL[0] |
| 0 | 1 | FNSEL[1] |
| 1 | 0 | FNSEL[2] |
| 1 | 1 | FNSEL[3] |

The configurable logic feature is implemented as a 2 input look up table, with each bit of FNSEL representing the outcome for a specific input combination (see [Table 13.1 Configurable Logic Look up Table on page 348](#)). For example, if input A is 0 and input B is 1, then the PRS output will assume the value of bit 1 of FNSEL (FNSEL[1]).

To calculate the FNSEL field for an "A NAND B" function, the truth table can be filled out as:

**Table 13.2. A NAND B Example**

| A | B | FNSEL = (A NAND B) |
|---|---|--------------------|
| 0 | 0 | FNSEL[0] = 1       |
| 0 | 1 | FNSEL[1] = 1       |
| 1 | 0 | FNSEL[2] = 1       |
| 1 | 1 | FNSEL[3] = 0       |

In this example, the value of FNSEL has been calculated to be 0111 (binary), or 0x7.

Using the FNSEL field, a total of 16 two-input logic functions can be implemented, as shown in [Table 13.3 List of Logic Functions on page 348](#).

**Table 13.3. List of Logic Functions**

| FNSEL value | Implemented Function |
|-------------|----------------------|
| 0x0         | 0                    |
| 0x1         | A NOR B              |
| 0x2         | (NOT A) AND B        |
| 0x3         | NOT A                |
| 0x4         | A AND (NOT B)        |
| 0x5         | (NOT B)              |
| 0x6         | A XOR B              |
| 0x7         | A NAND B             |
| 0x8         | A AND B              |
| 0x9         | A XNOR B             |

| FNSEL value | Implemented Function |
|-------------|----------------------|
| 0xA         | B                    |
| 0xB         | (NOT A) OR B         |
| 0xC         | A                    |
| 0xD         | A OR (NOT B)         |
| 0xE         | A OR B               |
| 0xF         | 1                    |

The default value of FNSEL is 0xC, meaning that the input from the selected producer goes through unchanged. This feature can be used to combine multiple channels to get even more complex functions.

### 13.3.3 Producers

Through SOURCESEL in PRS\_SYNCHx\_CTRL or PRS\_ASYNCCHx\_CTRL, each PRS channel (synchronous and asynchronous respectively) selects its signal producers. Each producer outputs one or more signals which can be selected by setting the SIGSEL field. Setting the SOURCESEL bits to 0 (Off) leads to a constant 0 output from the input mux regardless of SIGSEL.

The GPIO producer signals depend on settings in the GPIO module. They are selected using the edge interrupt configuration settings described in [24.3.10.1 Standard Interrupt Generation](#). PIN0 uses settings for the EXTI0 interrupt, PIN1 uses settings for EXTI1, and so on.

For example, to route PB00 as a producer for PRS channel 2, EXTI0, EXTI1, EXTI2, or EXTI3 should be configured to connect to PB00, and the corresponding GPIO PINx should be selected as the PRS channel 2 producer. If we choose EXTI1 via PRS producer "GPIO PIN1":

1. GPIO\_EXTIPSELL\_EXTIPSEL1 = PORTB, and GPIO\_EXTIPINSELL\_EXTIPINSEL1 = PIN0 connect PB00 through the EXTI1 signal.
2. PRS\_ASYNC\_CH2\_CTRL\_SOURCESEL = GPIO, and PRS\_ASYNC\_CH2\_CTRL\_SIGSEL = PIN1 connects the PIN1 (EXTI1) signal to asynchronous PRS channel 2 as a producer.

## 13.3.3.1 Producer Details

Table 13.4. Synchronous PRS Producers

| Peripheral | SOURCESEL     | Signal        | SIGSEL |
|------------|---------------|---------------|--------|
| TIMER0     | TIMER0 (0x01) | UF            | 0x0    |
|            |               | OF            | 0x1    |
|            |               | CC0           | 0x2    |
|            |               | CC1           | 0x3    |
|            |               | CC2           | 0x4    |
| TIMER1     | TIMER1 (0x02) | UF            | 0x0    |
|            |               | OF            | 0x1    |
|            |               | CC0           | 0x2    |
|            |               | CC1           | 0x3    |
|            |               | CC2           | 0x4    |
| IADC0      | IADC0 (0x03)  | SCANENTRYDONE | 0x0    |
|            |               | SCANTABLEDONE | 0x1    |
|            |               | SINGLEDONE    | 0x2    |
| TIMER2     | TIMER2 (0x04) | UF            | 0x0    |
|            |               | OF            | 0x1    |
|            |               | CC0           | 0x2    |
|            |               | CC1           | 0x3    |
|            |               | CC2           | 0x4    |
| TIMER3     | TIMER3 (0x05) | UF            | 0x0    |
|            |               | OF            | 0x1    |
|            |               | CC0           | 0x2    |
|            |               | CC1           | 0x3    |
|            |               | CC2           | 0x4    |
| TIMER4     | TIMER4 (0x06) | UF            | 0x0    |
|            |               | OF            | 0x1    |
|            |               | CC0           | 0x2    |
|            |               | CC1           | 0x3    |
|            |               | CC2           | 0x4    |
| VDAC0      | VDAC0 (0x07)  | CH0DONESYNC   | 0x0    |
|            |               | CH1DONESYNC   | 0x1    |
| VDAC1      | VDAC1 (0x08)  | CH0DONESYNC   | 0x0    |
|            |               | CH1DONESYNC   | 0x1    |

**Table 13.5. Asynchronous PRS Producers**

| Peripheral | SOURCESEL       | Signal        | SIGSEL |
|------------|-----------------|---------------|--------|
| IADC0      | IADC0 (0x01)    | SCANENTRYDONE | 0x0    |
|            |                 | SCANTABLEDONE | 0x1    |
|            |                 | SINGLEDONE    | 0x2    |
| LETIMER0   | LETIMER0 (0x02) | CH0           | 0x0    |
|            |                 | CH1           | 0x1    |
| BURTC      | BURTC (0x03)    | COMP          | 0x0    |
|            |                 | OVERFLOW      | 0x1    |
| GPIO       | GPIO (0x04)     | PIN0          | 0x0    |
|            |                 | PIN1          | 0x1    |
|            |                 | PIN2          | 0x2    |
|            |                 | PIN3          | 0x3    |
|            |                 | PIN4          | 0x4    |
|            |                 | PIN5          | 0x5    |
|            |                 | PIN6          | 0x6    |
|            |                 | PIN7          | 0x7    |
| CMU        | CMUL (0x05)     | CLKOUT0       | 0x0    |
|            |                 | CLKOUT1       | 0x1    |
|            |                 | CLKOUT2       | 0x2    |
| PRS        | PRSL (0x08)     | ASYNCH0       | 0x0    |
|            |                 | ASYNCH1       | 0x1    |
|            |                 | ASYNCH2       | 0x2    |
|            |                 | ASYNCH3       | 0x3    |
|            |                 | ASYNCH4       | 0x4    |
|            |                 | ASYNCH5       | 0x5    |
|            |                 | ASYNCH6       | 0x6    |
|            |                 | ASYNCH7       | 0x7    |
|            | PRS (0x09)      | ASYNCH8       | 0x0    |
|            |                 | ASYNCH9       | 0x1    |
|            |                 | ASYNCH10      | 0x2    |
|            |                 | ASYNCH11      | 0x3    |
| ACMP0      | ACMP0 (0x0A)    | OUT           | 0x0    |
| ACMP1      | ACMP1 (0x0B)    | OUT           | 0x0    |
| PCNT0      | PCNT0 (0x0C)    | DIR           | 0x0    |
|            |                 | UFOF          | 0x1    |

| Peripheral | SOURCESEL       | Signal          | SIGSEL |
|------------|-----------------|-----------------|--------|
| SYSRTC0    | SYSRTC0 (0x0D)  | GRP0OUT0        | 0x0    |
|            |                 | GRP0OUT1        | 0x1    |
|            |                 | GRP1OUT0        | 0x2    |
|            |                 | GRP1OUT1        | 0x3    |
| HFXO0      | HFXO0L (0x0E)   | STATUS          | 0x0    |
|            |                 | STATUS1         | 0x1    |
| EUSART0    | EUSART0L (0x10) | CS              | 0x0    |
|            |                 | IRDATX          | 0x1    |
|            |                 | RTS             | 0x2    |
|            |                 | RXDATAV         | 0x3    |
|            |                 | TX              | 0x4    |
|            |                 | TXC             | 0x5    |
|            |                 | RXFL            | 0x6    |
|            |                 | TXFL            | 0x7    |
| VDAC0      | VDAC0L (0x12)   | CH0WARM         | 0x0    |
|            |                 | CH1WARM         | 0x1    |
|            |                 | CH0DONEASYNC    | 0x2    |
|            |                 | CH1DONEASYNC    | 0x3    |
|            |                 | INTERNALTIMEROF | 0x4    |
|            |                 | REFRESHTIMEROF  | 0x5    |
| VDAC1      | VDAC1L (0x14)   | CH0WARM         | 0x0    |
|            |                 | CH1WARM         | 0x1    |
|            |                 | CH0DONEASYNC    | 0x2    |
|            |                 | CH1DONEASYNC    | 0x3    |
|            |                 | INTERNALTIMEROF | 0x4    |
|            |                 | REFRESHTIMEROF  | 0x5    |
| LFRCO      | LFRCO (0x18)    | CALMEAS         | 0x0    |
|            |                 | SDM             | 0x1    |
|            |                 | TCMEAS          | 0x2    |
| USART0     | USART0 (0x20)   | CS              | 0x0    |
|            |                 | IRTX            | 0x1    |
|            |                 | RTS             | 0x2    |
|            |                 | RXDATA          | 0x3    |
|            |                 | TX              | 0x4    |
|            |                 | TXC             | 0x5    |

| Peripheral | SOURCESEL     | Signal      | SIGSEL |
|------------|---------------|-------------|--------|
| TIMER0     | TIMER0 (0x21) | UF          | 0x0    |
|            |               | OF          | 0x1    |
|            |               | CC0         | 0x2    |
|            |               | CC1         | 0x3    |
|            |               | CC2         | 0x4    |
| TIMER1     | TIMER1 (0x22) | UF          | 0x0    |
|            |               | OF          | 0x1    |
|            |               | CC0         | 0x2    |
|            |               | CC1         | 0x3    |
|            |               | CC2         | 0x4    |
| TIMER2     | TIMER2 (0x23) | UF          | 0x0    |
|            |               | OF          | 0x1    |
|            |               | CC0         | 0x2    |
|            |               | CC1         | 0x3    |
|            |               | CC2         | 0x4    |
| TIMER3     | TIMER3 (0x24) | UF          | 0x0    |
|            |               | OF          | 0x1    |
|            |               | CC0         | 0x2    |
|            |               | CC1         | 0x3    |
|            |               | CC2         | 0x4    |
| CORE       | CORE (0x25)   | CTIOUT0     | 0x0    |
|            |               | CTIOUT1     | 0x1    |
|            |               | CTIOUT2     | 0x2    |
|            |               | CTIOUT3     | 0x3    |
| AGC        | AGCL (0x26)   | CCA         | 0x0    |
|            |               | CCAREQ      | 0x1    |
|            |               | GAINADJUST  | 0x2    |
|            |               | GAINOK      | 0x3    |
|            |               | GAINREDUCED | 0x4    |
|            |               | IFPKI1      | 0x5    |
|            |               | IFPKQ2      | 0x6    |
|            |               | IFPKRST     | 0x7    |
|            | AGC (0x27)    | PEAKDET     | 0x0    |
|            |               | PROPAGATED  | 0x1    |
|            |               | RSSIDONE    | 0x2    |

| Peripheral | SOURCESEL     | Signal     | SIGSEL |  |
|------------|---------------|------------|--------|--|
| BUFC       | BUFC (0x28)   | THR0       | 0x0    |  |
|            |               | THR1       | 0x1    |  |
|            |               | THR2       | 0x2    |  |
|            |               | THR3       | 0x3    |  |
|            |               | CNT0       | 0x4    |  |
|            |               | CNT1       | 0x5    |  |
|            |               | FULL       | 0x6    |  |
| MODEM      | MODEML (0x29) | ADVANCE    | 0x0    |  |
|            |               | ANT0       | 0x1    |  |
|            |               | ANT1       | 0x2    |  |
|            |               | COHDSADET  | 0x3    |  |
|            |               | COHDSALIVE | 0x4    |  |
|            |               | DCLK       | 0x5    |  |
|            |               | DOUT       | 0x6    |  |
|            |               | FRAMEDET   | 0x7    |  |
|            | MODEM (0x2A)  | FRAMESENT  | 0x0    |  |
|            |               | LOWCORR    | 0x1    |  |
|            |               | LRDSADET   | 0x2    |  |
|            |               | LRDSALIVE  | 0x3    |  |
|            |               | NEWSYMBOL  | 0x4    |  |
|            |               | NEWWND     | 0x5    |  |
|            |               | POSTPONE   | 0x6    |  |
| FRC        | FRC (0x2C)    | PREDET     | 0x7    |  |
|            |               | PRESENT    | 0x0    |  |
|            |               | RSSIJUMP   | 0x1    |  |
|            |               | SYNCSENT   | 0x2    |  |
|            |               | TIMDET     | 0x3    |  |
|            |               | WEAK       | 0x4    |  |
|            |               | EOF        | 0x5    |  |
|            |               | SI         | 0x6    |  |
|            |               | DCLK       | 0x0    |  |
|            |               | DOUT       | 0x1    |  |

| Peripheral | SOURCESEL        | Signal          | SIGSEL |
|------------|------------------|-----------------|--------|
| PROTIMER   | PROTILERL (0x2D) | BOF             | 0x0    |
|            |                  | CC0             | 0x1    |
|            |                  | CC1             | 0x2    |
|            |                  | CC2             | 0x3    |
|            |                  | CC3             | 0x4    |
|            |                  | CC4             | 0x5    |
|            |                  | LBTF            | 0x6    |
|            |                  | LBTR            | 0x7    |
|            | PROTIMER (0x2E)  | LBTS            | 0x0    |
|            |                  | POF             | 0x1    |
|            |                  | T0MATCH         | 0x2    |
|            |                  | T0UF            | 0x3    |
|            |                  | T1MATCH         | 0x4    |
|            |                  | T1UF            | 0x5    |
|            |                  | WOF             | 0x6    |
| SYNTH      | SYNTH (0x2F)     | MUX0            | 0x0    |
|            |                  | MUX1            | 0x1    |
| RAC        | RACL (0x30)      | ACTIVE          | 0x0    |
|            |                  | LNAEN           | 0x1    |
|            |                  | PAEN            | 0x2    |
|            |                  | RX              | 0x3    |
|            |                  | TX              | 0x4    |
|            |                  | CTIOUT0         | 0x5    |
|            |                  | CTIOUT1         | 0x6    |
|            |                  | CTIOUT2         | 0x7    |
|            | RAC (0x31)       | CTIOUT3         | 0x0    |
|            |                  | AUXADCDATA      | 0x1    |
|            |                  | AUXADCDATAVALID | 0x2    |
| TIMER4     | TIMER4 (0x32)    | UF              | 0x0    |
|            |                  | OF              | 0x1    |
|            |                  | CC0             | 0x2    |
|            |                  | CC1             | 0x3    |
|            |                  | CC2             | 0x4    |

| Peripheral | SOURCESEL       | Signal  | SIGSEL |
|------------|-----------------|---------|--------|
| EUSART1    | EUSART1L (0x33) | CS      | 0x0    |
|            |                 | IRDATX  | 0x1    |
|            |                 | RTS     | 0x2    |
|            |                 | RXDATAV | 0x3    |
|            |                 | TX      | 0x4    |
|            |                 | TXC     | 0x5    |
|            |                 | RXFL    | 0x6    |
|            |                 | TXFL    | 0x7    |

### 13.3.4 Consumers

Consumer peripherals can be set to listen to a PRS channel and perform an action based on the signal received on that channel. This is done by programming the PRSSEL or SPRSSEL in the consumer registers. SPRSSEL is only present for signals with the ability to listen to synchronous channels. The consumer registers follow the naming convention PRS\_CONSUMER\_<peripheral\_name>\_<signal\_name>. For example, the PRS\_CONSUMER\_TIMER0\_CC0 register is used to select which PRS channel output is sent to the TIMER0 peripheral's CC0 signal. In turn, the target peripheral should be configured to use the associated PRS trigger as desired. This is described in the individual peripheral chapters.

**Note:** When configuring the synchronous PRS consumer registers, the target peripheral should be disabled or configured to not use the affected PRS signal. This will ensure that no false triggers occur at the consumer.

#### 13.3.4.1 Event on PRS

The PRS can be used to send events to the MCU to wake the system. This is very useful in combination with the Wait For Event (WFE) instruction. Any asynchronous PRS channel can be selected for this using PRSSEL in PRS\_CONSUMER\_CORE\_M33RXEV.

Using this feature, one can e.g. set up a timer to trigger an event to the MCU periodically, every time letting the MCU continue from a WFE instruction in its program. This can help in performance-critical sections where timing is known, and the goal is to wait for an event, execute some code, then wait for another event, execute some code, and so on.

#### 13.3.4.2 DMA Request on PRS

Up to two independent DMA requests can be generated by the PRS. The PRS asynchronous channels triggering the DMA requests are selected with the PRSSEL fields in the PRS\_CONSUMER\_LDMAXBAR\_DMAREQx registers. The requests are set whenever the selected asynchronous PRS outputs are high.

### 13.4 PRS Register Map

The offset register address is relative to the registers base address.

| Offset | Name                              | Type | Description                    |
|--------|-----------------------------------|------|--------------------------------|
| 0x000  | PRS_IPVERSION                     | R    | PRS IPVERSION                  |
| 0x008  | PRS_ASYNC_SWPULSE                 | W    | Software Pulse Register        |
| 0x00C  | PRS_ASYNC_SWLEVEL                 | RW   | Software Level Register        |
| 0x010  | PRS_ASYNC_PEEK                    | RH   | Async Channel Values           |
| 0x014  | PRS_SYNC_PEEK                     | RH   | Sync Channel Values            |
| 0x018  | PRS_ASYNC_CHx_CTRL                | RW   | Async Channel Control Register |
| 0x058  | PRS_SYNC_CHx_CTRL                 | RW   | Sync Channel Control Register  |
| 0x068  | PRS_CONSUM-ER_CMU_CALDN           | RW   | CALDN Consumer Register        |
| 0x06C  | PRS_CONSUMER_CMU_CAL-UP           | RW   | CALUP Consumer Register        |
| 0x070  | PRS_CONSUMER_EU-SART0_CLK         | RW   | CLK Consumer Register          |
| 0x074  | PRS_CONSUMER_EU-SART0_RX          | RW   | RX Consumer Register           |
| 0x078  | PRS_CONSUMER_EU-SART0_TRIGGER     | RW   | TRIGGER Consumer Register      |
| 0x07C  | PRS_CONSUMER_EU-SART1_CLK         | RW   | CLK Consumer Register          |
| 0x080  | PRS_CONSUMER_EU-SART1_RX          | RW   | RX Consumer Register           |
| 0x084  | PRS_CONSUMER_EU-SART1_TRIGGER     | RW   | TRIGGER Consumer Register      |
| 0x08C  | PRS_CONSUM-ER_IADC0_SCANTRIGGER   | RW   | SCAN Consumer Register         |
| 0x090  | PRS_CONSUMER_IADC0_SIN-GLETRIGGER | RW   | SINGLE Consumer Register       |
| 0x094  | PRS_CONSUMER_LDMAX-BAR_DMAREQ0    | RW   | DMAREQ0 Consumer Register      |
| 0x098  | PRS_CONSUMER_LDMAX-BAR_DMAREQ1    | RW   | DMAREQ1 Consumer Register      |
| 0x09C  | PRS_CONSUMER_LETIM-ER0_CLEAR      | RW   | CLEAR Consumer Register        |
| 0x0A0  | PRS_CONSUMER_LETIM-ER0_START      | RW   | START Consumer Register        |
| 0x0A4  | PRS_CONSUMER_LETIM-ER0_STOP       | RW   | STOP Consumer Register         |
| 0x0A8  | PRS_CONSUMER_MO-DEM_DIN           | RW   | DIN Consumer Register          |
| 0x0AC  | PRS_CONSUMER_MO-DEM_PAEN          | RW   | PAEN Consumer Register         |

| Offset | Name                               | Type | Description                   |
|--------|------------------------------------|------|-------------------------------|
| 0x0B0  | PRS_CONSUM-ER_PCNT0_S0IN           | RW   | S0IN Consumer Register        |
| 0x0B4  | PRS_CONSUM-ER_PCNT0_S1IN           | RW   | S1IN Consumer Register        |
| 0x0E4  | PRS_CONSUMER_RAC_CLR               | RW   | CLR Consumer Register         |
| 0x0E8  | PRS_CONSUMER_RAC_CTIIN0            | RW   | CTI Consumer Register         |
| 0x0EC  | PRS_CONSUMER_RAC_CTIIN1            | RW   | CTI Consumer Register         |
| 0x0F0  | PRS_CONSUMER_RAC_CTIIN2            | RW   | CTI Consumer Register         |
| 0x0F4  | PRS_CONSUMER_RAC_CTIIN3            | RW   | CTI Consumer Register         |
| 0x0F8  | PRS_CONSUM-ER_RAC_FORCETX          | RW   | FORCETX Consumer Register     |
| 0x0FC  | PRS_CONSUMER_RAC_RXDIS             | RW   | RXDIS Consumer Register       |
| 0x100  | PRS_CONSUMER_RAC_RXEN              | RW   | RXEN Consumer Register        |
| 0x104  | PRS_CONSUMER_RAC_TXEN              | RW   | TXEN Consumer Register        |
| 0x108  | PRS_CONSUMER_SETAM-PER_TAMPERSRC25 | RW   | TAMPERSRC25 Consumer Register |
| 0x10C  | PRS_CONSUMER_SETAM-PER_TAMPERSRC26 | RW   | TAMPERSRC26 Consumer Register |
| 0x110  | PRS_CONSUMER_SETAM-PER_TAMPERSRC27 | RW   | TAMPERSRC27 Consumer Register |
| 0x114  | PRS_CONSUMER_SETAM-PER_TAMPERSRC28 | RW   | TAMPERSRC28 Consumer Register |
| 0x118  | PRS_CONSUMER_SETAM-PER_TAMPERSRC29 | RW   | TAMPERSRC29 Consumer Register |
| 0x11C  | PRS_CONSUMER_SETAM-PER_TAMPERSRC30 | RW   | TAMPERSRC30 Consumer Register |
| 0x120  | PRS_CONSUMER_SETAM-PER_TAMPERSRC31 | RW   | TAMPERSRC31 Consumer Register |
| 0x124  | PRS_CONSUM-ER_SYSRTC0_IN0          | RW   | IN0 Consumer Register         |
| 0x128  | PRS_CONSUM-ER_SYSRTC0_IN1          | RW   | IN1 Consumer Register         |
| 0x12C  | PRS_CONSUMER_HFX00_OS-CREQ         | RW   | OSCREQ Consumer Register      |
| 0x130  | PRS_CONSUM-ER_HFX00_TIMEOUT        | RW   | TIMEOUT Consumer Register     |
| 0x134  | PRS_CONSUM-ER_CORE_CTIIN0          | RW   | CTI0 Consumer Selection       |
| 0x138  | PRS_CONSUM-ER_CORE_CTIIN1          | RW   | CTI1 Consumer Selection       |
| 0x13C  | PRS_CONSUM-ER_CORE_CTIIN2          | RW   | CTI2 Consumer Selection       |
| 0x140  | PRS_CONSUM-ER_CORE_CTIIN3          | RW   | CTI3 Consumer Selection       |

| Offset | Name                        | Type | Description            |
|--------|-----------------------------|------|------------------------|
| 0x144  | PRS_CONSUM-ER_CORE_M33RXEV  | RW   | M33 Consumer Selection |
| 0x148  | PRS_CONSUMER_TIM-ER0_CC0    | RW   | CC0 Consumer Register  |
| 0x14C  | PRS_CONSUMER_TIM-ER0_CC1    | RW   | CC1 Consumer Register  |
| 0x150  | PRS_CONSUMER_TIM-ER0_CC2    | RW   | CC2 Consumer Register  |
| 0x154  | PRS_CONSUMER_TIMER0_DTI     | RW   | DTI Consumer Register  |
| 0x158  | PRS_CONSUMER_TIM-ER0_DTIFS1 | RW   | DTI Consumer Register  |
| 0x15C  | PRS_CONSUMER_TIM-ER0_DTIFS2 | RW   | DTI Consumer Register  |
| 0x160  | PRS_CONSUMER_TIM-ER1_CC0    | RW   | CC0 Consumer Register  |
| 0x164  | PRS_CONSUMER_TIM-ER1_CC1    | RW   | CC1 Consumer Register  |
| 0x168  | PRS_CONSUMER_TIM-ER1_CC2    | RW   | CC2 Consumer Register  |
| 0x16C  | PRS_CONSUMER_TIMER1_DTI     | RW   | DTI Consumer Register  |
| 0x170  | PRS_CONSUMER_TIM-ER1_DTIFS1 | RW   | DTI Consumer Register  |
| 0x174  | PRS_CONSUMER_TIM-ER1_DTIFS2 | RW   | DTI Consumer Register  |
| 0x178  | PRS_CONSUMER_TIM-ER2_CC0    | RW   | CC0 Consumer Register  |
| 0x17C  | PRS_CONSUMER_TIM-ER2_CC1    | RW   | CC1 Consumer Register  |
| 0x180  | PRS_CONSUMER_TIM-ER2_CC2    | RW   | CC2 Consumer Register  |
| 0x184  | PRS_CONSUMER_TIMER2_DTI     | RW   | DTI Consumer Register  |
| 0x188  | PRS_CONSUMER_TIM-ER2_DTIFS1 | RW   | DTI Consumer Register  |
| 0x18C  | PRS_CONSUMER_TIM-ER2_DTIFS2 | RW   | DTI Consumer Register  |
| 0x190  | PRS_CONSUMER_TIM-ER3_CC0    | RW   | CC0 Consumer Register  |
| 0x194  | PRS_CONSUMER_TIM-ER3_CC1    | RW   | CC1 Consumer Register  |
| 0x198  | PRS_CONSUMER_TIM-ER3_CC2    | RW   | CC2 Consumer Register  |
| 0x19C  | PRS_CONSUMER_TIMER3_DTI     | RW   | DTI Consumer Register  |
| 0x1A0  | PRS_CONSUMER_TIM-ER3_DTIFS1 | RW   | DTI Consumer Register  |
| 0x1A4  | PRS_CONSUMER_TIM-ER3_DTIFS2 | RW   | DTI Consumer Register  |

| Offset | Name                             | Type | Description                 |
|--------|----------------------------------|------|-----------------------------|
| 0x1A8  | PRS_CONSUMER_TIM-ER4_CC0         | RW   | CC0 Consumer Register       |
| 0x1AC  | PRS_CONSUMER_TIM-ER4_CC1         | RW   | CC1 Consumer Register       |
| 0x1B0  | PRS_CONSUMER_TIM-ER4_CC2         | RW   | CC2 Consumer Register       |
| 0x1B4  | PRS_CONSUMER_TIMER4_DTI          | RW   | DTI Consumer Register       |
| 0x1B8  | PRS_CONSUMER_TIM-ER4_DTIFS1      | RW   | DTI Consumer Register       |
| 0x1BC  | PRS_CONSUMER_TIM-ER4_DTIFS2      | RW   | DTI Consumer Register       |
| 0x1C0  | PRS_CONSUM-ER_USART0_CLK         | RW   | CLK Consumer Register       |
| 0x1C4  | PRS_CONSUMER_USART0_IR           | RW   | IR Consumer Register        |
| 0x1C8  | PRS_CONSUMER_USART0_RX           | RW   | RX Consumer Register        |
| 0x1CC  | PRS_CONSUM-ER_USART0_TRIGGER     | RW   | TRIGGER Consumer Register   |
| 0x1DC  | PRS_CONSUM-ER_VDAC0_ASYNCTRIGCH0 | RW   | ASYNCTRIG Consumer Register |
| 0x1E0  | PRS_CONSUM-ER_VDAC0_ASYNCTRIGCH1 | RW   | ASYNCTRIG Consumer Register |
| 0x1E4  | PRS_CONSUM-ER_VDAC0_SYNCTRIGCH0  | RW   | SYNCTRIG Consumer Register  |
| 0x1E8  | PRS_CONSUM-ER_VDAC0_SYNCTRIGCH1  | RW   | SYNCTRIG Consumer Register  |
| 0x1EC  | PRS_CONSUM-ER_VDAC1_ASYNCTRIGCH0 | RW   | ASYNCTRIG Consumer Register |
| 0x1F0  | PRS_CONSUM-ER_VDAC1_ASYNCTRIGCH1 | RW   | ASYNCTRIG Consumer Register |
| 0x1F4  | PRS_CONSUM-ER_VDAC1_SYNCTRIGCH0  | RW   | SYNCTRIG Consumer Register  |
| 0x1F8  | PRS_CONSUM-ER_VDAC1_SYNCTRIGCH1  | RW   | SYNCTRIG Consumer Register  |
| 0x1FC  | PRS_CONSUM-ER_WDOG0_SRC0         | RW   | SRC0 Consumer Register      |
| 0x200  | PRS_CONSUM-ER_WDOG0_SRC1         | RW   | SRC1 Consumer Register      |
| 0x204  | PRS_CONSUM-ER_WDOG1_SRC0         | RW   | SRC0 Consumer Register      |
| 0x208  | PRS_CONSUM-ER_WDOG1_SRC1         | RW   | SRC1 Consumer Register      |
| 0x1000 | PRS_IPVERSION_SET                | R    | PRS IPVERSION               |
| 0x1008 | PRS_ASYNC_SWPULSE_SET            | W    | Software Pulse Register     |
| 0x100C | PRS_ASYNC_SWLEVEL_SET            | RW   | Software Level Register     |
| 0x1010 | PRS_ASYNC_PEEK_SET               | RH   | Async Channel Values        |

| Offset | Name                                  | Type | Description                    |
|--------|---------------------------------------|------|--------------------------------|
| 0x1014 | PRS_SYNC_PEEK_SET                     | RH   | Sync Channel Values            |
| 0x1018 | PRS_ASYNC_CHx_CTRL_SET                | RW   | Async Channel Control Register |
| 0x1058 | PRS_SYNC_CHx_CTRL_SET                 | RW   | Sync Channel Control Register  |
| 0x1068 | PRS_CONSUM-ER_CMU_CALDN_SET           | RW   | CALDN Consumer Register        |
| 0x106C | PRS_CONSUMER_CMU_CAL-UP_SET           | RW   | CALUP Consumer Register        |
| 0x1070 | PRS_CONSUMER_EU-SART0_CLK_SET         | RW   | CLK Consumer Register          |
| 0x1074 | PRS_CONSUMER_EU-SART0_RX_SET          | RW   | RX Consumer Register           |
| 0x1078 | PRS_CONSUMER_EU-SART0_TRIGGER_SET     | RW   | TRIGGER Consumer Register      |
| 0x107C | PRS_CONSUMER_EU-SART1_CLK_SET         | RW   | CLK Consumer Register          |
| 0x1080 | PRS_CONSUMER_EU-SART1_RX_SET          | RW   | RX Consumer Register           |
| 0x1084 | PRS_CONSUMER_EU-SART1_TRIGGER_SET     | RW   | TRIGGER Consumer Register      |
| 0x108C | PRS_CONSUM-ER_IADC0_SCANTRIG-GER_SET  | RW   | SCAN Consumer Register         |
| 0x1090 | PRS_CONSUMER_IADC0_SIN-GLETRIGGER_SET | RW   | SINGLE Consumer Register       |
| 0x1094 | PRS_CONSUMER_LDMAX-BAR_DMAREQ0_SET    | RW   | DMAREQ0 Consumer Register      |
| 0x1098 | PRS_CONSUMER_LDMAX-BAR_DMAREQ1_SET    | RW   | DMAREQ1 Consumer Register      |
| 0x109C | PRS_CONSUMER_LETIM-ER0_CLEAR_SET      | RW   | CLEAR Consumer Register        |
| 0x10A0 | PRS_CONSUMER_LETIM-ER0_START_SET      | RW   | START Consumer Register        |
| 0x10A4 | PRS_CONSUMER_LETIM-ER0_STOP_SET       | RW   | STOP Consumer Register         |
| 0x10A8 | PRS_CONSUMER_MO-DEM_DIN_SET           | RW   | DIN Consumer Register          |
| 0x10AC | PRS_CONSUMER_MO-DEM_PAEN_SET          | RW   | PAEN Consumer Register         |
| 0x10B0 | PRS_CONSUM-ER_PCNT0_S0IN_SET          | RW   | S0IN Consumer Register         |
| 0x10B4 | PRS_CONSUM-ER_PCNT0_S1IN_SET          | RW   | S1IN Consumer Register         |
| 0x10E4 | PRS_CONSUM-ER_RAC_CLR_SET             | RW   | CLR Consumer Register          |
| 0x10E8 | PRS_CONSUM-ER_RAC_CTIIN0_SET          | RW   | CTI Consumer Register          |

| Offset | Name                                   | Type | Description                   |
|--------|----------------------------------------|------|-------------------------------|
| 0x10EC | PRS_CONSUM-ER_RAC_CTIIN1_SET           | RW   | CTI Consumer Register         |
| 0x10F0 | PRS_CONSUM-ER_RAC_CTIIN2_SET           | RW   | CTI Consumer Register         |
| 0x10F4 | PRS_CONSUM-ER_RAC_CTIIN3_SET           | RW   | CTI Consumer Register         |
| 0x10F8 | PRS_CONSUM-ER_RAC_FORCETX_SET          | RW   | FORCETX Consumer Register     |
| 0x10FC | PRS_CONSUM-ER_RAC_RXDIS_SET            | RW   | RXDIS Consumer Register       |
| 0x1100 | PRS_CONSUM-ER_RAC_RXEN_SET             | RW   | RXEN Consumer Register        |
| 0x1104 | PRS_CONSUM-ER_RAC_TXEN_SET             | RW   | TXEN Consumer Register        |
| 0x1108 | PRS_CONSUMER_SETAM-PER_TAMPERSRC25_SET | RW   | TAMPERSRC25 Consumer Register |
| 0x110C | PRS_CONSUMER_SETAM-PER_TAMPERSRC26_SET | RW   | TAMPERSRC26 Consumer Register |
| 0x1110 | PRS_CONSUMER_SETAM-PER_TAMPERSRC27_SET | RW   | TAMPERSRC27 Consumer Register |
| 0x1114 | PRS_CONSUMER_SETAM-PER_TAMPERSRC28_SET | RW   | TAMPERSRC28 Consumer Register |
| 0x1118 | PRS_CONSUMER_SETAM-PER_TAMPERSRC29_SET | RW   | TAMPERSRC29 Consumer Register |
| 0x111C | PRS_CONSUMER_SETAM-PER_TAMPERSRC30_SET | RW   | TAMPERSRC30 Consumer Register |
| 0x1120 | PRS_CONSUMER_SETAM-PER_TAMPERSRC31_SET | RW   | TAMPERSRC31 Consumer Register |
| 0x1124 | PRS_CONSUM-ER_SYSRTC0_IN0_SET          | RW   | IN0 Consumer Register         |
| 0x1128 | PRS_CONSUM-ER_SYSRTC0_IN1_SET          | RW   | IN1 Consumer Register         |
| 0x112C | PRS_CONSUMER_HFX00_OS-CREQ_SET         | RW   | OSCREQ Consumer Register      |
| 0x1130 | PRS_CONSUM-ER_HFX00_TIMEOUT_SET        | RW   | TIMEOUT Consumer Register     |
| 0x1134 | PRS_CONSUM-ER_CORE_CTIIN0_SET          | RW   | CTI0 Consumer Selection       |
| 0x1138 | PRS_CONSUM-ER_CORE_CTIIN1_SET          | RW   | CTI1 Consumer Selection       |
| 0x113C | PRS_CONSUM-ER_CORE_CTIIN2_SET          | RW   | CTI2 Consumer Selection       |
| 0x1140 | PRS_CONSUM-ER_CORE_CTIIN3_SET          | RW   | CTI3 Consumer Selection       |
| 0x1144 | PRS_CONSUM-ER_CORE_M33RXEV_SET         | RW   | M33 Consumer Selection        |

| Offset | Name                            | Type | Description           |
|--------|---------------------------------|------|-----------------------|
| 0x1148 | PRS_CONSUMER_TIM-ER0_CC0_SET    | RW   | CC0 Consumer Register |
| 0x114C | PRS_CONSUMER_TIM-ER0_CC1_SET    | RW   | CC1 Consumer Register |
| 0x1150 | PRS_CONSUMER_TIM-ER0_CC2_SET    | RW   | CC2 Consumer Register |
| 0x1154 | PRS_CONSUMER_TIM-ER0_DTI_SET    | RW   | DTI Consumer Register |
| 0x1158 | PRS_CONSUMER_TIM-ER0_DTIFS1_SET | RW   | DTI Consumer Register |
| 0x115C | PRS_CONSUMER_TIM-ER0_DTIFS2_SET | RW   | DTI Consumer Register |
| 0x1160 | PRS_CONSUMER_TIM-ER1_CC0_SET    | RW   | CC0 Consumer Register |
| 0x1164 | PRS_CONSUMER_TIM-ER1_CC1_SET    | RW   | CC1 Consumer Register |
| 0x1168 | PRS_CONSUMER_TIM-ER1_CC2_SET    | RW   | CC2 Consumer Register |
| 0x116C | PRS_CONSUMER_TIM-ER1_DTI_SET    | RW   | DTI Consumer Register |
| 0x1170 | PRS_CONSUMER_TIM-ER1_DTIFS1_SET | RW   | DTI Consumer Register |
| 0x1174 | PRS_CONSUMER_TIM-ER1_DTIFS2_SET | RW   | DTI Consumer Register |
| 0x1178 | PRS_CONSUMER_TIM-ER2_CC0_SET    | RW   | CC0 Consumer Register |
| 0x117C | PRS_CONSUMER_TIM-ER2_CC1_SET    | RW   | CC1 Consumer Register |
| 0x1180 | PRS_CONSUMER_TIM-ER2_CC2_SET    | RW   | CC2 Consumer Register |
| 0x1184 | PRS_CONSUMER_TIM-ER2_DTI_SET    | RW   | DTI Consumer Register |
| 0x1188 | PRS_CONSUMER_TIM-ER2_DTIFS1_SET | RW   | DTI Consumer Register |
| 0x118C | PRS_CONSUMER_TIM-ER2_DTIFS2_SET | RW   | DTI Consumer Register |
| 0x1190 | PRS_CONSUMER_TIM-ER3_CC0_SET    | RW   | CC0 Consumer Register |
| 0x1194 | PRS_CONSUMER_TIM-ER3_CC1_SET    | RW   | CC1 Consumer Register |
| 0x1198 | PRS_CONSUMER_TIM-ER3_CC2_SET    | RW   | CC2 Consumer Register |
| 0x119C | PRS_CONSUMER_TIM-ER3_DTI_SET    | RW   | DTI Consumer Register |
| 0x11A0 | PRS_CONSUMER_TIM-ER3_DTIFS1_SET | RW   | DTI Consumer Register |

| Offset | Name                                  | Type | Description                 |
|--------|---------------------------------------|------|-----------------------------|
| 0x11A4 | PRS_CONSUMER_TIM-ER3_DTIFS2_SET       | RW   | DTI Consumer Register       |
| 0x11A8 | PRS_CONSUMER_TIM-ER4_CC0_SET          | RW   | CC0 Consumer Register       |
| 0x11AC | PRS_CONSUMER_TIM-ER4_CC1_SET          | RW   | CC1 Consumer Register       |
| 0x11B0 | PRS_CONSUMER_TIM-ER4_CC2_SET          | RW   | CC2 Consumer Register       |
| 0x11B4 | PRS_CONSUMER_TIM-ER4_DTI_SET          | RW   | DTI Consumer Register       |
| 0x11B8 | PRS_CONSUMER_TIM-ER4_DTIFS1_SET       | RW   | DTI Consumer Register       |
| 0x11BC | PRS_CONSUMER_TIM-ER4_DTIFS2_SET       | RW   | DTI Consumer Register       |
| 0x11C0 | PRS_CONSUM-ER_USART0_CLK_SET          | RW   | CLK Consumer Register       |
| 0x11C4 | PRS_CONSUM-ER_USART0_IR_SET           | RW   | IR Consumer Register        |
| 0x11C8 | PRS_CONSUM-ER_USART0_RX_SET           | RW   | RX Consumer Register        |
| 0x11CC | PRS_CONSUM-ER_USART0_TRIGGER_SET      | RW   | TRIGGER Consumer Register   |
| 0x11DC | PRS_CONSUM-ER_VDAC0_ASYN-CTRIGCH0_SET | RW   | ASYNCTRIG Consumer Register |
| 0x11E0 | PRS_CONSUM-ER_VDAC0_ASYN-CTRIGCH1_SET | RW   | ASYNCTRIG Consumer Register |
| 0x11E4 | PRS_CONSUM-ER_VDAC0_SYN-CTRIGCH0_SET  | RW   | SYNCTRIG Consumer Register  |
| 0x11E8 | PRS_CONSUM-ER_VDAC0_SYN-CTRIGCH1_SET  | RW   | SYNCTRIG Consumer Register  |
| 0x11EC | PRS_CONSUM-ER_VDAC1_ASYN-CTRIGCH0_SET | RW   | ASYNCTRIG Consumer Register |
| 0x11F0 | PRS_CONSUM-ER_VDAC1_ASYN-CTRIGCH1_SET | RW   | ASYNCTRIG Consumer Register |
| 0x11F4 | PRS_CONSUM-ER_VDAC1_SYN-CTRIGCH0_SET  | RW   | SYNCTRIG Consumer Register  |
| 0x11F8 | PRS_CONSUM-ER_VDAC1_SYN-CTRIGCH1_SET  | RW   | SYNCTRIG Consumer Register  |
| 0x11FC | PRS_CONSUM-ER_WDOG0_SRC0_SET          | RW   | SRC0 Consumer Register      |

| Offset | Name                                  | Type | Description                    |
|--------|---------------------------------------|------|--------------------------------|
| 0x1200 | PRS_CONSUM-ER_WDOG0_SRC1_SET          | RW   | SRC1 Consumer Register         |
| 0x1204 | PRS_CONSUM-ER_WDOG1_SRC0_SET          | RW   | SRC0 Consumer Register         |
| 0x1208 | PRS_CONSUM-ER_WDOG1_SRC1_SET          | RW   | SRC1 Consumer Register         |
| 0x2000 | PRS_IPVERSION_CLR                     | R    | PRS IPVERSION                  |
| 0x2008 | PRS_ASYNC_SWPULSE_CLR                 | W    | Software Pulse Register        |
| 0x200C | PRS_ASYNC_SWLEVEL_CLR                 | RW   | Software Level Register        |
| 0x2010 | PRS_ASYNC_PEEK_CLR                    | RH   | Async Channel Values           |
| 0x2014 | PRS_SYNC_PEEK_CLR                     | RH   | Sync Channel Values            |
| 0x2018 | PRS_ASYNC_CHx_CTRL_CLR                | RW   | Async Channel Control Register |
| 0x2058 | PRS_SYNC_CHx_CTRL_CLR                 | RW   | Sync Channel Control Register  |
| 0x2068 | PRS_CONSUM-ER_CMU_CALDN_CLR           | RW   | CALDN Consumer Register        |
| 0x206C | PRS_CONSUMER_CMU_CAL-UP_CLR           | RW   | CALUP Consumer Register        |
| 0x2070 | PRS_CONSUMER_EU-SART0_CLK_CLR         | RW   | CLK Consumer Register          |
| 0x2074 | PRS_CONSUMER_EU-SART0_RX_CLR          | RW   | RX Consumer Register           |
| 0x2078 | PRS_CONSUMER_EU-SART0_TRIGGER_CLR     | RW   | TRIGGER Consumer Register      |
| 0x207C | PRS_CONSUMER_EU-SART1_CLK_CLR         | RW   | CLK Consumer Register          |
| 0x2080 | PRS_CONSUMER_EU-SART1_RX_CLR          | RW   | RX Consumer Register           |
| 0x2084 | PRS_CONSUMER_EU-SART1_TRIGGER_CLR     | RW   | TRIGGER Consumer Register      |
| 0x208C | PRS_CONSUM-ER_IADC0_SCANTRIG-GER_CLR  | RW   | SCAN Consumer Register         |
| 0x2090 | PRS_CONSUMER_IADC0_SIN-GLEtrigger_CLR | RW   | SINGLE Consumer Register       |
| 0x2094 | PRS_CONSUMER_LDMAX-BAR_DMAREQ0_CLR    | RW   | DMAREQ0 Consumer Register      |
| 0x2098 | PRS_CONSUMER_LDMAX-BAR_DMAREQ1_CLR    | RW   | DMAREQ1 Consumer Register      |
| 0x209C | PRS_CONSUMER_LETIM-ER0_CLEAR_CLR      | RW   | CLEAR Consumer Register        |
| 0x20A0 | PRS_CONSUMER_LETIM-ER0_START_CLR      | RW   | START Consumer Register        |
| 0x20A4 | PRS_CONSUMER_LETIM-ER0_STOP_CLR       | RW   | STOP Consumer Register         |

| Offset | Name                                   | Type | Description                   |
|--------|----------------------------------------|------|-------------------------------|
| 0x20A8 | PRS_CONSUMER_MO-DEM_DIN_CLR            | RW   | DIN Consumer Register         |
| 0x20AC | PRS_CONSUMER_MO-DEM_PAEN_CLR           | RW   | PAEN Consumer Register        |
| 0x20B0 | PRS_CONSUM-ER_PCNT0_S0IN_CLR           | RW   | S0IN Consumer Register        |
| 0x20B4 | PRS_CONSUM-ER_PCNT0_S1IN_CLR           | RW   | S1IN Consumer Register        |
| 0x20E4 | PRS_CONSUM-ER_RAC_CLR_CLR              | RW   | CLR Consumer Register         |
| 0x20E8 | PRS_CONSUM-ER_RAC_CTIIN0_CLR           | RW   | CTI Consumer Register         |
| 0x20EC | PRS_CONSUM-ER_RAC_CTIIN1_CLR           | RW   | CTI Consumer Register         |
| 0x20F0 | PRS_CONSUM-ER_RAC_CTIIN2_CLR           | RW   | CTI Consumer Register         |
| 0x20F4 | PRS_CONSUM-ER_RAC_CTIIN3_CLR           | RW   | CTI Consumer Register         |
| 0x20F8 | PRS_CONSUM-ER_RAC_FORCETX_CLR          | RW   | FORCETX Consumer Register     |
| 0x20FC | PRS_CONSUM-ER_RAC_RXDIS_CLR            | RW   | RXDIS Consumer Register       |
| 0x2100 | PRS_CONSUM-ER_RAC_RXEN_CLR             | RW   | RXEN Consumer Register        |
| 0x2104 | PRS_CONSUM-ER_RAC_TXEN_CLR             | RW   | TXEN Consumer Register        |
| 0x2108 | PRS_CONSUMER_SETAM-PER_TAMPERSRC25_CLR | RW   | TAMPERSRC25 Consumer Register |
| 0x210C | PRS_CONSUMER_SETAM-PER_TAMPERSRC26_CLR | RW   | TAMPERSRC26 Consumer Register |
| 0x2110 | PRS_CONSUMER_SETAM-PER_TAMPERSRC27_CLR | RW   | TAMPERSRC27 Consumer Register |
| 0x2114 | PRS_CONSUMER_SETAM-PER_TAMPERSRC28_CLR | RW   | TAMPERSRC28 Consumer Register |
| 0x2118 | PRS_CONSUMER_SETAM-PER_TAMPERSRC29_CLR | RW   | TAMPERSRC29 Consumer Register |
| 0x211C | PRS_CONSUMER_SETAM-PER_TAMPERSRC30_CLR | RW   | TAMPERSRC30 Consumer Register |
| 0x2120 | PRS_CONSUMER_SETAM-PER_TAMPERSRC31_CLR | RW   | TAMPERSRC31 Consumer Register |
| 0x2124 | PRS_CONSUM-ER_SYSRTC0_IN0_CLR          | RW   | IN0 Consumer Register         |
| 0x2128 | PRS_CONSUM-ER_SYSRTC0_IN1_CLR          | RW   | IN1 Consumer Register         |
| 0x212C | PRS_CONSUMER_HFX00_OS-CREQ_CLR         | RW   | OSCREQ Consumer Register      |

| Offset | Name                            | Type | Description               |
|--------|---------------------------------|------|---------------------------|
| 0x2130 | PRS_CONSUM-ER_HFX00_TIMEOUT_CLR | RW   | TIMEOUT Consumer Register |
| 0x2134 | PRS_CONSUM-ER_CORE_CTIIN0_CLR   | RW   | CTI0 Consumer Selection   |
| 0x2138 | PRS_CONSUM-ER_CORE_CTIIN1_CLR   | RW   | CTI1 Consumer Selection   |
| 0x213C | PRS_CONSUM-ER_CORE_CTIIN2_CLR   | RW   | CTI2 Consumer Selection   |
| 0x2140 | PRS_CONSUM-ER_CORE_CTIIN3_CLR   | RW   | CTI3 Consumer Selection   |
| 0x2144 | PRS_CONSUM-ER_CORE_M33RXEV_CLR  | RW   | M33 Consumer Selection    |
| 0x2148 | PRS_CONSUMER_TIM-ER0_CC0_CLR    | RW   | CC0 Consumer Register     |
| 0x214C | PRS_CONSUMER_TIM-ER0_CC1_CLR    | RW   | CC1 Consumer Register     |
| 0x2150 | PRS_CONSUMER_TIM-ER0_CC2_CLR    | RW   | CC2 Consumer Register     |
| 0x2154 | PRS_CONSUMER_TIM-ER0_DTI_CLR    | RW   | DTI Consumer Register     |
| 0x2158 | PRS_CONSUMER_TIM-ER0_DTIFS1_CLR | RW   | DTI Consumer Register     |
| 0x215C | PRS_CONSUMER_TIM-ER0_DTIFS2_CLR | RW   | DTI Consumer Register     |
| 0x2160 | PRS_CONSUMER_TIM-ER1_CC0_CLR    | RW   | CC0 Consumer Register     |
| 0x2164 | PRS_CONSUMER_TIM-ER1_CC1_CLR    | RW   | CC1 Consumer Register     |
| 0x2168 | PRS_CONSUMER_TIM-ER1_CC2_CLR    | RW   | CC2 Consumer Register     |
| 0x216C | PRS_CONSUMER_TIM-ER1_DTI_CLR    | RW   | DTI Consumer Register     |
| 0x2170 | PRS_CONSUMER_TIM-ER1_DTIFS1_CLR | RW   | DTI Consumer Register     |
| 0x2174 | PRS_CONSUMER_TIM-ER1_DTIFS2_CLR | RW   | DTI Consumer Register     |
| 0x2178 | PRS_CONSUMER_TIM-ER2_CC0_CLR    | RW   | CC0 Consumer Register     |
| 0x217C | PRS_CONSUMER_TIM-ER2_CC1_CLR    | RW   | CC1 Consumer Register     |
| 0x2180 | PRS_CONSUMER_TIM-ER2_CC2_CLR    | RW   | CC2 Consumer Register     |
| 0x2184 | PRS_CONSUMER_TIM-ER2_DTI_CLR    | RW   | DTI Consumer Register     |
| 0x2188 | PRS_CONSUMER_TIM-ER2_DTIFS1_CLR | RW   | DTI Consumer Register     |

| Offset | Name                                  | Type | Description                 |
|--------|---------------------------------------|------|-----------------------------|
| 0x218C | PRS_CONSUMER_TIM-ER2_DTIFS2_CLR       | RW   | DTI Consumer Register       |
| 0x2190 | PRS_CONSUMER_TIM-ER3_CC0_CLR          | RW   | CC0 Consumer Register       |
| 0x2194 | PRS_CONSUMER_TIM-ER3_CC1_CLR          | RW   | CC1 Consumer Register       |
| 0x2198 | PRS_CONSUMER_TIM-ER3_CC2_CLR          | RW   | CC2 Consumer Register       |
| 0x219C | PRS_CONSUMER_TIM-ER3_DTI_CLR          | RW   | DTI Consumer Register       |
| 0x21A0 | PRS_CONSUMER_TIM-ER3_DTIFS1_CLR       | RW   | DTI Consumer Register       |
| 0x21A4 | PRS_CONSUMER_TIM-ER3_DTIFS2_CLR       | RW   | DTI Consumer Register       |
| 0x21A8 | PRS_CONSUMER_TIM-ER4_CC0_CLR          | RW   | CC0 Consumer Register       |
| 0x21AC | PRS_CONSUMER_TIM-ER4_CC1_CLR          | RW   | CC1 Consumer Register       |
| 0x21B0 | PRS_CONSUMER_TIM-ER4_CC2_CLR          | RW   | CC2 Consumer Register       |
| 0x21B4 | PRS_CONSUMER_TIM-ER4_DTI_CLR          | RW   | DTI Consumer Register       |
| 0x21B8 | PRS_CONSUMER_TIM-ER4_DTIFS1_CLR       | RW   | DTI Consumer Register       |
| 0x21BC | PRS_CONSUMER_TIM-ER4_DTIFS2_CLR       | RW   | DTI Consumer Register       |
| 0x21C0 | PRS_CONSUM-ER_USART0_CLK_CLR          | RW   | CLK Consumer Register       |
| 0x21C4 | PRS_CONSUM-ER_USART0_IR_CLR           | RW   | IR Consumer Register        |
| 0x21C8 | PRS_CONSUM-ER_USART0_RX_CLR           | RW   | RX Consumer Register        |
| 0x21CC | PRS_CONSUM-ER_USART0_TRIGGER_CLR      | RW   | TRIGGER Consumer Register   |
| 0x21DC | PRS_CONSUM-ER_VDAC0_ASYN-CTRIGCH0_CLR | RW   | ASYNCTRIG Consumer Register |
| 0x21E0 | PRS_CONSUM-ER_VDAC0_ASYN-CTRIGCH1_CLR | RW   | ASYNCTRIG Consumer Register |
| 0x21E4 | PRS_CONSUM-ER_VDAC0_SYN-CTRIGCH0_CLR  | RW   | SYNCTRIG Consumer Register  |
| 0x21E8 | PRS_CONSUM-ER_VDAC0_SYN-CTRIGCH1_CLR  | RW   | SYNCTRIG Consumer Register  |

| Offset | Name                                  | Type | Description                    |
|--------|---------------------------------------|------|--------------------------------|
| 0x21EC | PRS_CONSUM-ER_VDAC1_ASYN-CTRIGCH0_CLR | RW   | ASYNCTRIG Consumer Register    |
| 0x21F0 | PRS_CONSUM-ER_VDAC1_ASYN-CTRIGCH1_CLR | RW   | ASYNCTRIG Consumer Register    |
| 0x21F4 | PRS_CONSUM-ER_VDAC1_SYN-CTRIGCH0_CLR  | RW   | SYNCTRIG Consumer Register     |
| 0x21F8 | PRS_CONSUM-ER_VDAC1_SYN-CTRIGCH1_CLR  | RW   | SYNCTRIG Consumer Register     |
| 0x21FC | PRS_CONSUM-ER_WDOG0_SRC0_CLR          | RW   | SRC0 Consumer Register         |
| 0x2200 | PRS_CONSUM-ER_WDOG0_SRC1_CLR          | RW   | SRC1 Consumer Register         |
| 0x2204 | PRS_CONSUM-ER_WDOG1_SRC0_CLR          | RW   | SRC0 Consumer Register         |
| 0x2208 | PRS_CONSUM-ER_WDOG1_SRC1_CLR          | RW   | SRC1 Consumer Register         |
| 0x3000 | PRS_IPVERSION_TGL                     | R    | PRS IPVERSION                  |
| 0x3008 | PRS_ASYNC_SWPULSE_TGL                 | W    | Software Pulse Register        |
| 0x300C | PRS_ASYNC_SWLEVEL_TGL                 | RW   | Software Level Register        |
| 0x3010 | PRS_ASYNC_PEEK_TGL                    | RH   | Async Channel Values           |
| 0x3014 | PRS_SYNC_PEEK_TGL                     | RH   | Sync Channel Values            |
| 0x3018 | PRS_ASYNC_CHx_CTRL_TGL                | RW   | Async Channel Control Register |
| 0x3058 | PRS_SYNC_CHx_CTRL_TGL                 | RW   | Sync Channel Control Register  |
| 0x3068 | PRS_CONSUM-ER_CMU_CALDN_TGL           | RW   | CALDN Consumer Register        |
| 0x306C | PRS_CONSUMER_CMU_CAL-UP_TGL           | RW   | CALUP Consumer Register        |
| 0x3070 | PRS_CONSUMER_EU-SART0_CLK_TGL         | RW   | CLK Consumer Register          |
| 0x3074 | PRS_CONSUMER_EU-SART0_RX_TGL          | RW   | RX Consumer Register           |
| 0x3078 | PRS_CONSUMER_EU-SART0_TRIGGER_TGL     | RW   | TRIGGER Consumer Register      |
| 0x307C | PRS_CONSUMER_EU-SART1_CLK_TGL         | RW   | CLK Consumer Register          |
| 0x3080 | PRS_CONSUMER_EU-SART1_RX_TGL          | RW   | RX Consumer Register           |
| 0x3084 | PRS_CONSUMER_EU-SART1_TRIGGER_TGL     | RW   | TRIGGER Consumer Register      |
| 0x308C | PRS_CONSUM-ER_IADC0_SCANTRIG-GER_TGL  | RW   | SCAN Consumer Register         |

| Offset | Name                                   | Type | Description                   |
|--------|----------------------------------------|------|-------------------------------|
| 0x3090 | PRS_CONSUMER_IADC0_SIN-GLETRIGGER_TGL  | RW   | SINGLE Consumer Register      |
| 0x3094 | PRS_CONSUMER_LDMAX-BAR_DMAREQ0_TGL     | RW   | DMAREQ0 Consumer Register     |
| 0x3098 | PRS_CONSUMER_LDMAX-BAR_DMAREQ1_TGL     | RW   | DMAREQ1 Consumer Register     |
| 0x309C | PRS_CONSUMER_LETIM-ER0_CLEAR_TGL       | RW   | CLEAR Consumer Register       |
| 0x30A0 | PRS_CONSUMER_LETIM-ER0_START_TGL       | RW   | START Consumer Register       |
| 0x30A4 | PRS_CONSUMER_LETIM-ER0_STOP_TGL        | RW   | STOP Consumer Register        |
| 0x30A8 | PRS_CONSUMER_MO-DEM_DIN_TGL            | RW   | DIN Consumer Register         |
| 0x30AC | PRS_CONSUMER_MO-DEM_PAEN_TGL           | RW   | PAEN Consumer Register        |
| 0x30B0 | PRS_CONSUM-ER_PCNT0_S0IN_TGL           | RW   | S0IN Consumer Register        |
| 0x30B4 | PRS_CONSUM-ER_PCNT0_S1IN_TGL           | RW   | S1IN Consumer Register        |
| 0x30E4 | PRS_CONSUM-ER_RAC_CLR_TGL              | RW   | CLR Consumer Register         |
| 0x30E8 | PRS_CONSUM-ER_RAC_CTIIN0_TGL           | RW   | CTI Consumer Register         |
| 0x30EC | PRS_CONSUM-ER_RAC_CTIIN1_TGL           | RW   | CTI Consumer Register         |
| 0x30F0 | PRS_CONSUM-ER_RAC_CTIIN2_TGL           | RW   | CTI Consumer Register         |
| 0x30F4 | PRS_CONSUM-ER_RAC_CTIIN3_TGL           | RW   | CTI Consumer Register         |
| 0x30F8 | PRS_CONSUM-ER_RAC_FORCETX_TGL          | RW   | FORCETX Consumer Register     |
| 0x30FC | PRS_CONSUM-ER_RAC_RXDIS_TGL            | RW   | RXDIS Consumer Register       |
| 0x3100 | PRS_CONSUM-ER_RAC_RXEN_TGL             | RW   | RXEN Consumer Register        |
| 0x3104 | PRS_CONSUM-ER_RAC_TXEN_TGL             | RW   | TXEN Consumer Register        |
| 0x3108 | PRS_CONSUMER_SETAM-PER_TAMPERSRC25_TGL | RW   | TAMPERSRC25 Consumer Register |
| 0x310C | PRS_CONSUMER_SETAM-PER_TAMPERSRC26_TGL | RW   | TAMPERSRC26 Consumer Register |
| 0x3110 | PRS_CONSUMER_SETAM-PER_TAMPERSRC27_TGL | RW   | TAMPERSRC27 Consumer Register |
| 0x3114 | PRS_CONSUMER_SETAM-PER_TAMPERSRC28_TGL | RW   | TAMPERSRC28 Consumer Register |

| Offset | Name                                   | Type | Description                   |
|--------|----------------------------------------|------|-------------------------------|
| 0x3118 | PRS_CONSUMER_SETAM_PER_TAMPERSRC29_TGL | RW   | TAMPERSRC29 Consumer Register |
| 0x311C | PRS_CONSUMER_SETAM_PER_TAMPERSRC30_TGL | RW   | TAMPERSRC30 Consumer Register |
| 0x3120 | PRS_CONSUMER_SETAM_PER_TAMPERSRC31_TGL | RW   | TAMPERSRC31 Consumer Register |
| 0x3124 | PRS_CONSUM-ER_SYSRTC0_IN0_TGL          | RW   | IN0 Consumer Register         |
| 0x3128 | PRS_CONSUM-ER_SYSRTC0_IN1_TGL          | RW   | IN1 Consumer Register         |
| 0x312C | PRS_CONSUMER_HFX00_OS-CREQ_TGL         | RW   | OSCREQ Consumer Register      |
| 0x3130 | PRS_CONSUM-ER_HFX00_TIMEOUT_TGL        | RW   | TIMEOUT Consumer Register     |
| 0x3134 | PRS_CONSUM-ER_CORE_CTIIN0_TGL          | RW   | CTI0 Consumer Selection       |
| 0x3138 | PRS_CONSUM-ER_CORE_CTIIN1_TGL          | RW   | CTI1 Consumer Selection       |
| 0x313C | PRS_CONSUM-ER_CORE_CTIIN2_TGL          | RW   | CTI2 Consumer Selection       |
| 0x3140 | PRS_CONSUM-ER_CORE_CTIIN3_TGL          | RW   | CTI3 Consumer Selection       |
| 0x3144 | PRS_CONSUM-ER_CORE_M33RXEV_TGL         | RW   | M33 Consumer Selection        |
| 0x3148 | PRS_CONSUMER_TIM-ER0_CC0_TGL           | RW   | CC0 Consumer Register         |
| 0x314C | PRS_CONSUMER_TIM-ER0_CC1_TGL           | RW   | CC1 Consumer Register         |
| 0x3150 | PRS_CONSUMER_TIM-ER0_CC2_TGL           | RW   | CC2 Consumer Register         |
| 0x3154 | PRS_CONSUMER_TIM-ER0_DTI_TGL           | RW   | DTI Consumer Register         |
| 0x3158 | PRS_CONSUMER_TIM-ER0_DTIFS1_TGL        | RW   | DTI Consumer Register         |
| 0x315C | PRS_CONSUMER_TIM-ER0_DTIFS2_TGL        | RW   | DTI Consumer Register         |
| 0x3160 | PRS_CONSUMER_TIM-ER1_CC0_TGL           | RW   | CC0 Consumer Register         |
| 0x3164 | PRS_CONSUMER_TIM-ER1_CC1_TGL           | RW   | CC1 Consumer Register         |
| 0x3168 | PRS_CONSUMER_TIM-ER1_CC2_TGL           | RW   | CC2 Consumer Register         |
| 0x316C | PRS_CONSUMER_TIM-ER1_DTI_TGL           | RW   | DTI Consumer Register         |
| 0x3170 | PRS_CONSUMER_TIM-ER1_DTIFS1_TGL        | RW   | DTI Consumer Register         |

| Offset | Name                             | Type | Description               |
|--------|----------------------------------|------|---------------------------|
| 0x3174 | PRS_CONSUMER_TIM-ER1_DTIFS2_TGL  | RW   | DTI Consumer Register     |
| 0x3178 | PRS_CONSUMER_TIM-ER2_CC0_TGL     | RW   | CC0 Consumer Register     |
| 0x317C | PRS_CONSUMER_TIM-ER2_CC1_TGL     | RW   | CC1 Consumer Register     |
| 0x3180 | PRS_CONSUMER_TIM-ER2_CC2_TGL     | RW   | CC2 Consumer Register     |
| 0x3184 | PRS_CONSUMER_TIM-ER2_DTI_TGL     | RW   | DTI Consumer Register     |
| 0x3188 | PRS_CONSUMER_TIM-ER2_DTIFS1_TGL  | RW   | DTI Consumer Register     |
| 0x318C | PRS_CONSUMER_TIM-ER2_DTIFS2_TGL  | RW   | DTI Consumer Register     |
| 0x3190 | PRS_CONSUMER_TIM-ER3_CC0_TGL     | RW   | CC0 Consumer Register     |
| 0x3194 | PRS_CONSUMER_TIM-ER3_CC1_TGL     | RW   | CC1 Consumer Register     |
| 0x3198 | PRS_CONSUMER_TIM-ER3_CC2_TGL     | RW   | CC2 Consumer Register     |
| 0x319C | PRS_CONSUMER_TIM-ER3_DTI_TGL     | RW   | DTI Consumer Register     |
| 0x31A0 | PRS_CONSUMER_TIM-ER3_DTIFS1_TGL  | RW   | DTI Consumer Register     |
| 0x31A4 | PRS_CONSUMER_TIM-ER3_DTIFS2_TGL  | RW   | DTI Consumer Register     |
| 0x31A8 | PRS_CONSUMER_TIM-ER4_CC0_TGL     | RW   | CC0 Consumer Register     |
| 0x31AC | PRS_CONSUMER_TIM-ER4_CC1_TGL     | RW   | CC1 Consumer Register     |
| 0x31B0 | PRS_CONSUMER_TIM-ER4_CC2_TGL     | RW   | CC2 Consumer Register     |
| 0x31B4 | PRS_CONSUMER_TIM-ER4_DTI_TGL     | RW   | DTI Consumer Register     |
| 0x31B8 | PRS_CONSUMER_TIM-ER4_DTIFS1_TGL  | RW   | DTI Consumer Register     |
| 0x31BC | PRS_CONSUMER_TIM-ER4_DTIFS2_TGL  | RW   | DTI Consumer Register     |
| 0x31C0 | PRS_CONSUM-ER_USART0_CLK_TGL     | RW   | CLK Consumer Register     |
| 0x31C4 | PRS_CONSUM-ER_USART0_IR_TGL      | RW   | IR Consumer Register      |
| 0x31C8 | PRS_CONSUM-ER_USART0_RX_TGL      | RW   | RX Consumer Register      |
| 0x31CC | PRS_CONSUM-ER_USART0_TRIGGER_TGL | RW   | TRIGGER Consumer Register |

| Offset | Name                                  | Type | Description                 |
|--------|---------------------------------------|------|-----------------------------|
| 0x31DC | PRS_CONSUM-ER_VDAC0_ASYN-CTRIGCH0_TGL | RW   | ASYNCTRIG Consumer Register |
| 0x31E0 | PRS_CONSUM-ER_VDAC0_ASYN-CTRIGCH1_TGL | RW   | ASYNCTRIG Consumer Register |
| 0x31E4 | PRS_CONSUM-ER_VDAC0_SYN-CTRIGCH0_TGL  | RW   | SYNCTRIG Consumer Register  |
| 0x31E8 | PRS_CONSUM-ER_VDAC0_SYN-CTRIGCH1_TGL  | RW   | SYNCTRIG Consumer Register  |
| 0x31EC | PRS_CONSUM-ER_VDAC1_ASYN-CTRIGCH0_TGL | RW   | ASYNCTRIG Consumer Register |
| 0x31F0 | PRS_CONSUM-ER_VDAC1_ASYN-CTRIGCH1_TGL | RW   | ASYNCTRIG Consumer Register |
| 0x31F4 | PRS_CONSUM-ER_VDAC1_SYN-CTRIGCH0_TGL  | RW   | SYNCTRIG Consumer Register  |
| 0x31F8 | PRS_CONSUM-ER_VDAC1_SYN-CTRIGCH1_TGL  | RW   | SYNCTRIG Consumer Register  |
| 0x31FC | PRS_CONSUM-ER_WDOG0_SRC0_TGL          | RW   | SRC0 Consumer Register      |
| 0x3200 | PRS_CONSUM-ER_WDOG0_SRC1_TGL          | RW   | SRC1 Consumer Register      |
| 0x3204 | PRS_CONSUM-ER_WDOG1_SRC0_TGL          | RW   | SRC0 Consumer Register      |
| 0x3208 | PRS_CONSUM-ER_WDOG1_SRC1_TGL          | RW   | SRC1 Consumer Register      |

## 13.5 PRS Register Description

### 13.5.1 PRS\_IPVERSION - PRS IPVERSION

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x3          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                             |
|------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | IPVERSION | 0x3   | R      | <b>New BitField</b><br><br>The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION |

### 13.5.2 PRS\_ASYNC\_SWPULSE - Software Pulse Register

| Offset | Bit Position |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |
|--------|--------------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| Reset  | 31           | 30        | 29        | 28        | 27        | 26        | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| Access | W(nB)        | W(nB)     | W(nB)     | W(nB)     | W(nB)     | W(nB)     | W(nB)    | W(nB)    | W(nB)    | W(nB)    | W(nB)    | W(nB)    | W(nB)    | W(nB)    | W(nB)    | W(nB)    |
| Name   | CH15PULSE    | CH14PULSE | CH13PULSE | CH12PULSE | CH11PULSE | CH10PULSE | CH9PULSE | CH8PULSE | CH7PULSE | CH6PULSE | CH5PULSE | CH4PULSE | CH3PULSE | CH2PULSE | CH1PULSE | CH0PULSE |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15    | CH15PULSE | 0x0   | W(nB)  | <b>Channel pulse</b>                                                                                                                                                              |
| 14    | CH14PULSE | 0x0   | W(nB)  | <b>Channel pulse</b>                                                                                                                                                              |
| 13    | CH13PULSE | 0x0   | W(nB)  | <b>Channel pulse</b>                                                                                                                                                              |
| 12    | CH12PULSE | 0x0   | W(nB)  | <b>Channel pulse</b>                                                                                                                                                              |
| 11    | CH11PULSE | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 11 pulse generation                                                                                                                               |
| 10    | CH10PULSE | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 10 pulse generation                                                                                                                               |
| 9     | CH9PULSE  | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 9 pulse generation                                                                                                                                |
| 8     | CH8PULSE  | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 8 pulse generation                                                                                                                                |
| 7     | CH7PULSE  | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 7 pulse generation                                                                                                                                |
| 6     | CH6PULSE  | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 6 pulse generation                                                                                                                                |
| 5     | CH5PULSE  | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 5 pulse generation                                                                                                                                |
| 4     | CH4PULSE  | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 4 pulse generation                                                                                                                                |
| 3     | CH3PULSE  | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 3 pulse generation                                                                                                                                |

| Bit | Name     | Reset | Access | Description                                        |
|-----|----------|-------|--------|----------------------------------------------------|
| 2   | CH2PULSE | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 2 pulse generation |
| 1   | CH1PULSE | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 1 pulse generation |
| 0   | CH0PULSE | 0x0   | W(nB)  | <b>Channel pulse</b><br>Channel 0 pulse generation |

## 13.5.3 PRS\_ASYNC\_SWLEVEL - Software Level Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x00C         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                       |
|-------|-----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15    | CH15LEVEL | 0x0   | RW     | <b>Channel Level</b>                                                                                                                                              |
| 14    | CH14LEVEL | 0x0   | RW     | <b>Channel Level</b>                                                                                                                                              |
| 13    | CH13LEVEL | 0x0   | RW     | <b>Channel Level</b>                                                                                                                                              |
| 12    | CH12LEVEL | 0x0   | RW     | <b>Channel Level</b>                                                                                                                                              |
| 11    | CH11LEVEL | 0x0   | RW     | <b>Channel Level</b><br>Channel 11 Software Level                                                                                                                 |
| 10    | CH10LEVEL | 0x0   | RW     | <b>Channel Level</b><br>Channel 10 Software Level                                                                                                                 |
| 9     | CH9LEVEL  | 0x0   | RW     | <b>Channel Level</b><br>Channel 9 Software Level                                                                                                                  |
| 8     | CH8LEVEL  | 0x0   | RW     | <b>Channel Level</b><br>Channel 8 Software Level                                                                                                                  |
| 7     | CH7LEVEL  | 0x0   | RW     | <b>Channel Level</b><br>Channel 7 Software Level                                                                                                                  |
| 6     | CH6LEVEL  | 0x0   | RW     | <b>Channel Level</b><br>Channel 6 Software Level                                                                                                                  |
| 5     | CH5LEVEL  | 0x0   | RW     | <b>Channel Level</b><br>Channel 5 Software Level                                                                                                                  |
| 4     | CH4LEVEL  | 0x0   | RW     | <b>Channel Level</b><br>Channel 4 Software Level                                                                                                                  |
| 3     | CH3LEVEL  | 0x0   | RW     | <b>Channel Level</b><br>Channel 3 Software Level                                                                                                                  |

| Bit | Name     | Reset | Access | Description                                      |
|-----|----------|-------|--------|--------------------------------------------------|
| 2   | CH2LEVEL | 0x0   | RW     | <b>Channel Level</b><br>Channel 2 Software Level |
| 1   | CH1LEVEL | 0x0   | RW     | <b>Channel Level</b><br>Channel 1 Software Level |
| 0   | CH0LEVEL | 0x0   | RW     | <b>Channel Level</b><br>Channel 0 Software Level |

#### 13.5.4 PRS ASYNC PEEK - Async Channel Values

| Offset | Bit Position |    |     |    |         |    |     |    |         |    |     |    |         |    |     |    |         |
|--------|--------------|----|-----|----|---------|----|-----|----|---------|----|-----|----|---------|----|-----|----|---------|
| Reset  | 31           | 30 | 29  | 28 | 27      | 26 | 25  | 24 | 23      | 22 | 21  | 20 | 19      | 18 | 17  | 16 |         |
| Access |              |    |     |    |         |    |     |    |         |    |     |    |         |    |     |    |         |
| Name   | CH15VAL      | R  | 0x0 | 15 | CH14VAL | R  | 0x0 | 14 | CH13VAL | R  | 0x0 | 13 | CH12VAL | R  | 0x0 | 12 | CH11VAL |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15    | CH15VAL  | 0x0   | R      | <b>Channel 15 current value</b>                                                                                                                                                   |
| 14    | CH14VAL  | 0x0   | R      | <b>Channel 14 current value</b>                                                                                                                                                   |
| 13    | CH13VAL  | 0x0   | R      | <b>Channel 13 current value</b>                                                                                                                                                   |
| 12    | CH12VAL  | 0x0   | R      | <b>Channel 12 Current Value</b>                                                                                                                                                   |
| 11    | CH11VAL  | 0x0   | R      | <b>Channel 11 Current Value</b><br>See bit 0.                                                                                                                                     |
| 10    | CH10VAL  | 0x0   | R      | <b>Channel 10 Current Value</b><br>See bit 0.                                                                                                                                     |
| 9     | CH9VAL   | 0x0   | R      | <b>Channel 9 Current Value</b><br>See bit 0.                                                                                                                                      |
| 8     | CH8VAL   | 0x0   | R      | <b>Channel 8 Current Value</b><br>See bit 0.                                                                                                                                      |
| 7     | CH7VAL   | 0x0   | R      | <b>Channel 7 Current Value</b><br>See bit 0.                                                                                                                                      |
| 6     | CH6VAL   | 0x0   | R      | <b>Channel 6 Current Value</b><br>See bit 0.                                                                                                                                      |
| 5     | CH5VAL   | 0x0   | R      | <b>Channel 5 Current Value</b><br>See bit 0.                                                                                                                                      |
| 4     | CH4VAL   | 0x0   | R      | <b>Channel 4 Current Value</b><br>See bit 0.                                                                                                                                      |
| 3     | CH3VAL   | 0x0   | R      | <b>Channel 3 Current Value</b><br>See bit 0.                                                                                                                                      |
| 2     | CH2VAL   | 0x0   | R      | <b>Channel 2 Current Value</b>                                                                                                                                                    |

| Bit | Name                                                                                     | Reset | Access | Description                    |
|-----|------------------------------------------------------------------------------------------|-------|--------|--------------------------------|
|     | See bit 0.                                                                               |       |        |                                |
| 1   | CH1VAL                                                                                   | 0x0   | R      | <b>Channel 1 Current Value</b> |
|     | See bit 0.                                                                               |       |        |                                |
| 0   | CH0VAL                                                                                   | 0x0   | R      | <b>Channel 0 Current Value</b> |
|     | Sample the current output value of channel 0. This value may be one or two clock delayed |       |        |                                |

### 13.5.5 PRS\_SYNC\_PEEK - Sync Channel Values

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |        |        |        |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------|--------|--------|--------|-----|
| 0x014         | 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   |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0    | 0x0    | 0x0    | 0x0    | 0x0 |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | R      | R      | R      | R      | R   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | CH3VAL | CH2VAL | CH1VAL | CH0VAL |     |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3    | CH3VAL   | 0x0   | R      | <b>Channel Value</b><br>Channel 3 current value                                                                                                                                   |
| 2    | CH2VAL   | 0x0   | R      | <b>Channel Value</b><br>Channel 2 current value                                                                                                                                   |
| 1    | CH1VAL   | 0x0   | R      | <b>Channel Value</b><br>Channel 1 current value                                                                                                                                   |
| 0    | CH0VAL   | 0x0   | R      | <b>Channel Value</b><br>Channel 0 current value                                                                                                                                   |

## 13.5.6 PRS\_ASYNC\_CHx\_CTRL - Async Channel Control Register

| Offset | Bit Position |    |    |    |        |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |           |   |   |   |   |     |   |   |   |        |
|--------|--------------|----|----|----|--------|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|-----------|---|---|---|---|-----|---|---|---|--------|
| 0x018  | 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      |
| Reset  |              |    |    |    | 0x0    |    |    |    |    |    |    |    |    | 0xC   |    |    |    |    |    |    |    |    | 0x0       |   |   |   |   | 0x0 |   |   |   |        |
| Access |              |    |    |    | RW     |    |    |    |    |    |    |    |    | RW    |    |    |    |    |    |    |    |    | RW        |   |   |   |   | RW  |   |   |   |        |
| Name   |              |    |    |    | AUXSEL |    |    |    |    |    |    |    |    | FNSEL |    |    |    |    |    |    |    |    | SOURCESEL |   |   |   |   |     |   |   |   | SIGSEL |

| Bit   | Name      | Reset        | Access | Description                                                                                                                                                       |
|-------|-----------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved  |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 27:24 | AUXSEL    | 0x0          | RW     | <b>Aux Select</b><br>Select Asynchronous PRS channel as input B of LUT function. Async PRS[n] is selected with AUXSEL = n.                                        |
| 23:20 | Reserved  |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 19:16 | FNSEL     | 0xC          | RW     | <b>Function Select</b><br>Look up table function select. Signal A is the selected producer input. Signal B is the output of the previous PRS channel.             |
|       | Value     | Mode         |        | Description                                                                                                                                                       |
|       | 0         | LOGICAL_ZERO |        | Logical 0                                                                                                                                                         |
|       | 1         | A_NOR_B      |        | A NOR B                                                                                                                                                           |
|       | 2         | NOT_A_AND_B  |        | (!A) AND B                                                                                                                                                        |
|       | 3         | NOT_A        |        | !A                                                                                                                                                                |
|       | 4         | A_AND_NOT_B  |        | A AND (!B)                                                                                                                                                        |
|       | 5         | NOT_B        |        | !B                                                                                                                                                                |
|       | 6         | A_XOR_B      |        | A XOR B                                                                                                                                                           |
|       | 7         | A_NAND_B     |        | A NAND B                                                                                                                                                          |
|       | 8         | A_AND_B      |        | A AND B                                                                                                                                                           |
|       | 9         | A_XNOR_B     |        | A XNOR B                                                                                                                                                          |
|       | 10        | B            |        | B                                                                                                                                                                 |
|       | 11        | NOT_A_OR_B   |        | (!A) OR B                                                                                                                                                         |
|       | 12        | A            |        | A                                                                                                                                                                 |
|       | 13        | A_OR_NOT_B   |        | A OR (!B)                                                                                                                                                         |
|       | 14        | A_OR_B       |        | A OR B                                                                                                                                                            |
|       | 15        | LOGICAL_ONE  |        | Logical 1                                                                                                                                                         |
| 15    | Reserved  |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 14:8  | SOURCESEL | 0x0          | RW     | <b>Source Select</b>                                                                                                                                              |

| Bit                                                                                             | Name     | Reset | Access      | Description                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------|----------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select input source for asynchronous PRS channel. See Asynchronous Producers table for details. |          |       |             |                                                                                                                                                                   |
| 7:3                                                                                             | Reserved |       |             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| Select signal input for asynchronous PRS channel. See Asynchronous Producers table for details. |          |       |             |                                                                                                                                                                   |
| 2:0                                                                                             | SIGSEL   | 0x0   | RW          | <b>Signal Select</b>                                                                                                                                              |
| Select signal input for asynchronous PRS channel. See Asynchronous Producers table for details. |          |       |             |                                                                                                                                                                   |
|                                                                                                 | Value    | Mode  | Description |                                                                                                                                                                   |
|                                                                                                 | 0        | NONE  |             |                                                                                                                                                                   |

### 13.5.7 PRS\_SYNC\_CHx\_CTRL - Sync Channel Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |     |   |   |           |  |        |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|-----|---|---|-----------|--|--------|--|
| 0x058  | 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         |  |        |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | 0x0 |   | 0x0 |   |   |           |  |        |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RW  |   | RW  |   |   |           |  |        |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |     |   |   | SOURCESEL |  | SIGSEL |  |

| Bit                                      | Name      | Reset | Access      | Description                                                                                                                                                       |
|------------------------------------------|-----------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select input source to sync PRS channel. |           |       |             |                                                                                                                                                                   |
| 31:15                                    | Reserved  |       |             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| Select signal input to sync PRS channel. |           |       |             |                                                                                                                                                                   |
| 14:8                                     | SOURCESEL | 0x0   | RW          | <b>Source Select</b>                                                                                                                                              |
| Select input source to sync PRS channel. |           |       |             |                                                                                                                                                                   |
| 7:3                                      | Reserved  |       |             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 2:0                                      | SIGSEL    | 0x0   | RW          | <b>Signal Select</b>                                                                                                                                              |
| Select signal input to sync PRS channel. |           |       |             |                                                                                                                                                                   |
|                                          | Value     | Mode  | Description |                                                                                                                                                                   |
|                                          | 0         | NONE  |             |                                                                                                                                                                   |

#### **13.5.8 PRS\_CONSUMER\_CMU\_CALDN - CALDN Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CALDN async channel select</b>                                                                                                                                                 |

### **13.5.9 PRS\_CONSUMER\_CMU\_CALUP - CALUP Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CALUP async channel select</b><br><br>CALUP async channel select                                                                                                               |

### **13.5.10 PRS\_CONSUMER\_EUSART0\_CLK - CLK Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CLK async channel select</b><br>CLK async channel select                                                                                                                       |

### 13.5.11 PRS\_CONSUMER\_EUSART0\_RX - RX Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>RX async channel select</b><br><br>RX async channel select                                                                                                                     |

### 13.5.12 PRS\_CONSUMER\_EUSART0\_TRIGGER - TRIGGER Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TRIGGER async channel select</b>                                                                                                                                               |

### **13.5.13 PRS\_CONSUMER\_EUSART1\_CLK - CLK Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CLK async channel select</b>                                                                                                                                                   |

## 13.5.14 PRS\_CONSUMER\_EUSART1\_RX - RX Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |       |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|-------|----|
| 0x080  | 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 |  |  |       |    |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |       |    |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |       |    |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  | PRSEL | RW |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                   |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------|
| 31:4 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                               |
| 3:0  | PRSEL    | 0x0                                                                                                                                                                               | RW     | <b>RX async channel select</b><br><br>RX async channel select |

## 13.5.15 PRS\_CONSUMER\_EUSART1\_TRIGGER - TRIGGER Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |     |       |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|-----|-------|----|
| 0x084  | 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 |  |  |     |       |    |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  | 0x0 |       |    |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |     |       |    |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |     | PRSEL | RW |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                             |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------|
| 31:4 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                         |
| 3:0  | PRSEL    | 0x0                                                                                                                                                                               | RW     | <b>TRIGGER async channel select</b><br><br>TRIGGER async channel select |

**13.5.16 PRS\_CONSUMER\_IADC0\_SCANTRIGGER - SCAN Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x08C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL                   | 0x0   | RW     | <b>SCAN sync channel select</b>                                                                                                                                                   |
|       | SCAN sync channel select  |       |        |                                                                                                                                                                                   |
| 7:4   | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | PRSSEL                    | 0x0   | RW     | <b>SCAN async channel select</b>                                                                                                                                                  |
|       | SCAN async channel select |       |        |                                                                                                                                                                                   |

**13.5.17 PRS\_CONSUMER\_IADC0\_SINGLEtrigger - SINGLE Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x090  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL                     | 0x0   | RW     | <b>SINGLE sync channel select</b>                                                                                                                                                 |
|       | SINGLE sync channel select  |       |        |                                                                                                                                                                                   |
| 7:4   | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | PRSSEL                      | 0x0   | RW     | <b>SINGLE async channel select</b>                                                                                                                                                |
|       | SINGLE async channel select |       |        |                                                                                                                                                                                   |

## 13.5.18 PRS\_CONSUMER\_LDMAXBAR\_DMAREQ0 - DMAREQ0 Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |       |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|-------|----|
| 0x094  | 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 |  |       |    |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |       |    |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |       |    |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | PRSEL | RW |

| Bit  | Name                         | Reset                                                                                                                                                                             | Access | Description                         |
|------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|
| 31:4 | Reserved                     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                     |
| 3:0  | PRSEL                        | 0x0                                                                                                                                                                               | RW     | <b>DMAREQ0 async channel select</b> |
|      | DMAREQ0 async channel select |                                                                                                                                                                                   |        |                                     |

## 13.5.19 PRS\_CONSUMER\_LDMAXBAR\_DMAREQ1 - DMAREQ1 Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |       |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|-------|----|
| 0x098  | 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 |  |       |    |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | 0x0   |    |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | RW    |    |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | PRSEL | RW |

| Bit  | Name                         | Reset                                                                                                                                                                             | Access | Description                         |
|------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|
| 31:4 | Reserved                     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                     |
| 3:0  | PRSEL                        | 0x0                                                                                                                                                                               | RW     | <b>DMAREQ1 async channel select</b> |
|      | DMAREQ1 async channel select |                                                                                                                                                                                   |        |                                     |

#### **13.5.20 PRS\_CONSUMER\_LETIME0\_CLEAR - CLEAR Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CLEAR async channel select</b><br><br>CLEAR async channel select                                                                                                               |

#### **13.5.21 PRS\_CONSUMER\_LETIME0\_START - START Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>START async channel select</b><br><br>START async channel select                                                                                                               |

#### **13.5.22 PRS\_CONSUMER\_LETIMER0\_STOP - STOP Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>STOP async channel select</b>                                                                                                                                                  |

### **13.5.23 PRS\_CONSUMER\_MODEM\_DIN - DIN Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DIN async channel select</b><br>DIN async channel select                                                                                                                       |

#### **13.5.24 PRS\_CONSUMER\_MODEM\_PAEN - PAEN Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>PAEN async channel select</b>                                                                                                                                                  |

### 13.5.25 PRS\_CONSUMER\_PCNT0\_S0IN - S0IN Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>S0IN async channel select</b><br><br>S0IN async channel select                                                                                                                 |

### 13.5.26 PRS\_CONSUMER\_PCNT0\_S1IN - S1IN Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>S1IN async channel select</b><br><br>S1IN async channel select                                                                                                                 |

### **13.5.27 PRS\_CONSUMER\_RAC\_CLR - CLR Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CLR async channel select</b><br><br>CLR async channel select                                                                                                                   |

### **13.5.28 PRS\_CONSUMER\_RAC\_CTIIN0 - CTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b>                                                                                                                                                   |

### **13.5.29 PRS\_CONSUMER\_RAC\_CTIIN1 - CTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b><br><br>CTI async channel select                                                                                                                   |

### **13.5.30 PRS\_CONSUMER\_RAC\_CTIIN2 - CTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b>                                                                                                                                                   |

### **13.5.31 PRS\_CONSUMER\_RAC\_CTIIN3 - CTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b><br><br>CTI async channel select                                                                                                                   |

### **13.5.32 PRS\_CONSUMER\_RAC\_FORCECTX - FORCECTX Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>FORCETX async channel select</b>                                                                                                                                               |

### 13.5.33 PRS\_CONSUMER\_RAC\_RXDIS - RXDIS Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>RXDIS async channel select</b>                                                                                                                                                 |

#### **13.5.34 PRS\_CONSUMER\_RAC\_RXEN - RXEN Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>RXEN</b> async channel select                                                                                                                                                  |

### 13.5.35 PRS\_CONSUMER\_RAC\_TXEN - TXEN Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TXEN</b> async channel select<br><br>TXEN async channel select                                                                                                                 |

### **13.5.36 PRS CONSUMER SETAMPER TAMPERSRC25 - TAMPERSRC25 Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TAMPERSRC25 async channel select</b>                                                                                                                                           |

### **13.5.37 PRS\_CONSUMER\_SETAMPER\_TAMPERSRC26 - TAMPERSRC26 Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TAMPERSRC26 async channel select</b>                                                                                                                                           |

### **13.5.38 PRS CONSUMER SETAMPER TAMPERSRC27 - TAMPERSRC27 Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TAMPERSRC27 async channel select</b>                                                                                                                                           |

### 13.5.39 PRS\_CONSUMER\_SETAMPER\_TAMPERSRC28 - TAMPERSRC28 Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TAMPERSRC28 async channel select</b>                                                                                                                                           |

#### **13.5.40 PRS CONSUMER SETAMPER TAMPERSRC29 - TAMPERSRC29 Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TAMPERSRC29 async channel select</b>                                                                                                                                           |

### 13.5.41 PRS\_CONSUMER\_SETAMPER\_TAMPERSRC30 - TAMPERSRC30 Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TAMPERSRC30 async channel select</b>                                                                                                                                           |

13.5.42 PRS CONSUMER SETAMPER TAMPERSRC31 - TAMPERSRC31 Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TAMPERSRC31 async channel select</b><br>TAMPERSRC31 async channel select                                                                                                       |

### 13.5.43 PRS\_CONSUMER\_SYSRTC0\_IN0 - IN0 Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>IN0 async channel select</b><br><br>IN0 async channel select                                                                                                                   |

#### **13.5.44 PRS\_CONSUMER\_SYSRTC0\_IN1 - IN1 Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>IN1 async channel select</b>                                                                                                                                                   |
|      |          |       |        | IN1 async channel select                                                                                                                                                          |

### 13.5.45 PRS\_CONSUMER\_HFX00\_OSCREQ - OSCREQ Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>OSC async channel select</b>                                                                                                                                                   |

OSC async channel select

#### **13.5.46 PRS\_CONSUMER\_HFX00\_TIMEOUT - TIMEOUT Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TIMEOUT async channel select</b>                                                                                                                                               |

### **13.5.47 PRS\_CONSUMER\_CORE\_CTIIN0 - CTI0 Consumer Selection**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b><br><br>CTI async channel select                                                                                                                   |

### **13.5.48 PRS\_CONSUMER\_CORE\_CTIIN1 - CTI1 Consumer Selection**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b>                                                                                                                                                   |

### **13.5.49 PRS\_CONSUMER\_CORE\_01IIN2 - CTI2 Consumer Selection**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b><br><br>CTI async channel select                                                                                                                   |

### **13.5.50 PRS\_CONSUMER\_CORE\_CTIIN3 - CTI3 Consumer Selection**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CTI async channel select</b>                                                                                                                                                   |

### **13.5.51 PRS\_CONSUMER\_CORE\_M33RXEV - M33 Consumer Selection**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>M33 async channel select</b><br><br>M33 async channel select                                                                                                                   |

### 13.5.52 PRS\_CONSUMER\_TIMER0\_CC0 - CC0 Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x148  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC0 sync channel select</b>                                                                                                                                    |
|       | CC0 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC0 async channel select</b>                                                                                                                                   |
|       | CC0 async channel select |       |        |                                                                                                                                                                   |

### 13.5.53 PRS\_CONSUMER\_TIMER0\_CC1 - CC1 Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x14C  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC1 sync channel select</b>                                                                                                                                    |
|       | CC1 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC1 async channel select</b>                                                                                                                                   |
|       | CC1 async channel select |       |        |                                                                                                                                                                   |

**13.5.54 PRS\_CONSUMER\_TIMER0\_CC2 - CC2 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |         |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|---|---|---|---|
| 0x150  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0     |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW      |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | SPRSSEL |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC2 sync channel select</b>                                                                                                                                                    |
|       | CC2 sync channel select  |       |        |                                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC2 async channel select</b>                                                                                                                                                   |
|       | CC2 async channel select |       |        |                                                                                                                                                                                   |

**13.5.55 PRS\_CONSUMER\_TIMER0\_DTI - DTI Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------|---|---|---|---|
| 0x154  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW     |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | PRSSEL |   |   |   |   |

| Bit  | Name                     | Reset | Access | Description                                                                                                                                                                       |
|------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL                   | 0x0   | RW     | <b>DTI async channel select</b>                                                                                                                                                   |
|      | DTI async channel select |       |        |                                                                                                                                                                                   |

### **13.5.56 PRS\_CONSUMER\_TIMER0\_DTIFS1 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b>                                                                                                                                                   |

### **13.5.57 PRS\_CONSUMER\_TIMER0\_DTIFS2 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br><br>DTI async channel select                                                                                                                   |

**13.5.58 PRS\_CONSUMER\_TIMER1\_CC0 - CC0 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x160  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC0 sync channel select</b>                                                                                                                                    |
|       | CC0 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC0 async channel select</b>                                                                                                                                   |
|       | CC0 async channel select |       |        |                                                                                                                                                                   |

**13.5.59 PRS\_CONSUMER\_TIMER1\_CC1 - CC1 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x164  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC1 sync channel select</b>                                                                                                                                    |
|       | CC1 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC1 async channel select</b>                                                                                                                                   |
|       | CC1 async channel select |       |        |                                                                                                                                                                   |

**13.5.60 PRS\_CONSUMER\_TIMER1\_CC2 - CC2 Consumer Register**

| Offset | Bit Position |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |       |  |
|--------|--------------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|-------|--|
| 0x168  | 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  |       |  |
| Reset  | 0x0          |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |       |  |
| Access |              |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |       |  |
| Name   |              |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |       |  |
|        | SPRSSEL      | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | PRSEL |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC2 sync channel select</b>                                                                                                                                                    |
|       | CC2 sync channel select  |       |        |                                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC2 async channel select</b>                                                                                                                                                   |
|       | CC2 async channel select |       |        |                                                                                                                                                                                   |

**13.5.61 PRS\_CONSUMER\_TIMER1\_DTI - DTI Consumer Register**

| Offset | Bit Position |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         | PRSEL |       |   |   |   |  |  |  |
|--------|--------------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|----|---------|-------|-------|---|---|---|--|--|--|
| 0x16C  | 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 |  |  |  |
| Reset  | 0x0          |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |       |       |   |   |   |  |  |  |
| Access |              |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |       |       |   |   |   |  |  |  |
| Name   |              |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |    |         |       |       |   |   |   |  |  |  |
|        | SPRSSEL      | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW | SPRSSEL | RW    | PRSEL |   |   |   |  |  |  |

| Bit  | Name                     | Reset | Access | Description                                                                                                                                                                       |
|------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL                   | 0x0   | RW     | <b>DTI async channel select</b>                                                                                                                                                   |
|      | DTI async channel select |       |        |                                                                                                                                                                                   |

### **13.5.62 PRS\_CONSUMER\_TIMER1\_DTIFS1 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br>DTI async channel select                                                                                                                       |

### **13.5.63 PRS\_CONSUMER\_TIMER1\_DTIFS2 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br><br>DTI async channel select                                                                                                                   |

**13.5.64 PRS\_CONSUMER\_TIMER2\_CC0 - CC0 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x178  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC0 sync channel select</b>                                                                                                                                    |
|       | CC0 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC0 async channel select</b>                                                                                                                                   |
|       | CC0 async channel select |       |        |                                                                                                                                                                   |

**13.5.65 PRS\_CONSUMER\_TIMER2\_CC1 - CC1 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x17C  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC1 sync channel select</b>                                                                                                                                    |
|       | CC1 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC1 async channel select</b>                                                                                                                                   |
|       | CC1 async channel select |       |        |                                                                                                                                                                   |

**13.5.66 PRS\_CONSUMER\_TIMER2\_CC2 - CC2 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |         |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|---|---|---|---|
| 0x180  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0     |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW      |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | SPRSSEL |   |   |   |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | PRSSEL  |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC2 sync channel select</b>                                                                                                                                                    |
|       | CC2 sync channel select  |       |        |                                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC2 async channel select</b>                                                                                                                                                   |
|       | CC2 async channel select |       |        |                                                                                                                                                                                   |

**13.5.67 PRS\_CONSUMER\_TIMER2\_DTI - DTI Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------|---|---|---|---|
| 0x184  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW     |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | PRSSEL |   |   |   |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | PRSSEL |   |   |   |   |

| Bit  | Name                     | Reset | Access | Description                                                                                                                                                                       |
|------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL                   | 0x0   | RW     | <b>DTI async channel select</b>                                                                                                                                                   |
|      | DTI async channel select |       |        |                                                                                                                                                                                   |

### **13.5.68 PRS\_CONSUMER\_TIMER2\_DTIFS1 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b>                                                                                                                                                   |

### **13.5.69 PRS\_CONSUMER\_TIMER2\_DTIFS2 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br><br>DTI async channel select                                                                                                                   |

### 13.5.70 PRS\_CONSUMER\_TIMER3\_CC0 - CC0 Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x190  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC0 sync channel select</b>                                                                                                                                    |
|       | CC0 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC0 async channel select</b>                                                                                                                                   |
|       | CC0 async channel select |       |        |                                                                                                                                                                   |

### 13.5.71 PRS\_CONSUMER\_TIMER3\_CC1 - CC1 Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x194  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC1 sync channel select</b>                                                                                                                                    |
|       | CC1 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC1 async channel select</b>                                                                                                                                   |
|       | CC1 async channel select |       |        |                                                                                                                                                                   |

**13.5.72 PRS\_CONSUMER\_TIMER3\_CC2 - CC2 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |         |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|---|---|---|---|
| 0x198  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0     |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW      |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | SPRSSEL |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC2 sync channel select</b>                                                                                                                                                    |
|       | CC2 sync channel select  |       |        |                                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC2 async channel select</b>                                                                                                                                                   |
|       | CC2 async channel select |       |        |                                                                                                                                                                                   |

**13.5.73 PRS\_CONSUMER\_TIMER3\_DTI - DTI Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------|---|---|---|---|
| 0x19C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW     |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | PRSSEL |   |   |   |   |

| Bit  | Name                     | Reset | Access | Description                                                                                                                                                                       |
|------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL                   | 0x0   | RW     | <b>DTI async channel select</b>                                                                                                                                                   |
|      | DTI async channel select |       |        |                                                                                                                                                                                   |

#### **13.5.74 PRS\_CONSUMER\_TIMER3 DTIFS1 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br>DTI async channel select                                                                                                                       |

### **13.5.75 PRS\_CONSUMER\_TIMER3\_DTIFS2 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br><br>DTI async channel select                                                                                                                   |

**13.5.76 PRS\_CONSUMER\_TIMER4\_CC0 - CC0 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x1A8  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC0 sync channel select</b>                                                                                                                                    |
|       | CC0 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC0 async channel select</b>                                                                                                                                   |
|       | CC0 async channel select |       |        |                                                                                                                                                                   |

**13.5.77 PRS\_CONSUMER\_TIMER4\_CC1 - CC1 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|--|--|
| 0x1AC  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SPRSSEL |   |   |   |   |   |   |  |  |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                       |
|-------|--------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC1 sync channel select</b>                                                                                                                                    |
|       | CC1 sync channel select  |       |        |                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC1 async channel select</b>                                                                                                                                   |
|       | CC1 async channel select |       |        |                                                                                                                                                                   |

**13.5.78 PRS\_CONSUMER\_TIMER4\_CC2 - CC2 Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |         |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|---|---|---|---|
| 0x1B0  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0     |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW      |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | SPRSSEL |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL                  | 0x0   | RW     | <b>CC2 sync channel select</b>                                                                                                                                                    |
|       | CC2 sync channel select  |       |        |                                                                                                                                                                                   |
| 7:4   | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | PRSSEL                   | 0x0   | RW     | <b>CC2 async channel select</b>                                                                                                                                                   |
|       | CC2 async channel select |       |        |                                                                                                                                                                                   |

**13.5.79 PRS\_CONSUMER\_TIMER4\_DTI - DTI Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |        |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------|---|---|---|---|
| 0x1B4  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW     |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | PRSSEL |   |   |   |   |

| Bit  | Name                     | Reset | Access | Description                                                                                                                                                                       |
|------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL                   | 0x0   | RW     | <b>DTI async channel select</b>                                                                                                                                                   |
|      | DTI async channel select |       |        |                                                                                                                                                                                   |

### **13.5.80 PRS\_CONSUMER\_TIMER4\_DTIFS1 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br>DTI async channel select                                                                                                                       |

### **13.5.81 PRS\_CONSUMER\_TIMER4\_DTIFS2 - DTI Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>DTI async channel select</b><br><br>DTI async channel select                                                                                                                   |

### 13.5.82 PRS\_CONSUMER\_USART0\_CLK - CLK Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>CLK async channel select</b><br>CLK async channel select                                                                                                                       |

### **13.5.83 PRS\_CONSUMER\_USART0\_IR - IR Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>IR async channel select</b>                                                                                                                                                    |

### 13.5.84 PRS CONSUMER USART0 RX - RX Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>RX async channel select</b>                                                                                                                                                    |
|      |          |       |        | RX async channel select                                                                                                                                                           |

### **13.5.85 PRS\_CONSUMER\_USART0\_TRIGGER - TRIGGER Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>TRIGGER async channel select</b><br><br>TRIGGER async channel select                                                                                                           |

## 13.5.86 PRS\_CONSUMER\_VDAC0\_ASYNCTRIGCH0 - ASYNCTRIG Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |       |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|-------|
| 0x1DC  | 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     |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |       |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW  |       |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | PRSEL |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                                 |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------|
| 31:4 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                             |
| 3:0  | PRSEL    | 0x0                                                                                                                                                                               | RW     | <b>ASYNCTRIG async channel select</b><br><br>ASYNCTRIG async channel select |

## 13.5.87 PRS\_CONSUMER\_VDAC0\_ASYNCTRIGCH1 - ASYNCTRIG Consumer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |       |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|-------|
| 0x1E0  | 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     |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |       |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW  |       |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | PRSEL |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                                 |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------|
| 31:4 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                             |
| 3:0  | PRSEL    | 0x0                                                                                                                                                                               | RW     | <b>ASYNCTRIG async channel select</b><br><br>ASYNCTRIG async channel select |

## 13.5.88 PRS\_CONSUMER\_VDAC0\_SYNCTRGCH0 - SYNCTRG Consumer Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x1E4         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL  | 0x0   | RW     | <b>SYNCTRG sync channel select</b>                                                                                                                                                |
| 7:0   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 13.5.89 PRS\_CONSUMER\_VDAC0\_SYNCTRGCH1 - SYNCTRG Consumer Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x1E8         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL  | 0x0   | RW     | <b>SYNCTRG sync channel select</b>                                                                                                                                                |
| 7:0   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**13.5.90 PRS\_CONSUMER\_VDAC1\_ASYNCTRIGCH0 - ASYNCTRIG Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    |       |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|----|-------|
| 0x1EC  | 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  |       |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |    |       |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | RW |       |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    | PRSEL |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                             |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------|
| 31:4 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                         |
| 3:0  | PRSEL    | 0x0                                                                                                                                                                               | RW     | <b>ASYNCTRIG async channel select</b><br>ASYNCTRIG async channel select |

**13.5.91 PRS\_CONSUMER\_VDAC1\_ASYNCTRIGCH1 - ASYNCTRIG Consumer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |       |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|-------|
| 0x1F0  | 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     |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |       |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW  |       |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | PRSEL |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                             |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------|
| 31:4 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                         |
| 3:0  | PRSEL    | 0x0                                                                                                                                                                               | RW     | <b>ASYNCTRIG async channel select</b><br>ASYNCTRIG async channel select |

**13.5.92 PRS\_CONSUMER\_VDAC1\_SYNCTRGCH0 - SYNCTRG Consumer Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x1F4         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL  | 0x0   | RW     | <b>SYNCTRG sync channel select</b>                                                                                                                                                |
| 7:0   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**13.5.93 PRS\_CONSUMER\_VDAC1\_SYNCTRGCH1 - SYNCTRG Consumer Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x1F8         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | SPRSSEL  | 0x0   | RW     | <b>SYNCTRG sync channel select</b>                                                                                                                                                |
| 7:0   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 13.5.94 PRS\_CONSUMER\_WDOG0\_SRC0 - SRC0 Consumer Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |       |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------|---|---|---|---|---|---|
| 0x1FC         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW    |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PRSEL |   |   |   |   |   |   |

| Bit  | Name                      | Reset                                                                                                                                                                             | Access | Description                      |
|------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------|
| 31:4 | Reserved                  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                  |
| 3:0  | PRSEL                     | 0x0                                                                                                                                                                               | RW     | <b>SRC0 async channel select</b> |
|      | SRC0 async channel select |                                                                                                                                                                                   |        |                                  |

## 13.5.95 PRS\_CONSUMER\_WDOG0\_SRC1 - SRC1 Consumer Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |       |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------|---|---|---|---|---|---|
| 0x200         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW    |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PRSEL |   |   |   |   |   |   |

| Bit  | Name                      | Reset                                                                                                                                                                             | Access | Description                      |
|------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------|
| 31:4 | Reserved                  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                  |
| 3:0  | PRSEL                     | 0x0                                                                                                                                                                               | RW     | <b>SRC1 async channel select</b> |
|      | SRC1 async channel select |                                                                                                                                                                                   |        |                                  |

### 13.5.96 PRS\_CONSUMER\_WDOG1\_SRC0 - SRC0 Consumer Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>SRC0 async channel select</b>                                                                                                                                                  |

### **13.5.97 PRS\_CONSUMER\_WDOG1\_SRC1 - SRC1 Consumer Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0  | PRSSEL   | 0x0   | RW     | <b>SRC1 async channel select</b><br>SRC1 async channel select                                                                                                                     |

## 14. GPCRC - General Purpose Cyclic Redundancy Check



| Quick Facts                                                                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b>                                                                                                                                                                                                                                                                       |
| The GPCRC is an error-detecting module commonly used in digital networks and storage systems to detect accidental changes to data.                                                                                                                                                 |
| <b>Why?</b>                                                                                                                                                                                                                                                                        |
| The GPCRC module can detect errors in data, giving a higher system reliability and robustness.                                                                                                                                                                                     |
| <b>How?</b>                                                                                                                                                                                                                                                                        |
| Blocks of data entering GPCRC module can have a short checksum, based on the remainder of a polynomial division of their contents; on retrieval the calculation is repeated, and corrective action can be taken against presumed data corruption if the check values do not match. |

### 14.1 Introduction

The GPCRC module implements a Cyclic Redundancy Check (CRC) function. It supports both 32-bit and 16-bit polynomials. The supported 32-bit polynomial is 0x04C11DB7(IEEE 802.3), while the 16-bit polynomial can be programmed to any value, depending on the needs of the application. Common 16-bit polynomials are 0x1021 (CCITT-16), 0x3D65 (IEC16-MBus), and 0x8005 (zigbee, 802.15.4, and USB).

### 14.2 Features

- Programmable 16-bit polynomial, fixed 32-bit polynomial
- Byte-level bit reversal for the CRC input
- Byte-order reorientation for the CRC input
- Word or half-word bit reversal of the CRC result
- Ability to configure and seed an operation in a single register write
- Single-cycle CRC computation for 32-, 16-, or 8-bit blocks
- DMA operation

### 14.3 Functional Description

An overview of the GPCRC module is shown in [Figure 14.1 GPCRC Overview on page 429](#).



**Figure 14.1. GPCRC Overview**

### 14.3.1 Polynomial Specification

POLYSEL in GPCRC\_CTRL selects between 32-bit and 16-bit polynomial functions. When a 32-bit polynomial is selected, the fixed IEEE 802.3 polynomial(0x04C11DB7) is used. When a 16-bit polynomial is selected, any valid polynomial can be defined by the user in GPCRC\_POLY.

A valid 16-bit CRC polynomial must have an  $x^{16}$  term and an  $x^0$  term. Theoretically, a 16-bit polynomial has 17 terms total. The convention used is to omit the  $x^{16}$  term. The polynomial should be written in **reversed** (little endian) bit order. The most significant bit corresponds to the lowest order term. Thus, the most significant bit in CRC\_POLY represents the  $x^0$  term, and the least significant bit in CRC\_POLY represents the  $x^{15}$  term. The highest significant bit of CRC\_POLY should always set to 1. The polynomial representation for the CRC-16-CCIT polynomial  $x^{16} + x^{12} + x^5 + 1$ , or 0x8408 in reversed order, is shown in [Figure 14.2 Polynomial Representation on page 430](#).



**Figure 14.2. Polynomial Representation**

### 14.3.2 Input and Output Specification

The CRC input data can be written to the GPCRC\_INPUTDATA, GPCRC\_INPUTDATAWORD or GPCRC\_INPUTDATABYTE register via the APB bus based on different data size. If BYTEMODE in GPCRC\_CTRL is set, only the least significant byte of the data word will be used for the CRC calculation no matter which input register is written. There are also three output registers for different ordering. Reading from GPCRC\_DATA will get the result based on the polynomial in reversed order, while reading from GPCRC\_DATAREV will get the result based on the polynomial in normal order. The CRC calculation completes in one clock cycle. Reads from the GPCRC\_DATA, GPCRC\_DATAREV or GPCRC\_DATABYTEREV registers and writes to the GPCRC\_CMD register are halted while the calculation is in progress.

### 14.3.3 Initialization

The CRC can be pre-loaded or re-initialized by first writing a 32-bit programmable init value to INIT in GPCRC\_INIT and then setting INIT in GPCRC\_CMD. It can also be re-initialized automatically when read from DATA, DATAREV or DATABYTEREV provided that AUTOINIT in GPCRC\_CTRL is set, the CRC would be re-initialized with the stored init value.

### 14.3.4 DMA Usage

A DMA channel may be used to transfer data into the CRC engine. All bytes and half-word writes must be word-aligned. The recommended DMA usage model is to use the DMA to transfer all available words of data and use software writes to capture any remaining bytes.

#### 14.3.5 Byte-Level Bit Reversal and Byte Reordering

The byte-level bit reversal and byte reordering operations occur before the data is used in the CRC calculation. Byte reordering can occur on words or half words. The hardware ignores the BYTEREVERSE field with any byte writes or operations with byte mode enabled (BYTEMODE = 1), but the bit reversal settings (BITREVERSE) are still applied to the byte. 32-bit little endian MSB-first data can be treated like 32-bit little endian LSB-first data, as shown in [Figure 14.3 Data Ordering Example - 32-bit MSB -first to LSB-first on page 431](#). In this example, 32-bit data is written to GPCRC\_INPUTDATA, BYTEREVERSE is set for byte ordering, and BITREVERSE is set for byte-level bit reversal.



**Figure 14.3. Data Ordering Example - 32-bit MSB -first to LSB-first**

When handling 16-bit data, the byte reordering function only swap the two lowest bytes and clear the two highest bytes, as shown in [Figure 14.4 Data Ordering Example - 16-bit MSB -first to LSB-first on page 432](#). In this example, 16-bit data is written to GPCRC\_INPUTDATAWORD, BYTEREVERSE is set for byte ordering, and BITREVERSE is set for byte-level bit reversal.

Input data is big endian,  
MSB-first



**Figure 14.4. Data Ordering Example - 16-bit MSB -first to LSB-first**

Assuming a word input byte order of B3 B2 B1 B0, the values used in the CRC calculation for the various settings of the byte-level bit reversal and byte reordering are shown in [Table 14.1 Byte-Level Bit Reversal and Byte Reordering Results \(B3 B2 B1 B0 Input Order\) on page 432](#).

**Table 14.1. Byte-Level Bit Reversal and Byte Reordering Results (B3 B2 B1 B0 Input Order)**

| Input Width(bits) | BYTEREVERSE Setting | BITREVERSE Setting | Input to CRC Calculation |
|-------------------|---------------------|--------------------|--------------------------|
| 32                | 0                   | 0                  | B3 B2 B1 B0              |
| 32                | 1                   | 1                  | 'B0 'B1 'B2 'B3          |
| 32                | 1                   | 0                  | B0 B1 B2 B3              |
| 32                | 0                   | 1                  | 'B3 'B2 'B1 'B0          |
| 16                | 0                   | 0                  | XX XX B1 B0              |
| 16                | 1                   | 1                  | XX XX 'B0 'B1            |
| 16                | 1                   | 0                  | XX XX B0 B1              |
| 16                | 0                   | 1                  | XX XX 'B1 'B0            |
| 8                 | -                   | 0                  | XX XX XX XX B0           |
| 8                 | -                   | 1                  | XX XX XX XX 'B0          |

| Input Width(bits)                                                                                                                    | BYTEREVERSE Setting | BITREVERSE Setting | Input to CRC Calculation |
|--------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------|--------------------------|
| Notes:                                                                                                                               |                     |                    |                          |
| 1. X indicates a "don't care".<br>2. Bn is the byte field within the word.<br>3. 'Bn is the bit-reversed byte field within the word. |                     |                    |                          |

#### 14.4 GPCRC Register Map

The offset register address is relative to the registers base address.

| Offset | Name                     | Type  | Description                    |
|--------|--------------------------|-------|--------------------------------|
| 0x000  | GPCRC_IPVERSION          | R     | IP Version ID                  |
| 0x004  | GPCRC_EN                 | RW    | CRC Enable                     |
| 0x008  | GPCRC_CTRL               | RW    | Control Register               |
| 0x00C  | GPCRC_CMD                | W     | Command Register               |
| 0x010  | GPCRC_INIT               | RWH   | CRC Init Value                 |
| 0x014  | GPCRC_POLY               | RW    | CRC Polynomial Value           |
| 0x018  | GPCRC_INPUTDATA          | W     | Input 32-Bit Data Register     |
| 0x01C  | GPCRC_INPUTDATAHWORD     | W     | Input 16-Bit Data Register     |
| 0x020  | GPCRC_INPUTDATABYTE      | W     | Input 8-Bit Data Register      |
| 0x024  | GPCRC_DATA               | RH(r) | CRC Data Register              |
| 0x028  | GPCRC_DATAREV            | RH(r) | CRC Data Reverse Register      |
| 0x02C  | GPCRC_DATABYTTEREV       | RH(r) | CRC Data Byte Reverse Register |
| 0x1000 | GPCRC_IPVERSION_SET      | R     | IP Version ID                  |
| 0x1004 | GPCRC_EN_SET             | RW    | CRC Enable                     |
| 0x1008 | GPCRC_CTRL_SET           | RW    | Control Register               |
| 0x100C | GPCRC_CMD_SET            | W     | Command Register               |
| 0x1010 | GPCRC_INIT_SET           | RWH   | CRC Init Value                 |
| 0x1014 | GPCRC_POLY_SET           | RW    | CRC Polynomial Value           |
| 0x1018 | GPCRC_INPUTDATA_SET      | W     | Input 32-Bit Data Register     |
| 0x101C | GPCRC_INPUTDATAHWORD_SET | W     | Input 16-Bit Data Register     |
| 0x1020 | GPCRC_INPUTDATABYTE_SET  | W     | Input 8-Bit Data Register      |
| 0x1024 | GPCRC_DATA_SET           | RH(r) | CRC Data Register              |
| 0x1028 | GPCRC_DATAREV_SET        | RH(r) | CRC Data Reverse Register      |
| 0x102C | GPCRC_DATABYTTEREV_SET   | RH(r) | CRC Data Byte Reverse Register |
| 0x2000 | GPCRC_IPVERSION_CLR      | R     | IP Version ID                  |
| 0x2004 | GPCRC_EN_CLR             | RW    | CRC Enable                     |
| 0x2008 | GPCRC_CTRL_CLR           | RW    | Control Register               |
| 0x200C | GPCRC_CMD_CLR            | W     | Command Register               |
| 0x2010 | GPCRC_INIT_CLR           | RWH   | CRC Init Value                 |
| 0x2014 | GPCRC_POLY_CLR           | RW    | CRC Polynomial Value           |
| 0x2018 | GPCRC_INPUTDATA_CLR      | W     | Input 32-Bit Data Register     |
| 0x201C | GPCRC_INPUTDATAHWORD_CLR | W     | Input 16-Bit Data Register     |
| 0x2020 | GPCRC_INPUTDATABYTE_CLR  | W     | Input 8-Bit Data Register      |

| Offset | Name                      | Type  | Description                    |
|--------|---------------------------|-------|--------------------------------|
| 0x2024 | GPCRC_DATA_CLR            | RH(r) | CRC Data Register              |
| 0x2028 | GPCRC_DATAREV_CLR         | RH(r) | CRC Data Reverse Register      |
| 0x202C | GPCRC_DATABYTEREV_CLR     | RH(r) | CRC Data Byte Reverse Register |
| 0x3000 | GPCRC_IPVERSION_TGL       | R     | IP Version ID                  |
| 0x3004 | GPCRC_EN_TGL              | RW    | CRC Enable                     |
| 0x3008 | GPCRC_CTRL_TGL            | RW    | Control Register               |
| 0x300C | GPCRC_CMD_TGL             | W     | Command Register               |
| 0x3010 | GPCRC_INIT_TGL            | RWH   | CRC Init Value                 |
| 0x3014 | GPCRC_POLY_TGL            | RW    | CRC Polynomial Value           |
| 0x3018 | GPCRC_INPUTDATA_TGL       | W     | Input 32-Bit Data Register     |
| 0x301C | GPCRC_INPUTDATAH-WORD_TGL | W     | Input 16-Bit Data Register     |
| 0x3020 | GPCRC_INPUTDATA-BYTE_TGL  | W     | Input 8-Bit Data Register      |
| 0x3024 | GPCRC_DATA_TGL            | RH(r) | CRC Data Register              |
| 0x3028 | GPCRC_DATAREV_TGL         | RH(r) | CRC Data Reverse Register      |
| 0x302C | GPCRC_DATABYTEREV_TGL     | RH(r) | CRC Data Byte Reverse Register |

## 14.5 GPCRC Register Description

### 14.5.1 GPCRC\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|        | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description   |
|------|-----------|-------|--------|---------------|
| 31:0 | IPVERSION | 0x0   | R      | IP Version ID |

The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION.

#### **14.5.2 GPCRC\_EN - CRC Enable**

| Offset | Bit Position |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset  | 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 |
| Access |              |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|        | EN           | RW | 0x0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                              | Name     | Reset                                                                                                                               | Access | Description                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1                                                                                                                                                                                             | Reserved |                                                                                                                                     |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0                                                                                                                                                                                                | EN       | 0x0                                                                                                                                 | RW     | <b>CRC Enable</b>                                                                                                                                                                 |
| The ENABLE bit enables the module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit. |          |                                                                                                                                     |        |                                                                                                                                                                                   |
| Value                                                                                                                                                                                            | Mode     | Description                                                                                                                         |        |                                                                                                                                                                                   |
| 0                                                                                                                                                                                                | DISABLE  | Disable CRC function. Reordering functions are still available. Only BITREVERSE and BYTEREVERSE bits are configurable in this mode. |        |                                                                                                                                                                                   |
| 1                                                                                                                                                                                                | ENABLE   | Writes to INPUTDATA registers will result in CRC operations.                                                                        |        |                                                                                                                                                                                   |

## 14.5.3 GPCRC\_CTRL - Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |     |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|
| 0x008  | 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 |  |  |  |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0         |    |     |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW          |    |     |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AUTOINIT    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BYTEREVERSE | RW | 0x0 | 10 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BITREVERSE  | RW | 0x0 | 9  |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BYTEMODE    | RW | 0x0 | 8  |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | POLYSEL     | RW |     |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |

| Bit   | Name        | Reset    | Access | Description                                                                                                                                                                       |
|-------|-------------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | Reserved    |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13    | AUTOINIT    | 0x0      | RW     | <b>Auto Init Enable</b><br><br>Enables auto init by re-seeding the CRC result based on the value in INIT after reading of DATA, DATAREV or DATABYTETEREV.                         |
| 12:11 | Reserved    |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 10    | BYTEREVERSE | 0x0      | RW     | <b>Byte Reverse Mode</b><br><br>Allows byte level reverse of bytes B3, B2, B1, B0 within the 32-bit data word                                                                     |
|       | Value       | Mode     |        | Description                                                                                                                                                                       |
|       | 0           | NORMAL   |        | No reverse: B3, B2, B1, B0                                                                                                                                                        |
|       | 1           | REVERSED |        | Reverse byte order. For 32-bit: B0, B1, B2, B3; For 16-bit: 0, 0, B0, B1                                                                                                          |
| 9     | BITREVERSE  | 0x0      | RW     | <b>Byte-level Bit Reverse Enable</b><br><br>Reverses bits within each byte of the 32-bit data word                                                                                |
|       | Value       | Mode     |        | Description                                                                                                                                                                       |
|       | 0           | NORMAL   |        | No reverse                                                                                                                                                                        |
|       | 1           | REVERSED |        | Reverse bit order in each byte                                                                                                                                                    |
| 8     | BYTEMODE    | 0x0      | RW     | <b>Byte Mode Enable</b><br><br>Treats all writes as bytes. Only the least significant byte of the data-word will be used for CRC calculation for all writes                       |
| 7:5   | Reserved    |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4     | POLYSEL     | 0x0      | RW     | <b>Polynomial Select</b><br><br>Selects 16-bit CRC programmable polynomial or 32-bit CRC fixed polynomial                                                                         |
|       | Value       | Mode     |        | Description                                                                                                                                                                       |
|       | 0           | CRC32    |        | CRC-32 (0x04C11DB7) polynomial selected                                                                                                                                           |
|       | 1           | CRC16    |        | 16-bit CRC programmable polynomial selected                                                                                                                                       |

| Bit | Name     | Reset | Access | Description                                                                                                                                                                       |
|-----|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

#### **14.5.4 GPCRC\_CMD - Command Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | INIT     | 0x0   | W      | <b>Initialization Enable</b><br><br>Writing 1 to this bit initialize the CRC by writing the INIT value in CRC_INIT to CRC_DATA.                                                   |

#### **14.5.5 GPCRC\_INIT - CRC Init Value**

| Bit                                                                         | Name | Reset | Access | Description                     |
|-----------------------------------------------------------------------------|------|-------|--------|---------------------------------|
| 31:0                                                                        | INIT | 0x0   | RW     | <b>CRC Initialization Value</b> |
| This value is loaded into CRC_DATA upon issuing the INIT command in CRC_CMD |      |       |        |                                 |

#### 14.5.6 GPCRC\_POLY - CRC Polynomial Value

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|------|
| 0x014  | 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    |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |      |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW  |      |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | POLY |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | POLY     | 0x0   | RW     | <b>CRC Polynomial Value</b>                                                                                                                                                       |

This value defines 16-bit POLY, which is used as the polynomial during the 16-bit CRC calculation. The polynomial is defined in reversed representation, meaning that the lowest degree term is in the highest bit position of POLY. Additionally, the highest degree term in the polynomial is implicit. Further examples of the CRC configuration can be found in the documentation.

#### 14.5.7 GPCRC\_INPUTDATA - Input 32-Bit Data Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |           |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|-----------|
| 0x018  | 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         |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |           |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | W   |           |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | INPUTDATA |

| Bit  | Name      | Reset | Access | Description                  |
|------|-----------|-------|--------|------------------------------|
| 31:0 | INPUTDATA | 0x0   | W      | <b>Input Data for 32-bit</b> |

CRC Input 32-bit Data can be written to this register. Each time this register is written, the CRC value is updated.

#### 14.5.8 GPCRC\_INPUTDATAWORD - Input 16-Bit Data Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|---|---|---|---|---|---|
| 0x01C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0           |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | W             |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | INPUTDATAWORD |   |   |   |   |   |   |

| Bit   | Name          | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | INPUTDATAWORD | 0x0   | W      | <b>Input Data for 16-bit</b><br><br>CRC Input 16-bit Data can be written to this register. Each time this register is written, the CRC value is updated.                          |

#### 14.5.9 GPCRC\_INPUTDATABYTE - Input 8-Bit Data Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |               |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------|---|---|---|---|---|---|
| 0x020  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0           |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | W             |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | INPUTDATABYTE |   |   |   |   |   |   |

| Bit  | Name          | Reset | Access | Description                                                                                                                                                                       |
|------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | INPUTDATABYTE | 0x0   | W      | <b>Input Data for 8-bit</b><br><br>CRC Input 8-bit Data can be written to this register. Each time this register is written, the CRC value is updated.                            |

**14.5.10 GPCRC\_DATA - CRC Data Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x024  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | R(r)         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | DATA         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                                                                                                                                   | Name | Reset | Access | Description              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------|--------------------------|
| 31:0                                                                                                                                                                  | DATA | 0x0   | R(r)   | <b>CRC Data Register</b> |
| CRC Data Register, read only. The CRC data register may still be indirectly written from software, by writing the INIT register and then issue an INITIALIZE command. |      |       |        |                          |

**14.5.11 GPCRC\_DATAREV - CRC Data Reverse Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x028  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R(r)         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DATAREV      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                         | Name    | Reset | Access | Description               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|---------------------------|
| 31:0                                                                                                                                                                                                        | DATAREV | 0x0   | R(r)   | <b>Data Reverse Value</b> |
| Bit reversed version of CRC Data register. When a 32-bit CRC polynomial is selected, the reversal occurs on the entire 32-bit word. When a 16-bit CRC polynomial is selected, the bits [15:0] are reversed. |         |       |        |                           |

**14.5.12 GPCRC\_DATABYTEREV - CRC Data Byte Reverse Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x02C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R(r)         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DATABYTEREV  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                   | Name        | Reset | Access | Description                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------|--------|--------------------------------|
| 31:0                                                                                                                                                                                                                  | DATABYTEREV | 0x0   | R(r)   | <b>Data Byte Reverse Value</b> |
| Byte reversed version of CRC Data register. When a 32-bit CRC polynomial is selected, the bytes are swizzled to {B0, B1, B2, B3}. When a 16-bit CRC polynomial is selected, the bytes are swizzled to {0, 0, B0, B1}. |             |       |        |                                |

## 15. SYSRTC - System RTC



| Quick Facts                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b>                                                                                                                                                                                                                                                                                                                                |
| The System Real-Time Counter (SYSRTC) is a 32-bit Real Time Clock ensuring timekeeping in low energy modes.                                                                                                                                                                                                                                 |
| <b>Why?</b>                                                                                                                                                                                                                                                                                                                                 |
| Timekeeping over long time periods while using as little power as possible is required in many low power applications.                                                                                                                                                                                                                      |
| <b>How?</b>                                                                                                                                                                                                                                                                                                                                 |
| The SYSRTC operates a central counter off a low-frequency oscillator source. It has configurable compare and capture channels which can be used to trigger wake-up, generate PRS signalling, or capture system events. The SYSRTC allows the system to stay in low energy modes for long periods of time and maintain reliable timekeeping. |

### 15.1 Introduction

The SYSRTC (System Real Time Counter), is a 32-bit counter kept running down to energy mode EM3. It can be used as a sleep timer / wakeup source as well as a timekeeping counter during low energy modes. Multiple groups of capture / compare registers are available to different cores in the system, allowing the peripheral and time base to be shared across cores and save energy. Only group 0 registers are directly accessible to the main processor core, but compare / capture signals and interrupts from group 1 are also available to the main processor.

Capture compare channels can be used to trigger interrupts, generate PRS signals, capture PRS events, and to wake the device up from EM1, EM2, or EM3.

**Note:** Critical portions of the EFR32/EFM32 software stack related to system timing and power management make use of SYSRTC in such a way that it is effectively unavailable to user software. Please refer to relevant software documentation for additional information.

### 15.2 Features

- 32-bit counter
- Debug mode
- 32.768 kHz LFXO or LFRCO / 1 kHz ULFRCO
- Low energy wake-up source
- Separate groups of capture / compare registers and signals
  - MCU core and Radio core each control one group
  - 2 compare channels per group
  - 1 capture channel per group
  - Separate interrupt vectors for MCU and Radio events
  - Capture / compare available in PRS

### 15.3 Functional Description

### 15.3.1 Interrupts and Wake Events

Each group has a dedicated, independent interrupt line, and has the ability to wake the system. The Group 0 interrupt line (SYSRTC\_APP) is used and fully controlled by user code running on the main processor. The Group 1 interrupt line (SYSRTC\_SEQ) is also available to the main processor, but Group 1 registers and configuration are not directly available to the user application.

### 15.3.2 Counter

A single counter value (CNT) is used across all groups. The SYSRTC module is enabled by setting its EN bit field. The counter value is asserted to 0x00000000 on reset. The counter can be started/stopped by writing to the START/STOP bit fields in the CMD register. The RUNNING field in the STATUS register indicates that the counter is running when it is set.

Once started, the counter increments by 1 on each cycle (typically 32.768 kHz). The counter value can be programmed directly by writing to the CNT register. Once the programmed value is applied and the counter is running, the counter will increment on every clock starting from the newly programmed value.

When the counter reaches its maximum value of 0xFFFFFFFF, an overflow event is generated, followed by a counter wrap-around to its reset value (from which counting continues) and the OVF interrupt flag (OVFIF) on the next cycle. The overflow event is common for all the groups, i.e. OVFIF flags in all groups get set.

The normal operation of SYSRTC is to configure it, enable it, start it, and then leave it running. This should be done by a single core so that other cores only access the registers for their designated group as needed. If SYSRTC needs to be disabled, it is recommended to stop it first using the STOP command.

### 15.3.3 Compare Events

A compare event for channel "x" of group "n" is generated whenever the counter is RUNNING, the CMPxEN bit is set / enabled in the GRPn\_CTRL register, and the CNT value is equal to the GRPn\_CMPxVALUE register setting. This event is followed by GRPn\_IF.CMPxIF being set on the next counter clock cycle.

Compare events can be routed as PRS producers on the GRPnOUTx signals. There are several options for the match action, selected by CMPxCMOA in GRPn\_CTRL. Note that when using the PULSE option, the PRS output should already be cleared for the pulse to get set and the PULSE option should remain configured until the pulse is cleared (otherwise if the PULSE option is reprogrammed to the SET option, the "pulse" remains set). A possible use case when using the CMPIF option is to signal early events prior to the following wake-up. After wakeup, the compare flag should be processed and cleared. To avoid a race condition on the PRS output, the compare flag should be cleared away from the next possible compare event.

Note that when setting the compare value to the current counter value, a compare event may not get generated until the counter overflows and reaches the current value again. To generate a compare event quickly, it is recommended to program the compare value to the current counter value + 1. Compare events are group-specific.

### 15.3.4 Capture Events

SYSRTC groups support counter value capture triggered by PRS consumer signals. For group "n" the SYSRTC0 "INn" PRS consumer is used to trigger captures. Capture can be triggered on RISING, FALLING, or BOTH edges, according to the setting programmed in CAP0EDGE of the GRPn\_CTRL register. A capture event for group "n" is generated whenever the counter is RUNNING, the CAP0EN bit is set / enabled in the GRPn\_CTRL register, and the desired event occurs on the PRS output.

A capture event is followed by GRPn\_IF\_CAP0IF being set after up to 3 counter clock cycles. At the same time the flag is set, the GRPn\_CAP0VALUE register captures the current counter value. Note that PRS input edges should not occur more frequently than once every three counter cycles. If the counter is being started/stopped or GRPn\_CTRL.CAP0EN / GRPn\_CTRL.CAP0EDGE is changed close to the PRS input edge, a race condition may occur. Capture events are group-specific.

### 15.3.5 SYSRTC Behavior on SWRST/Disablement/STOP

On SWRST / Disablement, the counter is reset to 0x00000000, PRS outputs are cleared, compare/capture events are disabled, compare/capture flags are reset, and the CAP0VALUE register is reset.

When the counter is stopped using the STOP command in the CMD register, all other settings remain unchanged, except that the RUNNING status will return to 0, which blocks any compare/capture events until the counter is started again.

### 15.3.6 Debug Functionality

By default, the counter value is frozen when the main processor is halted during debugging. The RUNNING status bit is not affected by debug halt, and will continue to indicate that the counter is active. If DEBUGRUN in the CFG register is set, the counter will not halt when the main processor is halted, and SYSRTC will continue to count clocks.

Note that the main processor runs on a much higher frequency than the counter and that the halt condition needs to last long enough (more than 3 counter cycles) for the counter to reach the frozen state.

## 15.4 SYSRTC Register Map

The offset register address is relative to the registers base address.

| Offset | Name                       | Type        | Description                   |
|--------|----------------------------|-------------|-------------------------------|
| 0x000  | SYSRTC_IPVERSION           | R           | IP VERSION                    |
| 0x004  | SYSRTC_EN                  | RW ENABLE   | Module Enable Register        |
| 0x008  | SYSRTC_SWRST               | RW SWRST    | Software Reset Register       |
| 0x00C  | SYSRTC_CFG                 | RW CONFIG   | Configuration Register        |
| 0x010  | SYSRTC_CMD                 | W LFSYNC    | Command Register              |
| 0x014  | SYSRTC_STATUS              | RH          | Status Register               |
| 0x018  | SYSRTC_CNT                 | RWH LFSYNC  | Counter Value Register        |
| 0x01C  | SYSRTC_SYNCBUSY            | RH          | Synchronization Busy Register |
| 0x020  | SYSRTC_LOCK                | W           | Configuration Lock Register   |
| 0x040  | SYSRTC_GRP0_IF             | RWH INTFLAG | Group Interrupt Flags         |
| 0x044  | SYSRTC_GRP0_IEN            | RW          | Group Interrupt Enables       |
| 0x048  | SYSRTC_GRP0_CTRL           | RW          | Group Control Register        |
| 0x04C  | SYSRTC_GRP0_CMP0VALUE      | RW          | Compare 0 Value Register      |
| 0x050  | SYSRTC_GRP0_CMP1VALUE      | RW          | Compare 1 Value Register      |
| 0x054  | SYSRTC_GRP0_CAP0VALUE      | RH          | Capture 0 Value Register      |
| 0x058  | SYSRTC_GRP0_SYNCBUSY       | RH          | Synchronization Busy Register |
| 0x1000 | SYSRTC_IPVERSION_SET       | R           | IP VERSION                    |
| 0x1004 | SYSRTC_EN_SET              | RW ENABLE   | Module Enable Register        |
| 0x1008 | SYSRTC_SWRST_SET           | RW SWRST    | Software Reset Register       |
| 0x100C | SYSRTC_CFG_SET             | RW CONFIG   | Configuration Register        |
| 0x1010 | SYSRTC_CMD_SET             | W LFSYNC    | Command Register              |
| 0x1014 | SYSRTC_STATUS_SET          | RH          | Status Register               |
| 0x1018 | SYSRTC_CNT_SET             | RWH LFSYNC  | Counter Value Register        |
| 0x101C | SYSRTC_SYNCBUSY_SET        | RH          | Synchronization Busy Register |
| 0x1020 | SYSRTC_LOCK_SET            | W           | Configuration Lock Register   |
| 0x1040 | SYSRTC_GRP0_IF_SET         | RWH INTFLAG | Group Interrupt Flags         |
| 0x1044 | SYSRTC_GRP0_IEN_SET        | RW          | Group Interrupt Enables       |
| 0x1048 | SYSRTC_GRP0_CTRL_SET       | RW          | Group Control Register        |
| 0x104C | SYSRTC_GRP0_CMP0VAL-UE_SET | RW          | Compare 0 Value Register      |
| 0x1050 | SYSRTC_GRP0_CMP1VAL-UE_SET | RW          | Compare 1 Value Register      |
| 0x1054 | SYSRTC_GRP0_CAP0VAL-UE_SET | RH          | Capture 0 Value Register      |
| 0x1058 | SYSRTC_GRP0_SYN-CBUSY_SET  | RH          | Synchronization Busy Register |
| 0x2000 | SYSRTC_IPVERSION_CLR       | R           | IP VERSION                    |

| Offset | Name                       | Type        | Description                   |
|--------|----------------------------|-------------|-------------------------------|
| 0x2004 | SYSRTC_EN_CLR              | RW ENABLE   | Module Enable Register        |
| 0x2008 | SYSRTC_SWRST_CLR           | RW SWRST    | Software Reset Register       |
| 0x200C | SYSRTC_CFG_CLR             | RW CONFIG   | Configuration Register        |
| 0x2010 | SYSRTC_CMD_CLR             | W LFSYNC    | Command Register              |
| 0x2014 | SYSRTC_STATUS_CLR          | RH          | Status Register               |
| 0x2018 | SYSRTC_CNT_CLR             | RWH LFSYNC  | Counter Value Register        |
| 0x201C | SYSRTC_SYNCBUSY_CLR        | RH          | Synchronization Busy Register |
| 0x2020 | SYSRTC_LOCK_CLR            | W           | Configuration Lock Register   |
| 0x2040 | SYSRTC_GRP0_IF_CLR         | RWH INTFLAG | Group Interrupt Flags         |
| 0x2044 | SYSRTC_GRP0_IEN_CLR        | RW          | Group Interrupt Enables       |
| 0x2048 | SYSRTC_GRP0_CTRL_CLR       | RW          | Group Control Register        |
| 0x204C | SYSRTC_GRP0_CMP0VAL-UE_CLR | RW          | Compare 0 Value Register      |
| 0x2050 | SYSRTC_GRP0_CMP1VAL-UE_CLR | RW          | Compare 1 Value Register      |
| 0x2054 | SYSRTC_GRP0_CAP0VAL-UE_CLR | RH          | Capture 0 Value Register      |
| 0x2058 | SYSRTC_GRP0_SYN-CBUSY_CLR  | RH          | Synchronization Busy Register |
| 0x3000 | SYSRTC_IPVERSION_TGL       | R           | IP VERSION                    |
| 0x3004 | SYSRTC_EN_TGL              | RW ENABLE   | Module Enable Register        |
| 0x3008 | SYSRTC_SWRST_TGL           | RW SWRST    | Software Reset Register       |
| 0x300C | SYSRTC_CFG_TGL             | RW CONFIG   | Configuration Register        |
| 0x3010 | SYSRTC_CMD_TGL             | W LFSYNC    | Command Register              |
| 0x3014 | SYSRTC_STATUS_TGL          | RH          | Status Register               |
| 0x3018 | SYSRTC_CNT_TGL             | RWH LFSYNC  | Counter Value Register        |
| 0x301C | SYSRTC_SYNCBUSY_TGL        | RH          | Synchronization Busy Register |
| 0x3020 | SYSRTC_LOCK_TGL            | W           | Configuration Lock Register   |
| 0x3040 | SYSRTC_GRP0_IF_TGL         | RWH INTFLAG | Group Interrupt Flags         |
| 0x3044 | SYSRTC_GRP0_IEN_TGL        | RW          | Group Interrupt Enables       |
| 0x3048 | SYSRTC_GRP0_CTRL_TGL       | RW          | Group Control Register        |
| 0x304C | SYSRTC_GRP0_CMP0VAL-UE_TGL | RW          | Compare 0 Value Register      |
| 0x3050 | SYSRTC_GRP0_CMP1VAL-UE_TGL | RW          | Compare 1 Value Register      |
| 0x3054 | SYSRTC_GRP0_CAP0VAL-UE_TGL | RH          | Capture 0 Value Register      |
| 0x3058 | SYSRTC_GRP0_SYN-CBUSY_TGL  | RH          | Synchronization Busy Register |

## 15.5 SYSRTC Register Description

### **15.5.1 SYSRTC\_IPVERSION - IP VERSION**

| Bit                                      | Name      | Reset | Access | Description       |
|------------------------------------------|-----------|-------|--------|-------------------|
| 31:0                                     | IPVERSION | 0x1   | R      | <b>IP VERSION</b> |
| Gives access to the IP VERSION of SYSRTC |           |       |        |                   |

### **15.5.2 SYSRTC\_EN - Module Enable Register**

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                       |
|------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | DISABLING | 0x0   | R      | <b>Disablement busy status</b><br>Set when EN cleared and cleared when the peripheral core reset is finished                                                                      |
| 0    | EN        | 0x0   | RW     | <b>SYSRTC Enable</b><br>Enable the SYSRTC by requesting Clk from CMU                                                                                                              |

### 15.5.3 SYSRTC\_SWRST - Software Reset Register

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                       |
|------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | RESETTING | 0x0   | R      | <b>Software reset busy status</b><br><br>When SWRST command is issued, resetting logic sets this status immediately and it is later cleared when the reset process is finished    |
| 0    | SWRST     | 0x0   | W      | <b>Software reset command</b><br><br>A software reset command field resets the module back to the initial condition, similar to the power-on reset condition                      |

#### 15.5.4 SYSRTC\_CFG - Configuration Register

| Bit  | Name     | Reset                                                        | Access                          | Description                                                                                                                                                                       |
|------|----------|--------------------------------------------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved |                                                              |                                 | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | DEBUGRUN | 0x0                                                          | RW                              | <b>Debug Mode Run Enable</b>                                                                                                                                                      |
|      |          | Set this bit to keep the SYSRTC running during a debug halt. |                                 |                                                                                                                                                                                   |
|      | Value    | Mode                                                         | Description                     |                                                                                                                                                                                   |
|      | 0        | DISABLE                                                      | SYSRTC is frozen in debug mode  |                                                                                                                                                                                   |
|      | 1        | ENABLE                                                       | SYSRTC is running in debug mode |                                                                                                                                                                                   |

**15.5.5 SYSRTC\_CMD - Command Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x010  | 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 |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| STOP   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| START  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | STOP     | 0x0   | W(nB)  | <b>Stop SYSRTC</b><br><br>Write a 1 to stop the SYSRTC                                                                                                                            |
| 0    | START    | 0x0   | W(nB)  | <b>Start SYSRTC</b><br><br>Write a 1 to start the SYSRTC                                                                                                                          |

**15.5.6 SYSRTC\_STATUS - Status Register**

| Offset     | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x014      | 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 |  |
| Reset      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name       |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| LOCKSTATUS |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| RUNNING    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name       | Reset | Access | Description                                                                                                                                                                       |
|------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | LOCKSTATUS | 0x0   | R      | <b>Lock Status</b><br><br>Indicates the current status of SYSRTC Lock                                                                                                             |
|      | Value      | Mode  |        | Description                                                                                                                                                                       |
| 0    | UNLOCKED   |       |        | SYSRTC registers are unlocked                                                                                                                                                     |
| 1    | LOCKED     |       |        | SYSRTC registers are locked                                                                                                                                                       |
| 0    | RUNNING    | 0x0   | R      | <b>SYSRTC running status</b><br><br>Indicates the current status of SYSRTC running                                                                                                |

**15.5.7 SYSRTC\_CNT - Counter Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x018  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | CNT          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                              | Name | Reset | Access | Description          |
|--------------------------------------------------|------|-------|--------|----------------------|
| 31:0                                             | CNT  | 0x0   | RW     | <b>Counter Value</b> |
| Gives access to the counter value of the SYSRTC. |      |       |        |                      |

**15.5.8 SYSRTC\_SYNCBUSY - Synchronization Busy Register**

| Offset | Bit Position   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x01C  | 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 |  |
| Reset  | 0x0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | CNT STOP START |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                | Name     | Reset                                                                                                                                                                      | Access | Description                         |
|----------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|
| 31:3                                               | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                     |
|                                                    |          |                                                                                                                                                                            |        |                                     |
| 2                                                  | CNT      | 0x0                                                                                                                                                                        | R      | <b>Sync busy for CNT bitfield</b>   |
| Last writing of CNT is synchronizing to LF clock   |          |                                                                                                                                                                            |        |                                     |
| 1                                                  | STOP     | 0x0                                                                                                                                                                        | R      | <b>Sync busy for STOP bitfield</b>  |
| Last writing of STOP is synchronizing to LF clock  |          |                                                                                                                                                                            |        |                                     |
| 0                                                  | START    | 0x0                                                                                                                                                                        | R      | <b>Sync busy for START bitfield</b> |
| Last writing of START is synchronizing to LF clock |          |                                                                                                                                                                            |        |                                     |

**15.5.9 SYSRTC\_LOCK - Configuration Lock Register**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---------|
| 0x020         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0     |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | W       |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | LOCKKEY |

| Bit                                                                                                                                  | Name     | Reset | Access | Description                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                                                | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                                                                                 | LOCKKEY  | 0x0   | W      | <b>Configuration Lock Key</b>                                                                                                                                                     |
| Write any other value than the unlock code to lock EN, SWRST, CFG, CMD, CNT registers from editing. Write the unlock code to unlock. |          |       |        |                                                                                                                                                                                   |
|                                                                                                                                      |          | Value | Mode   | Description                                                                                                                                                                       |
|                                                                                                                                      |          | 18294 | UNLOCK | Write to unlock SYSRTC lockable registers                                                                                                                                         |

**15.5.10 SYSRTC\_GRP0\_IF - Group Interrupt Flags**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|
| 0x040         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0 |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RW  |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | OVF |

| Bit  | Name                                            | Reset | Access | Description                                                                                                                                                                       |
|------|-------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved                                        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3    | CAP0                                            | 0x0   | RW     | <b>Capture 0 Interrupt Flag</b>                                                                                                                                                   |
|      | This bit is set when CAP0VALUE is updated       |       |        |                                                                                                                                                                                   |
| 2    | CMP1                                            | 0x0   | RW     | <b>Compare 1 Interrupt Flag</b>                                                                                                                                                   |
|      | This bit is set when counter matches COMP1VALUE |       |        |                                                                                                                                                                                   |
| 1    | CMP0                                            | 0x0   | RW     | <b>Compare 0 Interrupt Flag</b>                                                                                                                                                   |
|      | This bit is set when counter matches COMP0VALUE |       |        |                                                                                                                                                                                   |
| 0    | OVF                                             | 0x0   | RW     | <b>Overflow Interrupt Flag</b>                                                                                                                                                    |
|      | This bit is set when counter overflows          |       |        |                                                                                                                                                                                   |

## 15.5.11 SYSRTC\_GRP0\_IEN - Group Interrupt Enables

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |      |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|------|-----|
| 0x044         | 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    |     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0  | 3   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0  | 2   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | CAP0 | 1   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | CMP1 | 0x0 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | CMP0 | 0x0 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | OVF  | 0   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                       |
|------|-----------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3    | CAP0            | 0x0   | RW     | <b>Capture 0 Interrupt Enable</b><br>Enable CAP0 interrupt                                                                                                        |
| 2    | CMP1            | 0x0   | RW     | <b>Compare 1 Interrupt Enable</b><br>Enable CMP1 interrupt                                                                                                        |
| 1    | CMP0            | 0x0   | RW     | <b>Compare 0 Interrupt Enable</b><br>Enable CMP0 interrupt                                                                                                        |
| 0    | OVF             | 0x0   | RW     | <b>Overflow Interrupt Enable</b><br>Enable OVF interrupt                                                                                                          |

## 15.5.12 SYSRTC\_GRP0\_CTRL - Group Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |          |          |        |        |        |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|----------|----------|--------|--------|--------|---|
| 0x048  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0      | 0x0      | 0x0      | 0x0    | 0x0    |        |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW       | RW       | RW       | RW     | RW     |        |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CAP0EDGE | CMP1CMOA | CMP0CMOA | CAP0EN | CMP1EN | CMP0EN |   |

| Bit   | Name     | Reset   | Access | Description                                                                                                                                                       |
|-------|----------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 10:9  | CAP0EDGE | 0x0     | RW     | <b>Capture 0 Edge Select</b><br><br>Select edge detection for Capture 0                                                                                           |
|       | Value    | Mode    |        | Description                                                                                                                                                       |
|       | 0        | RISING  |        | Rising edges detected                                                                                                                                             |
|       | 1        | FALLING |        | Falling edges detected                                                                                                                                            |
|       | 2        | BOTH    |        | Both edges detected                                                                                                                                               |
| 8:6   | CMP1CMOA | 0x0     | RW     | <b>Compare 1 Compare Match Output Action</b><br><br>Select PRS output action on Compare 1 match                                                                   |
|       | Value    | Mode    |        | Description                                                                                                                                                       |
|       | 0        | CLEAR   |        | Cleared on the next cycle                                                                                                                                         |
|       | 1        | SET     |        | Set on the next cycle                                                                                                                                             |
|       | 2        | PULSE   |        | Set on the next cycle, cleared on the cycle after                                                                                                                 |
|       | 3        | TOGGLE  |        | Inverted on the next cycle                                                                                                                                        |
|       | 4        | CMPIF   |        | Export this channel's CMP IF                                                                                                                                      |
| 5:3   | CMP0CMOA | 0x0     | RW     | <b>Compare 0 Compare Match Output Action</b><br><br>Select PRS output action on Compare 0 match                                                                   |
|       | Value    | Mode    |        | Description                                                                                                                                                       |
|       | 0        | CLEAR   |        | Cleared on the next cycle                                                                                                                                         |
|       | 1        | SET     |        | Set on the next cycle                                                                                                                                             |
|       | 2        | PULSE   |        | Set on the next cycle, cleared on the cycle after                                                                                                                 |
|       | 3        | TOGGLE  |        | Inverted on the next cycle                                                                                                                                        |
|       | 4        | CMPIF   |        | Export this channel's CMP IF                                                                                                                                      |
| 2     | CAP0EN   | 0x0     | RW     | <b>Capture 0 Enable</b><br><br>Set this bit to enable Capture 0                                                                                                   |

| Bit | Name   | Reset | Access | Description                                                 |
|-----|--------|-------|--------|-------------------------------------------------------------|
| 1   | CMP1EN | 0x0   | RW     | <b>Compare 1 Enable</b><br>Set this bit to enable Compare 1 |
| 0   | CMP0EN | 0x0   | RW     | <b>Compare 0 Enable</b><br>Set this bit to enable Compare 0 |

#### 15.5.13 SYSRTC\_GRP0\_CMP0VALUE - Compare 0 Value Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x04C         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | CMP0VALUE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                                     |
|------|-----------|-------|--------|-------------------------------------------------|
| 31:0 | CMP0VALUE | 0x0   | RW     | <b>Compare 0 Value</b><br>Compare 0 match value |
|      |           |       |        |                                                 |

#### 15.5.14 SYSRTC\_GRP0\_CMP1VALUE - Compare 1 Value Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x050         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   | CMP1VALUE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                                     |
|------|-----------|-------|--------|-------------------------------------------------|
| 31:0 | CMP1VALUE | 0x0   | RW     | <b>Compare 1 Value</b><br>Compare 1 match value |
|      |           |       |        |                                                 |

**15.5.15 SYSRTC\_GRP0\_CAP0VALUE - Capture 0 Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x054  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | CAP0VALUE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name      | Reset | Access | Description                                            |
|------|-----------|-------|--------|--------------------------------------------------------|
| 31:0 | CAP0VALUE | 0x0   | R      | <b>Capture 0 Value</b><br><br>Capture 0 captured value |

**15.5.16 SYSRTC\_GRP0\_SYNCBUSY - Synchronization Busy Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x058  | 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 |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name      | Reset                                                                                                                                                                      | Access | Description                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:3 | Reserved  | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2    | CMP1VALUE | 0x0                                                                                                                                                                        | R      | <b>Sync busy for CMP1VALUE register</b><br><br>Last writing of CMP1VALUE is synchronizing to LF clock |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1    | CMP0VALUE | 0x0                                                                                                                                                                        | R      | <b>Sync busy for CMP0VALUE register</b><br><br>Last writing of CMP0VALUE is synchronizing to LF clock |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0    | CTRL      | 0x0                                                                                                                                                                        | R      | <b>Sync busy for CTRL register</b><br><br>Last writing of CTRL is synchronizing to LF clock           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 16. BURTC - Back-Up Real Time Counter



| Quick Facts                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b>                                                                                                                     |
| The BURTC is a 32 bit counter which operates on a low frequency oscillator, and is capable of running in all Energy Modes.       |
| <b>Why?</b>                                                                                                                      |
| It can provide periodic Wakeup events and PRS signals which can be used to wake up peripherals from any energy mode.             |
| The availability of the BURTC in EM4, where most of the device is powered down, makes it ideal for keeping track of time in EM4. |
| <b>How?</b>                                                                                                                      |
| The BURTC provides a very wide range of periods for the interrupts facilitating flexible ultra-low energy operation.             |

### 16.1 Introduction

The Back-Up Real Time Counter (BURTC) is a 32-bit counter which operates on a low frequency oscillator, and is capable of running in all Energy Modes. It can provide periodic Wakeup events and PRS signals which can be used to wake up peripherals from any energy mode. The BURTC provides a very wide range of periods for the interrupts facilitating flexible ultra-low energy operation. The availability of the BURTC in EM4, where most of the device is powered down, makes it ideal for keeping track of time in EM4. A single compare channel is available which can be used to trigger an interrupt and/or wake the device up from a low energy mode.

### 16.2 Features

A low frequency oscillator is used as clock signal and the BURTC with one compare channel which can trigger wake-up, generate PRS signalling, or capture system events. 32-bit resolution and selectable prescaling allows the system to stay in low energy modes for long periods of time and still maintain reliable timekeeping.

- 32-bit Real Time Counter
- 15-bit pre-counter for flexible frequency scaling of main counter
- EM2/3/4 operation and wakeup
- Reset only by External Pin and Power-On Resets
- Interrupt/wake up event after deterministic intervals
- PRS Outputs
- Debug mode
  - Configurable to either run or stop when processor is stopped (break)

## 16.3 Functional Description

An overview of the BURTC module is shown in [Figure 16.1 BURTC Overview on page 458](#).



**Figure 16.1. BURTC Overview**

### 16.3.1 Clock Selection

The BURTC source clock (BURTCCLK) can be selected to be the LFXO, LFRCO, or ULFRCO by configuring the CMU\_EM4GRPAACLKCTRL.CLKSEL bitfield. Note that in EM3, only ULFRCO is a valid source clock.

### 16.3.2 Configuration

To configure and use the BURTC properly, the following programming sequence must be followed:

1. Configure any desired options in the BURTC\_CFG register. Note that the BURTC\_CFG register can only be written when BURTC\_EN.EN = 0 - a bus fault will occur if writing BURTC\_CFG register while BURTC\_EN.EN = 1.
2. Set BURTC\_EN.EN = 1.
3. Set BURTC\_CMD.START = 1 to start the BURTC counter.

**Note:** All low frequency synchronization registers can only be programmed after EN is set to 1. The BURTC counter will only start to count once START command is issued. For HV Sync registers (e.g., BURTC\_CMD), the first bitfield write will occur without issue. However, on subsequent bitfield writes to HV Sync registers, the firmware needs to poll the corresponding bit in BURTC\_SYNCBUSY before programming the same bitfield once again.

To stop the BURTC, set BURTC\_CMD.STOP = 1

### 16.3.3 Debug Features and Description

By default, the BURTC is halted when code execution is halted from the debugger. By setting the DEBUGRUN bit in the BURTC\_CFG register, the BURTC will continue to run even when the debugger has halted the system.

#### 16.3.4 Counter

The BURTC consists of two counters: the 32-bit main counter, BURTC\_CNT, and a 15-bit pre-counter, BURTC\_PRECNT. The pre-counter is a free running counter clocked by low frequency clock, used to generate a specific frequency for the main counter. The pre-counter will be counting only when the BURTC\_CFG.CNTPRESC value is set greater than 0.

The BURTC peripheral clock is requested by setting the EN bit in BURTC\_EN. Then the BURTC counters can be started by setting the command register START in BURTC\_CMD. When BURTC\_CMD.START has been initiated and BURTC\_CFG.CNTPRESC > 0, the pre-counter (BURTC\_PRECNT) increments upon each positive clock edge of the BURTCCLK, wrapping around to zero when it overflows.

The main counter can be accessed in BURTC\_CNT register, and counts at frequency determined by the CNTPRESC bitfield in BURTC\_CFG. Setting CNTPRESC to 0 gives the maximum resolution, with the main counter clocked at the same frequency as the BURTCCLK. When CNTPRESC > 0, the main counter increments upon each tick given from the pre-counter, allowing the main counter ticks to be power-of-2 divisions of the BURTCCLK.

The [Table 16.1 BURTC Resolution vs Overflow, F<sub>BURTCCLK</sub> = 32768 Hz on page 459](#) table below shows the BURTC Resolution vs Overflow Time when using a 32768 Hz oscillator as the source clock of BURTC.

**Table 16.1. BURTC Resolution vs Overflow, F<sub>BURTCCLK</sub> = 32768 Hz**

| BURTC_CFG.CNTPRESC | Main counter period, T <sub>CNT</sub> | Overflow Time |
|--------------------|---------------------------------------|---------------|
| DIV1               | 30.5 µs                               | 36.4 hours    |
| DIV2               | 61 µs                                 | 72.8 hours    |
| DIV4               | 122 µs                                | 145.6 hours   |
| DIV8               | 244 µs                                | 12 days       |
| DIV16              | 488 µs                                | 24 days       |
| DIV32              | 977 µs                                | 48 days       |
| DIV64              | 1.95 ms                               | 97 days       |
| DIV128             | 3.91 ms                               | 194 days      |
| DIV256             | 7.81 ms                               | 388 days      |
| DIV512             | 15.6 ms                               | 776 days      |
| DIV1024            | 31.25 ms                              | 4.2 years     |
| DIV2048            | 62.5 ms                               | 8.5 years     |
| DIV4096            | 0.125 s                               | 17 years      |
| DIV8192            | 0.25 s                                | 34 years      |
| DIV16384           | 0.5 s                                 | 68 years      |
| DIV32768           | 1 s                                   | 136 years     |

By default, the counter will keep counting until it reaches the top value, 0xFFFFFFFF, and then it wrap around and continue counting from zero. If COMPTOP in BURTC\_CFG is set, the main counter will wrap to 0 on a Compare value match (i.e., BURTC\_CNT = BURTC\_COMP). If using the Compare value match, make sure to set COMPTOP prior to or at the same time the BURTC is enabled. Setting COMPTOP after enabling the BURTC will result in a bus fault error.

The counters of the BURTC, BURTC\_CNT and BURTC\_PRECNT, can at any time be written by software, as long as the registers are not locked using BURTC\_LOCKKEY. All BURTC control registers with Sync Type HV uses the 2 FF synchronization scheme.

**Note:** Writing to the BURTC\_PRECNT register may alter the frequency of the ticks for the BURTC\_CNT register.

### 16.3.5 Compare Channel

A single compare channel is available in the BURTC. The compare value is set in BURTC\_COMP register. If BURTC\_CFG.COMPTOP is set, the main counter will clear to 0 when it matches the value set in BURTC\_COMP.

### 16.3.6 Interrupts

The BURTC has two interrupts: one for counter overflow and another for the compare match event. Individual interrupts are enabled by BURTC\_IEN register bits, and the respective bits can be used as EM2 wakeup. BURTC\_EM4WUEN enables the wakeup enable from EM4 for those events.

### 16.3.7 Register Lock

To prevent accidental writes to the BURTC registers, the BURTC\_LOCK register can be written to any other value than the unlock value. To unlock the register, write the unlock value to BURTC\_LOCKKEY. Registers affected by this lock are:

- BURTC\_CFG
- BURTC\_EN
- BURTC\_CMD
- BURTC\_PRECNT
- BURTC\_CNT
- BURTC\_COMP
- BURTC\_IEN

## 16.4 BURTC Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description                        |
|--------|---------------------|-------------|------------------------------------|
| 0x000  | BURTC_IPVERSION     | R           | IP Version ID                      |
| 0x004  | BURTC_EN            | RW ENABLE   | Module Enable Register             |
| 0x008  | BURTC_CFG           | RW CONFIG   | Configuration Register             |
| 0x00C  | BURTC_CMD           | W LFSYNC    | Command Register                   |
| 0x010  | BURTC_STATUS        | RH          | Status Register                    |
| 0x014  | BURTC_IF            | RWH INTFLAG | Interrupt Flag Register            |
| 0x018  | BURTC_IEN           | RW          | Interrupt Enable Register          |
| 0x01C  | BURTC_PRECNT        | RWH LFSYNC  | Pre-Counter Value Register         |
| 0x020  | BURTC_CNT           | RWH LFSYNC  | Counter Value Register             |
| 0x024  | BURTC_EM4WUEN       | RW          | EM4 Wakeup Request Enable Register |
| 0x028  | BURTC_SYNCBUSY      | RH          | Synchronization Busy Register      |
| 0x02C  | BURTC_LOCK          | W           | Configuration Lock Register        |
| 0x030  | BURTC_COMP          | RW LFSYNC   | Compare Value Register             |
| 0x1000 | BURTC_IPVERSION_SET | R           | IP Version ID                      |
| 0x1004 | BURTC_EN_SET        | RW ENABLE   | Module Enable Register             |
| 0x1008 | BURTC_CFG_SET       | RW CONFIG   | Configuration Register             |
| 0x100C | BURTC_CMD_SET       | W LFSYNC    | Command Register                   |
| 0x1010 | BURTC_STATUS_SET    | RH          | Status Register                    |
| 0x1014 | BURTC_IF_SET        | RWH INTFLAG | Interrupt Flag Register            |
| 0x1018 | BURTC_IEN_SET       | RW          | Interrupt Enable Register          |
| 0x101C | BURTC_PRECNT_SET    | RWH LFSYNC  | Pre-Counter Value Register         |
| 0x1020 | BURTC_CNT_SET       | RWH LFSYNC  | Counter Value Register             |
| 0x1024 | BURTC_EM4WUEN_SET   | RW          | EM4 Wakeup Request Enable Register |
| 0x1028 | BURTC_SYNCBUSY_SET  | RH          | Synchronization Busy Register      |
| 0x102C | BURTC_LOCK_SET      | W           | Configuration Lock Register        |
| 0x1030 | BURTC_COMP_SET      | RW LFSYNC   | Compare Value Register             |
| 0x2000 | BURTC_IPVERSION_CLR | R           | IP Version ID                      |
| 0x2004 | BURTC_EN_CLR        | RW ENABLE   | Module Enable Register             |
| 0x2008 | BURTC_CFG_CLR       | RW CONFIG   | Configuration Register             |
| 0x200C | BURTC_CMD_CLR       | W LFSYNC    | Command Register                   |
| 0x2010 | BURTC_STATUS_CLR    | RH          | Status Register                    |
| 0x2014 | BURTC_IF_CLR        | RWH INTFLAG | Interrupt Flag Register            |
| 0x2018 | BURTC_IEN_CLR       | RW          | Interrupt Enable Register          |
| 0x201C | BURTC_PRECNT_CLR    | RWH LFSYNC  | Pre-Counter Value Register         |
| 0x2020 | BURTC_CNT_CLR       | RWH LFSYNC  | Counter Value Register             |

| Offset | Name                | Type        | Description                        |
|--------|---------------------|-------------|------------------------------------|
| 0x2024 | BURTC_EM4WUEN_CLR   | RW          | EM4 Wakeup Request Enable Register |
| 0x2028 | BURTC_SYNCBUSY_CLR  | RH          | Synchronization Busy Register      |
| 0x202C | BURTC_LOCK_CLR      | W           | Configuration Lock Register        |
| 0x2030 | BURTC_COMP_CLR      | RW LFSYNC   | Compare Value Register             |
| 0x3000 | BURTC_IPVERSION_TGL | R           | IP Version ID                      |
| 0x3004 | BURTC_EN_TGL        | RW ENABLE   | Module Enable Register             |
| 0x3008 | BURTC_CFG_TGL       | RW CONFIG   | Configuration Register             |
| 0x300C | BURTC_CMD_TGL       | W LFSYNC    | Command Register                   |
| 0x3010 | BURTC_STATUS_TGL    | RH          | Status Register                    |
| 0x3014 | BURTC_IF_TGL        | RWH INTFLAG | Interrupt Flag Register            |
| 0x3018 | BURTC_IEN_TGL       | RW          | Interrupt Enable Register          |
| 0x301C | BURTC_PRECNT_TGL    | RWH LFSYNC  | Pre-Counter Value Register         |
| 0x3020 | BURTC_CNT_TGL       | RWH LFSYNC  | Counter Value Register             |
| 0x3024 | BURTC_EM4WUEN_TGL   | RW          | EM4 Wakeup Request Enable Register |
| 0x3028 | BURTC_SYNCBUSY_TGL  | RH          | Synchronization Busy Register      |
| 0x302C | BURTC_LOCK_TGL      | W           | Configuration Lock Register        |
| 0x3030 | BURTC_COMP_TGL      | RW LFSYNC   | Compare Value Register             |

## 16.5 BURTC Register Description

### 16.5.1 BURTC\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|        | 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 |
| Reset  | 0x1          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description   |
|------|-----------|-------|--------|---------------|
| 31:0 | IPVERSION | 0x1   | R      | IP Version ID |

### **16.5.2 BURTC\_EN - Module Enable Register**

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                                                                                                                                                                 |
|------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                           |
| 1    | DISABLING | 0x0   | R      | <b>Disablement busy status</b><br><br>When EN is cleared, DISABLING is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS and FIFOs. The CNT and PRECNT count registers are not reset during disablement. |
| 0    | EN        | 0x0   | RW     | <b>BURTC Enable</b><br><br>Enable the BURTC to make the peripheral clock available to the module                                                                                                                                                                                                                            |

## 16.5.3 BURTC\_CFG - Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |          |         |          |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----------|---------|----------|---|
| 0x008  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |          |         |          |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |          |         |          |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | CNTPRESC | COMPTOP | DEBUGRUN |   |

| Bit  | Name     | Reset    | Access | Description                                                                                                                                                       |
|------|----------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 7:4  | CNTPRESC | 0x0      | RW     | <b>Counter prescaler value.</b><br><br>Configure counting frequency of the CNT register                                                                           |
|      | Value    | Mode     |        | Description                                                                                                                                                       |
|      | 0        | DIV1     |        | CLK_CNT = (BURTC LF CLK)/1                                                                                                                                        |
|      | 1        | DIV2     |        | CLK_CNT = (BURTC LF CLK)/2                                                                                                                                        |
|      | 2        | DIV4     |        | CLK_CNT = (BURTC LF CLK)/4                                                                                                                                        |
|      | 3        | DIV8     |        | CLK_CNT = (BURTC LF CLK)/8                                                                                                                                        |
|      | 4        | DIV16    |        | CLK_CNT = (BURTC LF CLK)/16                                                                                                                                       |
|      | 5        | DIV32    |        | CLK_CNT = (BURTC LF CLK)/32                                                                                                                                       |
|      | 6        | DIV64    |        | CLK_CNT = (BURTC LF CLK)/64                                                                                                                                       |
|      | 7        | DIV128   |        | CLK_CNT = (BURTC LF CLK)/128                                                                                                                                      |
|      | 8        | DIV256   |        | CLK_CNT = (BURTC LF CLK)/256                                                                                                                                      |
|      | 9        | DIV512   |        | CLK_CNT = (BURTC LF CLK)/512                                                                                                                                      |
|      | 10       | DIV1024  |        | CLK_CNT = (BURTC LF CLK)/1024                                                                                                                                     |
|      | 11       | DIV2048  |        | CLK_CNT = (BURTC LF CLK)/2048                                                                                                                                     |
|      | 12       | DIV4096  |        | CLK_CNT = (BURTC LF CLK)/4096                                                                                                                                     |
|      | 13       | DIV8192  |        | CLK_CNT = (BURTC LF CLK)/8192                                                                                                                                     |
|      | 14       | DIV16384 |        | CLK_CNT = (BURTC LF CLK)/16384                                                                                                                                    |
|      | 15       | DIV32768 |        | CLK_CNT = (BURTC LF CLK)/32768                                                                                                                                    |
| 3:2  | Reserved |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 1    | COMPTOP  | 0x0      | RW     | <b>Compare Channel is Top Value</b><br><br>When set, the counter is cleared in the clock cycle after a compare match with compare channel                         |
|      | Value    | Mode     |        | Description                                                                                                                                                       |
|      | 0        | DISABLE  |        | The top value of the BURTC is 4294967295 (0xFFFFFFFF)                                                                                                             |

| Bit | Name     | Reset  | Access | Description                                               |
|-----|----------|--------|--------|-----------------------------------------------------------|
|     | 1        | ENABLE |        | The top value of the BURTC is given by COMP               |
| 0   | DEBUGRUN | 0x0    | RW     | <b>Debug Mode Run Enable</b>                              |
|     |          |        |        | Set this bit to enable the BURTC to keep running in debug |
|     | Value    | Mode   |        | Description                                               |
|     | 0        | X0     |        | BURTC is frozen in debug mode                             |
|     | 1        | X1     |        | BURTC is running in debug mode                            |

#### 16.5.4 BURTC\_CMD - Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |       |       |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------|-------|---|
| 0x00C  | 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     |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0   | 1     |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | W(nB) | 0x0   | 0 |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | STOP  | START |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | STOP     | 0x0   | W(nB)  | <b>Stop BURTC counter</b>                                                                                                                                                         |
|      |          |       |        | Write a 1 to stop the BURTC counter.                                                                                                                                              |
| 0    | START    | 0x0   | W(nB)  | <b>Start BURTC counter</b>                                                                                                                                                        |
|      |          |       |        | Write a 1 to start the BURTC counter.                                                                                                                                             |

### 16.5.5 BURTC\_STATUS - Status Register

| Bit  | Name     | Reset                                         | Access | Description                                                                                                                                                                       |
|------|----------|-----------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |                                               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | LOCK     | 0x0                                           | R      | <b>Configuration Lock Status</b>                                                                                                                                                  |
|      |          | Indicates the current status of BURTC Lock    |        |                                                                                                                                                                                   |
|      | Value    | Mode                                          |        | Description                                                                                                                                                                       |
|      | 0        | UNLOCKED                                      |        | All BURTC lockable registers are unlocked.                                                                                                                                        |
|      | 1        | LOCKED                                        |        | All BURTC lockable registers are locked.                                                                                                                                          |
| 0    | RUNNING  | 0x0                                           | R      | <b>BURTC running status</b>                                                                                                                                                       |
|      |          | Indicates the current status of BURTC running |        |                                                                                                                                                                                   |

### **16.5.6 BURTC\_IF - Interrupt Flag Register**

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | COMP     | 0x0   | RW     | <b>Compare Match Interrupt Flag</b><br><br>Set on a compare match between CNT and COMP.                                                                                           |
| 0    | OF       | 0x0   | RW     | <b>Overflow Interrupt Flag</b><br><br>Set on a CNT value overflow.                                                                                                                |

**16.5.7 BURTC\_IEN - Interrupt Enable Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |      |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|------|-----|
| 0x018         | 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   |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0  | 1   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW   | 0x0 |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | COMP | RW  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | OF   | 0x0 |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | COMP            | 0x0   | RW     | <b>Compare Match Interrupt Flag</b>                                                                                                                                               |
|      |                 |       |        | Set to enable the COMPIF Interrupt                                                                                                                                                |
| 0    | OF              | 0x0   | RW     | <b>Overflow Interrupt Flag</b>                                                                                                                                                    |
|      |                 |       |        | Set to enable the OFIF Interrupt                                                                                                                                                  |

**16.5.8 BURTC\_PRECNT - Pre-Counter Value Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------|---|---|---|
| 0x01C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0    |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW     |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | PRECNT |   |   |   |

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 14:0  | PRECNT          | 0x0   | RW     | <b>Pre-Counter Value</b>                                                                                                                                                          |
|       |                 |       |        | Gives access to the Pre-counter value of the BURTC.                                                                                                                               |

**16.5.9 BURTC\_CNT - Counter Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x020  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | CNT          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                             | Name | Reset | Access | Description          |
|-------------------------------------------------|------|-------|--------|----------------------|
| 31:0                                            | CNT  | 0x0   | RW     | <b>Counter Value</b> |
| Gives access to the counter value of the BURTC. |      |       |        |                      |

**16.5.10 BURTC\_EM4WUEN - EM4 Wakeup Request Enable Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x024  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | COMPEM4WUEN  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                                                      | Name        | Reset                                                                                                                                                                      | Access | Description                            |
|------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------|
| 31:2                                                                                     | Reserved    | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                        |
|                                                                                          |             |                                                                                                                                                                            |        |                                        |
| 1                                                                                        | COMPEM4WUEN | 0x0                                                                                                                                                                        | RW     | <b>Compare Match EM4 Wakeup Enable</b> |
| Compare Match EM4 wakeup requests. No Synchronization done into peripheral clock domain. |             |                                                                                                                                                                            |        |                                        |
| 0                                                                                        | OFEM4WUEN   | 0x0                                                                                                                                                                        | RW     | <b>Overflow EM4 Wakeup Enable</b>      |
| Overflow EM4 Wakeup request. No Synchronization done into peripheral clock domain.       |             |                                                                                                                                                                            |        |                                        |

## 16.5.11 BURTC\_SYNCBUSY - Synchronization Busy Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |        |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|--------|---|
| 0x028         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0  | 4      |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R    | 0x0    |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | COMP | R      |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      | CNT    | R |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      | PRECNT | R |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      | STOP   | R |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      | START  | R |

| Bit  | Name     | Reset                                                                                                                                                             | Access | Description                                                                            |
|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------|
| 31:5 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                        |
| 4    | COMP     | 0x0                                                                                                                                                               | R      | <b>Sync busy for COMP</b><br><br>Last writing of COMP is synchronizing to LF clock     |
| 3    | CNT      | 0x0                                                                                                                                                               | R      | <b>Sync busy for CNT</b><br><br>Last writing of CNT is synchronizing to LF clock       |
| 2    | PRECNT   | 0x0                                                                                                                                                               | R      | <b>Sync busy for PRECNT</b><br><br>Last writing of PRECNT is synchronizing to LF clock |
| 1    | STOP     | 0x0                                                                                                                                                               | R      | <b>Sync busy for STOP</b><br><br>Last writing of STOP is synchronizing to LF clock     |
| 0    | START    | 0x0                                                                                                                                                               | R      | <b>Sync busy for START</b><br><br>Last writing of START is synchronizing to LF clock   |

**16.5.12 BURTC\_LOCK - Configuration Lock Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |   |   |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|---|---|--|
| 0x02C         | 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 |   |   |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0xAEE8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | W       |   |   |   |   |   |   |   |   |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | LOCKKEY |   |   |   |   |   |   |   |   |  |

| Bit                                                                                                                                                                                | Name     | Reset                                        | Access | Description                                                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                                                                                              | Reserved |                                              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:0                                                                                                                                                                               | LOCKKEY  | 0xAEE8                                       | W      | <b>Configuration Lock Key</b>                                                                                                                                     |
| Write any other value than the unlock code to lock BURTC_EN, BURTC_CFG, BURTC_CMD, BURTC_PRECNT, BURTC_CNT and BURTC_COMP registers from editing. Write the unlock code to unlock. |          |                                              |        |                                                                                                                                                                   |
| Value                                                                                                                                                                              | Mode     | Description                                  |        |                                                                                                                                                                   |
| 44776                                                                                                                                                                              | UNLOCK   | Write to unlock all BURTC lockable registers |        |                                                                                                                                                                   |

**16.5.13 BURTC\_COMP - Compare Value Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |  |  |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|--|--|--|
| 0x030         | 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 |  |  |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |  |  |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |  |  |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | COMP |   |   |   |   |   |   |  |  |  |

| Bit                                                                                                                                          | Name | Reset | Access | Description          |
|----------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------|----------------------|
| 31:0                                                                                                                                         | COMP | 0x0   | RW     | <b>Compare Value</b> |
| A compare match event occurs when CNT is equal to this value. This event sets the COMP interrupt flag. It is also available as a PRS signal. |      |       |        |                      |

## 17. BURAM - Backup RAM



| Quick Facts                                                                                                                                                                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b>                                                                                                                                                                       |
| The BURAM is a dedicated 128-byte low-power RAM that is retained in EM4.                                                                                                           |
| <b>Why?</b>                                                                                                                                                                        |
| Most of the system, including the RAM, is powered off at EM4 entry to minimize current draw. The purpose of the BURAM is to retain critical data for use when the system wakes up. |
| <b>How?</b>                                                                                                                                                                        |
| Because it is separate from the main system RAM, the BURAM has a dedicated power supply that is not shutdown when the system enters EM4.                                           |

### 17.1 Introduction

The Back-Up RAM (BURAM) is a dedicated 128-byte RAM that remains powered when the system enters EM4. Upon exit from EM4, the data retained in the BURAM can be accessed by the application software.

### 17.2 Functional Description

The BURAM consists of 32 x 32-bit registers, which are retained in all energy modes, including EM4. Each word in the BURAM is accessible through the corresponding 32 RETx\_REG register. Note that each RETx\_REG register has an undefined state out of reset.

### 17.3 BURAM Register Map

The offset register address is relative to the registers base address.

| Offset | Name               | Type | Description        |
|--------|--------------------|------|--------------------|
| 0x000  | BURAM_RETx_REG     | RW   | Retention Register |
| 0x1000 | BURAM_RETx_REG_SET | RW   | Retention Register |
| 0x2000 | BURAM_RETx_REG_CLR | RW   | Retention Register |
| 0x3000 | BURAM_RETx_REG_TGL | RW   | Retention Register |

## 17.4 BURAM Register Description

### 17.4.1 BURAM\_RETx\_REG - Retention Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW(nB)       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | RETREG       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name   | Reset | Access | Description                                                                                                                                                                                         |
|------|--------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RETREG | 0x0   | RW(nB) | <b>Latch based Retention register</b><br><br>The RETREG registers are undefined out of reset. Any written RETREG values will be retained through any event other than a brownout or power-on reset. |

## 18. LETIMER - Low Energy Timer



### Quick Facts

#### What?

The LETIMER is a down-counter that can keep track of time and output configurable waveforms. Running on a 32768 Hz clock, the LETIMER is available in EM0 Active, EM1 Sleep, EM2 DeepSleep, and EM3 Stop.

#### Why?

The LETIMER can be used to provide repeatable waveforms to external components while remaining in EM2 DeepSleep. It is well suited for applications such as metering systems or to provide more compare values than available in the SYSRTC.

#### How?

With buffered repeat and top value registers, the LETIMER can provide glitch-free waveforms at frequencies up to 16 kHz. It can be coupled with SYSRTC using PRS, allowing advanced time-keeping and wake-up functions in EM2 DeepSleep and EM3 Stop

### 18.1 Introduction

The LETIMER is a down-counter that can keep track of time and output configurable waveforms with minimal software intervention. Running on a Low Frequency clock, the LETIMER is available in Energy Mode0, Energy Mode 1 and optionally available in Energy Mode 2 and Energy Mode 3. Because of this, it can be used for timing and output generation when most of the device is powered down, allowing simple tasks to be performed while the power consumption of the system is kept at an absolute minimum. It is well suited for applications such as metering systems or to provide more compare values than available in the SYSRTC. With buffered repeat and top value registers, the LETIMER can provide glitch-free waveforms at frequencies up to 16 kHz. It can be coupled with other peripherals using PRS, allowing advanced time-keeping and wake-up functions

### 18.2 Features

#### High-level features

- 24-bit Down counter
- 8-bit prescalar
- 2 Compare match registers
- TOP register can be Timer top value
- TOP register can be double buffered using TOPBUFF register
- Double buffered 8-bit Repeat Register
- Timer Start/Stop/Clear trigger can be from PRS or Software
- Configurable 2 Output pins - Toggle/Pulse/PWM
- Interrupt - Compare match/Timer underflow/Repeat done
- Optionally runs during debug
- 2 output pins can optionally be configured to provide different waveforms on timer underflow:
  - Toggle output pin
  - Pulse output with width of One Prescaled clock period
  - PWM
- 2 PRS Output

### 18.3 Functional Description

An overview of the LETIMER module is shown in [Figure 18.1 LETIMER Overview on page 474](#). The LETIMER is a 24-bit down-counter with two compare registers, LETIMERn\_COMP0 and LETIMERn\_COMP1. The LETIMERn\_TOP register can optionally act as a top value for the counter. The repeat counter LETIMERn\_REPEAT0 allows the timer to count a specified number of times before it stops. Both the LETIMERn\_TOP and LETIMERn\_REPEAT0 registers can be double buffered by the LETIMERn\_TOPBUFF and LETIMERn\_REPEAT1 registers to allow continuous operation. The timer can generate a single pin output, or two linked outputs.



Figure 18.1. LETIMER Overview

### 18.3.1 Internal Overview

#### Timer

The timer value can be read using the LETIMERn\_CNT register. The value can be written, and it can also be cleared by setting the CLEAR command bit in LETIMERn\_CMD. If the CLEAR and START commands are issued at the same time, the timer will be cleared, then start counting at the top value.

#### Compare Registers

- The LETIMER has two compare match registers, LETIMERn\_COMP0 and LETIMERn\_COMP1. Each of these compare registers are capable of generating an interrupt when the counter value LETIMERn\_CNT is equal to their value. When LETIMERn\_CNT is equal to the value of LETIMERn\_COMP0, the interrupt flag COMP0 in LETIMERn\_IF is set, and when LETIMERn\_CNT is equal to the value of LETIMERn\_COMP1, the interrupt flag COMP1 in LETIMERn\_IF is set.

- Top Value**

If CNTTOPEN in LETIMERn\_CTRL is set, the value of LETIMERn\_TOP acts as the top value of the timer, and LETIMERn\_TOP is loaded into LETIMERn\_CNT on timer underflow. If CNTTOPEN is cleared to 0, the timer wraps around to 0xFFFFFFF. The underflow interrupt flag UF in LETIMERn\_IF is set when the timer reaches zero.

- Repeat Modes**

By default, the timer wraps around to the top value or 0xFFFFFFF on each underflow, and continues counting. The repeat counters can be used to get more control of the operation of the timer, including defining the number of times the counter should wrap around. Four different repeat modes are available, see [Table 18.1 LETIMER Repeat Modes on page 475](#).

Table 18.1. LETIMER Repeat Modes

| REPMODE | Mode         | Description                                                                                                                                                                                                                                                                                             |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b00    | Free-running | The timer runs until it is stopped.                                                                                                                                                                                                                                                                     |
| 0b01    | One-shot     | The timer runs as long as LETIMERn_REPO != 0. LETIMERn_REPO is decremented at each timer underflow.                                                                                                                                                                                                     |
| 0b10    | Buffered     | The timer runs as long as LETIMERn_REPO != 0. LETIMERn_REPO is decremented on each timer underflow. If LETIMERn_REPO1 has been written with Non zero value, then it is loaded into LETIMERn_REPO when LETIMERn_REPO is about to be decremented to 0 and Timer continue counting with new LETIMERn_REPO. |
| 0b11    | Double       | The timer runs as long as LETIMERn_REPO != 0 or LETIMERn_REPO1 != 0. Both LETIMERn_REPO and LETIMERn_REPO1 are decremented at each timer underflow.                                                                                                                                                     |

The interrupt flags REP0 and REP1 in LETIMERn\_IF are set whenever LETIMERn\_REPO or LETIMERn\_REPO1 are decremented to 0 respectively. REP0 is also set when the value of LETIMERn\_REPO1 is loaded into LETIMERn\_REPO in buffered mode.

Write operations to LETIMERn\_REPO have priority over buffer loads from LETIMERn\_REPO1.

- Buffered Top Value**

In Buffered Mode, If BUFTOP in LETIMERn\_CTRL is set, the value of LETIMERn\_TOP is buffered by LETIMERn\_TOPBUFF. In this mode, the value of LETIMERn\_TOPBUFF is loaded into LETIMERn\_TOP every time LETIMERn\_REPO is about to decrement to 0. This can be used to generate continually changing output waveforms.

Write operations to LETIMERn\_TOP have priority over buffer loads from LETIMERn\_TOPBUFF.

### 18.3.2 Free Running Mode

In free-running mode, the LETIMER acts as a regular timer and the repeat operation is disabled. When started, the timer runs until it is stopped using the STOP command bit in LETIMERn\_CMD/PRS. A state machine for this mode is shown in [Figure 18.2 LETIMER State Machine for Free-running Mode on page 476](#).



Figure 18.2. LETIMER State Machine for Free-running Mode

Note that the CLEAR command bit in LETIMERn\_CMD always has priority over Decrement and Load TOP to LETIMERn\_CNT. When the clear command is used, LETIMERn\_CNT is set to 0 and an underflow event will not be generated when LETIMERn\_CNT wraps around to the top value or 0xFFFFFFF. Since no underflow event is generated, no output action is performed. LETIMERn\_REP0, LETIMERn\_REP1, LETIMERn\_COMP0 and LETIMERn\_COMP1 are also left untouched.

### 18.3.3 One-shot Mode

The one-shot repeat mode is the most basic repeat mode. In this mode, the repeat register LETIMERn\_REPEAT is decremented every time the timer underflows, and the timer stops when LETIMERn\_REPEAT goes from 1 to 0. In this mode, the timer counts down LETIMERn\_REPEAT times, i.e. the timer underflows LETIMERn\_REPEAT times.

**Note:** Note that write operations to LETIMERn\_REPEAT have priority over the timer decrement event. If LETIMERn\_REPEAT is assigned a new value in the same cycle as a timer decrement event occurs, the timer decrement will not occur and the new value is assigned.

LETIMERn\_REPEAT can be written while the timer is running to allow the timer to run for longer periods at a time without stopping. Write to LETIMERn\_REPEAT should be done after checking SYNC busy status [Figure 18.3 LETIMER One-shot Repeat State Machine on page 477](#).



Figure 18.3. LETIMER One-shot Repeat State Machine

#### 18.3.4 Buffered Mode

The Buffered repeat mode allows buffered timer operation. When started, the timer runs LETIMERn\_REPO number of times. If LETIMERn\_REPO has been written since the last time it was used and if it is nonzero, LETIMERn\_REPO is then loaded into LETIMERn\_REPO, and counting continues the new number of times. The timer keeps going as long as LETIMERn\_REPO is updated with a nonzero value before LETIMERn\_REPO is finished counting down. The timer top value (LETIMERn\_TOP) may also optionally be buffered using Top buff value (LETIMERn\_TOPBUFF) by setting BUFTOP in LETIMERn\_CTRL.

If the timer is started when both LETIMERn\_CNT and LETIMERn\_REPO are zero but LETIMERn\_REP1 is non-zero, LETIMERn\_REP1 is loaded into LETIMERn\_REPO, and the counter counts the loaded number of times.

Used in conjunction with a buffered top value, both the top and repeat values of the timer may be buffered, and the timer can for instance be set to run 4 times with period 7 (top value 6), 6 times with period 200, then 3 times with period 50.

A state machine for the buffered repeat mode is shown in Figure 18.4 LETIMER Buffered Repeat State Machine on page 478. REP1<sub>USED</sub> shown in the state machine is an internal variable that keeps track of whether the value in LETIMERn\_REPEAT has been loaded into LETIMERn\_REPEAT0 or not. The purpose of this is that a value written to LETIMERn\_REPEAT1 should only be counted once. REP1<sub>USED</sub> is cleared whenever LETIMERn\_REPEAT1 is used.



**Figure 18.4.** LETIMER Buffered Repeat State Machine

### 18.3.5 Double Mode

The Double repeat mode works much like the one-shot repeat mode. The difference is that, where the one-shot mode counts as long as LETIMERn\_REPO is larger than 0, the double mode counts as long as either LETIMERn\_REPO or LETIMERn\_REP1 is larger than 0. As an example, say LETIMERn\_REPO is 3 and LETIMERn\_REP1 is 10 when the timer is started. If no further interaction is done with the timer, LETIMERn\_REPO will now be decremented 3 times, and LETIMERn\_REP1 will be decremented 10 times. The timer counts a total of 10 times, and LETIMERn\_REPO is 0 after the first three timer underflows and stays at 0. LETIMERn\_REPO and LETIMERn\_REP1 can be written at any time. After a write to either of these, the timer is guaranteed to underflow at least the written number of times if the timer is running. Use the Double repeat mode to generate output on both the LETIMER outputs at the same time. The state machine for this repeat mode can be seen in [Figure 18.5 LETIMER Double Repeat State Machine on page 479](#).



**Figure 18.5. LETIMER Double Repeat State Machine**

## 18.4 Clock Frequency

The LETIMER clock source is derived from EM23GRPACLK, which is selected in the Clock Management Unit (CMU), and is typically configured to have a frequency of 32 kHz in EM0/1/2 and 1 kHz in EM3. The LETIMER clock prescaler is defined by LETIMERn\_CTRL->CNTPRESC.

The LETIMER Prescaled clock frequency is given by [Figure 18.6 LETIMER Clock Frequency on page 480](#).

EM0/1/2 - Clocked by LFRCO

$$f_{\text{LETIMERn\_CLK}} = 32768/2^{\text{CNTPRESC}}$$

EM3 - Clocked by ULFRCO

$$f_{\text{LETIMERn\_CLK}} = 1024/2^{\text{CNTPRESC}}$$

**Figure 18.6. LETIMER Clock Frequency**

The exponent CNTPRESC is a 4 bit value in the LETIMERn\_CTRL->CNTPRESC register bits.

To use this module, the LETIMERn\_CLK must be enabled by writing 1 to LETIMERn\_EN->EN.

## 18.5 PRS Input Triggers

The LETIMER can be configured to start, stop, and/or clear based on PRS inputs. The diagram showing the functions of the PRS input triggers is shown in [Figure 18.7 LETIMER PRS input triggers. on page 481](#).

There are 3 PRS inputs to the LETIMER, allowing the LETIMER to be started, stopped, or cleared based on the PRS inputs. The PRSSTARTMODE, PRSSTOPMODE, and PRSCLEARMODE bitfields in LETIMERn->PRSMODE select which edge or edge(s) will trigger the start, stop, and/or clear action.

The PRS channel inputs can be configured in the PRS\_CONSUMER\_LETIMERn\_CLEAR, PRS\_CONSUMER\_LETIMERn\_START, and PRS\_CONSUMER\_LETIMERn\_STOP registers in the PRS module.



Figure 18.7. LETIMER PRS input triggers.

## 18.6 Debug

If DEBUGRUN in LETIMERn\_CTRL is cleared, the LETIMER automatically stops counting when the CPU is halted during a debug session, and resumes operation when the CPU continues. Because of synchronization, the LETIMER is halted two clock cycles after the CPU is halted, and continues running two clock cycles after the CPU continues. RUNNING in LETIMERn\_STATUS is not cleared when the LETIMER stops because of a debug-session.

Set DEBUGRUN in LETIMERn\_CTRL to allow the LETIMER to continue counting even when the CPU is halted in debug mode.

## 18.7 Output Action

For each of the Outputs, an output action can be set.

The output actions can be set by configuring UFOA0 and UFOA1 in LETIMERn\_CTRL. UFOA0 defines the action on output 0, while UFOA1 defines the action on output 1. The possible actions are defined in [Table 18.2 LETIMER Underflow Output Actions on page 482](#).

**Table 18.2. LETIMER Underflow Output Actions**

| UF0A0/UF0A1 | Mode   | Description                                                                                                   |
|-------------|--------|---------------------------------------------------------------------------------------------------------------|
| 0b00        | Idle   | The output is held at its idle value                                                                          |
| 0b01        | Toggle | The output is toggled on LETIMERn_CNT underflow                                                               |
| 0b10        | Pulse  | The output is held active for one LF clock cycle on LETIMERn_CNT underflow. It then returns to its idle value |
| 0b11        | PWM    | The output is set idle on LETIMERn_CNT underflow and active on compare match with LETIMERn_COMP0/1.           |

**Note:** For the Pulse output Disabling LETIMER, Clearing Output while pulse output is generated can affect the pulse width.

**Note:** For Double mode, OUT0/1 generation is enabled when LETIMERn\_REP0/1 != 0 respectively.

The polarity of the outputs can be set individually by configuring OPOL0 and OPOL1 in LETIMERn\_CTRL. When these are cleared, their respective outputs have a low idle value and a high active value. When they are set, the idle value is high, and the active value is low. It is recommended to Clear outputs after changing polarity to make sure outputs take their default value.

When using the toggle action, the outputs can be driven to their idle values by setting their respective CTO0/CTO1 command bits in LETIMERn\_CTRL. This can be used to put the output in a well-defined state before beginning to generate toggle output, which may be important in some applications. The command bit can also be used while the timer is running.

## 18.8 PRS Output

The LETIMER outputs can be routed out onto the PRS system. LETn\_O0 can be routed to PRS channel 0, and LETn\_O1 can be routed to PRS channel 1. Enabling the PRS connection can be done by setting SOURCESEL to LETIMERx and SIGSEL to LETIMERxCHn in PRS\_CHx\_CTRL.

## 18.9 Interrupts

The interrupts generated by the LETIMER are combined into one interrupt vector. If the interrupt for the LETIMER is enabled, an interrupt will be made if one or more of the interrupt flags in LETIMERn\_IF and their corresponding bits in LETIMER\_IEN are set.

## 18.10 Using the LETIMER in EM3

The LETIMER can be enabled all the way down to EM3 by using the ULFRCO as clock source. This is done by setting CMU\_EM23GRPACLKCTRL.CLKSEL to ULFRCO before enabling the LETIMER block.

## 18.11 Register Access

This module is a Low Energy Peripheral, and supports immediate synchronization. For description regarding immediate synchronization, refer to [4.2.4.4 Peripheral Access Performance](#).

Since this module is a Low Energy Peripheral, and runs off a clock which is asynchronous to the APB register clock, special considerations must be taken when accessing registers.

## 18.12 Programmer's Model

Important Note : Before writing any LFSYNC register, the module must be enabled ( LETIMER\_EN->EN) and the LETIMER\_SYNCBUSY register should be polled to ensure the SYNC busy of that particular register field is not high.

Write LETIMER Configuration into LETIMER CTRL Register

Enable clock to LETIMER module by setting LETIMER\_EN->EN = 1

If used, write compare values into LETIMER COMP0 and LETIMER COMP1

If used, write repeat values into LETIMER REP0 and LETIMER REP1

If used, write LETIMER\_TOP and LETIMER\_TOPBUFF

If PRS is used as a trigger, configure LETIMER\_PRSMODE accordingly.

#### Enable Interrupts in LETIMER\_IEN

Write LETIMER\_CMD register to START Timer

### 18.12.1 Free Running Mode

LETIMER operation in Free running Mode with different output modes are shown in [Figure 18.8 LETIMER - Free Running Mode Waveform on page 483](#). In this example, REP MODE in LETIMERn\_CTRL is set to FREE, CNTTOPEN also in LETIMERn\_CTRL has been set and LETIMERn\_TOP has been written to 3. As seen in the figure, LETIMERn\_TOP now decides the length of the signal periods. For the toggle mode, the period of the output signal is  $2(\text{LETIMERn\_TOP} + 1)$ , and for the pulse modes, the periods of the output signals are  $\text{LETIMERn\_TOP} + 1$ . Note that the pulse outputs are delayed by one period relative to the toggle output. The pulses come at the end of their periods.



**Figure 18.8. LETIMER - Free Running Mode Waveform**

### 18.12.2 One Shot Mode

LETIMER operation in ONESHOT Mode with different output modes are shown in [Figure 18.9 LETIMER - One Shot Mode Waveform on page 484](#). In this example, REPMode in LETIMERn\_CTRL is set to ONESHOT, CNTTOPEN also in LETIMERn\_CTRL has been set and LETIMERn\_TOP has been written to 3 and LETIMERn\_REPO has been written to 3. The resulting behavior is pretty similar to that shown in Figure 6, but in this case, the timer stops after counting to zero LETIMERn\_REPO times. By using LETIMERn\_REPO the user has full control of the number of pulses/toggles generated on the output.



Figure 18.9. LETIMER - One Shot Mode Waveform

### 18.12.3 DOUBLE Mode

LETIMER operation in DOUBLE Mode with both outputs is shown in [Figure 18.10 LETIMER - Double Mode Waveform on page 484](#). UFOA0 and UFOA1 in LETIMERn\_CTRL are configured for pulse output and the outputs are configured for low idle polarity. As seen in the figure, the number written to the repeat registers determine the number of pulses generated on each of the outputs.



Figure 18.10. LETIMER - Double Mode Waveform

#### 18.12.4 BUFFERED Mode

In BUFFERED Mode LETIMERn\_TOPBUFF and LETIMERn\_REP1 registers are used as Buffers for LETIMERn\_TOP and LETIMERn\_REPO respectively. If both LETIMERn\_TOP and LETIMERn\_REPO are 0 in buffered mode, and CNTTOPEN and BUFTOP in LETIMERn\_CTRL are set, the values of LETIMERn\_TOPBUFF and LETIMERn\_REPO1 are loaded into LETIMERn\_TOP and LETIMERn\_REPO respectively when the timer is started. If no additional writes to LETIMERn\_REPO1 are done before the timer stops, LETIMERn\_REPO1 determines the number of pulses/toggles generated on the output, and LETIMERn\_TOPBUFF determines the period lengths.

As the SYSRTC can also be used via PRS to start the LETIMER, the SYSRTC and LETIMER can thus be combined to generate specific pulse-trains at given intervals. Software can update LETIMERn\_TOPBUFF and LETIMERn\_REPO1 to change the number of pulses and pulse-period in each train, but if changes are not required, software does not have to update the registers between each pulse train.

For the example in [Figure 18.11 LETIMER - Buffered Mode Waveform on page 485](#), the initial values cause the LETIMER to generate two pulses with 3 cycle periods, or a single pulse 3 cycles wide every time the LETIMER is started. After the output has been generated, the LETIMER stops, and is ready to be triggered again.



**Figure 18.11. LETIMER - Buffered Mode Waveform**

### 18.12.5 Continuous Output Generation

In some scenarios, it might be desired to make LETIMER generate a continuous waveform. Very simple constant waveforms can be generated without the repeat counter as shown in [Figure 18.8 LETIMER - Free Running Mode Waveform on page 483](#), but to generate changing waveforms, using the repeat counter and buffer registers can prove advantageous.

For the example in [Figure 18.12 LETIMER - Continuous Operation on page 486](#), the goal is to produce a pulse train consisting of 3 sequences with the following properties:

- 3 pulses with periods of 3 cycles
- 4 pulses with periods of 2 cycles
- 2 pulses with periods of 3 cycles



**Figure 18.12. LETIMER - Continuous Operation**

The first two sequences are loaded into the LETIMER before the timer is started.

LETIMERn\_TOP is set to 2 (cycles – 1), and LETIMERn\_REPEAT0 is set to 3 for the first sequence, and the second sequence is loaded into the buffer registers, i.e. TOPBUFF is set to 1 and LETIMERn\_REPEAT1 is set to 4.

The LETIMER is set to trigger an interrupt when LETIMERn\_REPEAT0 is done by setting REPO in LETIMERn\_IEN. This interrupt is a good place to update the values of the buffers. Last but not least REPMODE in LETIMERn\_CTRL is set to buffered mode, and the timer is started.

In the interrupt routine the buffers are updated with the values for the third sequence. If this had not been done, the timer would have stopped after the second sequence.

The final result is shown in [Figure 18.12 LETIMER - Continuous Operation on page 486](#). The pulse output is grouped to show which sequence generated which output. Toggle output is also shown in the figure. Note that the toggle output is not aligned with the pulse outputs.

**Note:** Multiple LETIMER cycles are required to write a value to the LETIMER registers. The example in Figure 18.12 LETIMER - Continuous Operation on page 486 assumes that writes are done in advance so they arrive in the LETIMER as described in the figure.

Figure 18.13 LETIMERn\_CNT Not Initialized to 0 on page 487 shows an example where the LETIMER is started while LETIMERn\_CNT is nonzero. In this case the length of the first repetition is given by the value in LETIMERn\_CNT.



**Figure 18.13.** LETIMERn\_CNT Not Initialized to 0

## 18.12.6 PWM Output

There are several ways of generating PWM output with the LETIMER, but the most straight-forward way is to use the PWM output mode. This mode is enabled by setting UFOA0 or UFOA1 in LETIMERn\_CTRL to 3. In PWM mode, the output is set to idle on timer underflow, and active on LETIMERn\_COMP0/1 match, so if for instance CNTTOPEN = 1 and OPOL0 = 0 in LETIMERn\_CTRL, LETIMERn\_TOP determines the PWM period, and LETIMERn\_COMP0/1 determines the active period.

The PWM period in PWM mode is LETIMERn\_TOP + 1. There is no special handling of the case where LETIMERn\_COMP0/1 > LETIMERn\_TOP, so if LETIMERn\_COMP0/1 > LETIMERn\_TOP, the PWM output is given by the idle output value. This means that for OPOLx = 0 in LETIMERn\_CTRL, the PWM output will always be 0 for at least one clock cycle, and for OPOLx = 1 LETIMERn\_CTRL, the PWM output will always be 1 for at least one clock cycle.

To generate a PWM signal using the full PWM range, invert OPOLx when LETIMERn\_COMP0/1 is set to a value larger than LETIMERn\_TOP.

### 18.13 LETIMER Register Map

The offset register address is relative to the registers base address.

| Offset | Name                  | Type        | Description                    |
|--------|-----------------------|-------------|--------------------------------|
| 0x000  | LETIMER_IPVERSION     | R           | IP Version                     |
| 0x004  | LETIMER_EN            | RW ENABLE   | Module En                      |
| 0x008  | LETIMER_SWRST         | RW SWRST    | Software Reset Register        |
| 0x00C  | LETIMER_CTRL          | RW          | Control Register               |
| 0x010  | LETIMER_CMD           | W LFSYNC    | Command Register               |
| 0x014  | LETIMER_STATUS        | RH          | Status Register                |
| 0x018  | LETIMER_CNT           | RWH LFSYNC  | Counter Value Register         |
| 0x01C  | LETIMER_COMP0         | RW          | Compare Value Register 0       |
| 0x020  | LETIMER_COMP1         | RW          | Compare Value Register 1       |
| 0x024  | LETIMER_TOP           | RWH LFSYNC  | Counter TOP Value Register     |
| 0x028  | LETIMER_TOPBUFF       | RW          | Buffered Counter TOP Value     |
| 0x02C  | LETIMER_REP0          | RWH LFSYNC  | Repeat Counter Register 0      |
| 0x030  | LETIMER_REP1          | RWH LFSYNC  | Repeat Counter Register 1      |
| 0x034  | LETIMER_IF            | RWH INTFLAG | Interrupt Flag Register        |
| 0x038  | LETIMER_IEN           | RW          | Interrupt Enable Register      |
| 0x03C  | LETIMER_LOCK          | W           | Configuration Lock Register    |
| 0x040  | LETIMER_SYNCBUSY      | RH          | Synchronization Busy Register  |
| 0x050  | LETIMER_PRSMODE       | RW          | PRS Input Mode Select Register |
| 0x1000 | LETIMER_IPVERSION_SET | R           | IP Version                     |
| 0x1004 | LETIMER_EN_SET        | RW ENABLE   | Module En                      |
| 0x1008 | LETIMER_SWRST_SET     | RW SWRST    | Software Reset Register        |
| 0x100C | LETIMER_CTRL_SET      | RW          | Control Register               |
| 0x1010 | LETIMER_CMD_SET       | W LFSYNC    | Command Register               |
| 0x1014 | LETIMER_STATUS_SET    | RH          | Status Register                |
| 0x1018 | LETIMER_CNT_SET       | RWH LFSYNC  | Counter Value Register         |
| 0x101C | LETIMER_COMP0_SET     | RW          | Compare Value Register 0       |
| 0x1020 | LETIMER_COMP1_SET     | RW          | Compare Value Register 1       |
| 0x1024 | LETIMER_TOP_SET       | RWH LFSYNC  | Counter TOP Value Register     |
| 0x1028 | LETIMER_TOPBUFF_SET   | RW          | Buffered Counter TOP Value     |
| 0x102C | LETIMER_REP0_SET      | RWH LFSYNC  | Repeat Counter Register 0      |
| 0x1030 | LETIMER_REP1_SET      | RWH LFSYNC  | Repeat Counter Register 1      |
| 0x1034 | LETIMER_IF_SET        | RWH INTFLAG | Interrupt Flag Register        |
| 0x1038 | LETIMER_IEN_SET       | RW          | Interrupt Enable Register      |
| 0x103C | LETIMER_LOCK_SET      | W           | Configuration Lock Register    |
| 0x1040 | LETIMER_SYNCBUSY_SET  | RH          | Synchronization Busy Register  |

| Offset | Name                  | Type        | Description                    |
|--------|-----------------------|-------------|--------------------------------|
| 0x1050 | LETIMER_PRSMODE_SET   | RW          | PRS Input Mode Select Register |
| 0x2000 | LETIMER_IPVERSION_CLR | R           | IP Version                     |
| 0x2004 | LETIMER_EN_CLR        | RW ENABLE   | Module En                      |
| 0x2008 | LETIMER_SWRST_CLR     | RW SWRST    | Software Reset Register        |
| 0x200C | LETIMER_CTRL_CLR      | RW          | Control Register               |
| 0x2010 | LETIMER_CMD_CLR       | W LFSYNC    | Command Register               |
| 0x2014 | LETIMER_STATUS_CLR    | RH          | Status Register                |
| 0x2018 | LETIMER_CNT_CLR       | RWH LFSYNC  | Counter Value Register         |
| 0x201C | LETIMER_COMP0_CLR     | RW          | Compare Value Register 0       |
| 0x2020 | LETIMER_COMP1_CLR     | RW          | Compare Value Register 1       |
| 0x2024 | LETIMER_TOP_CLR       | RWH LFSYNC  | Counter TOP Value Register     |
| 0x2028 | LETIMER_TOPBUFF_CLR   | RW          | Buffered Counter TOP Value     |
| 0x202C | LETIMER_REP0_CLR      | RWH LFSYNC  | Repeat Counter Register 0      |
| 0x2030 | LETIMER_REP1_CLR      | RWH LFSYNC  | Repeat Counter Register 1      |
| 0x2034 | LETIMER_IF_CLR        | RWH INTFLAG | Interrupt Flag Register        |
| 0x2038 | LETIMER_IEN_CLR       | RW          | Interrupt Enable Register      |
| 0x203C | LETIMER_LOCK_CLR      | W           | Configuration Lock Register    |
| 0x2040 | LETIMER_SYNCBUSY_CLR  | RH          | Synchronization Busy Register  |
| 0x2050 | LETIMER_PRSMODE_CLR   | RW          | PRS Input Mode Select Register |
| 0x3000 | LETIMER_IPVERSION_TGL | R           | IP Version                     |
| 0x3004 | LETIMER_EN_TGL        | RW ENABLE   | Module En                      |
| 0x3008 | LETIMER_SWRST_TGL     | RW SWRST    | Software Reset Register        |
| 0x300C | LETIMER_CTRL_TGL      | RW          | Control Register               |
| 0x3010 | LETIMER_CMD_TGL       | W LFSYNC    | Command Register               |
| 0x3014 | LETIMER_STATUS_TGL    | RH          | Status Register                |
| 0x3018 | LETIMER_CNT_TGL       | RWH LFSYNC  | Counter Value Register         |
| 0x301C | LETIMER_COMP0_TGL     | RW          | Compare Value Register 0       |
| 0x3020 | LETIMER_COMP1_TGL     | RW          | Compare Value Register 1       |
| 0x3024 | LETIMER_TOP_TGL       | RWH LFSYNC  | Counter TOP Value Register     |
| 0x3028 | LETIMER_TOPBUFF_TGL   | RW          | Buffered Counter TOP Value     |
| 0x302C | LETIMER_REP0_TGL      | RWH LFSYNC  | Repeat Counter Register 0      |
| 0x3030 | LETIMER_REP1_TGL      | RWH LFSYNC  | Repeat Counter Register 1      |
| 0x3034 | LETIMER_IF_TGL        | RWH INTFLAG | Interrupt Flag Register        |
| 0x3038 | LETIMER_IEN_TGL       | RW          | Interrupt Enable Register      |
| 0x303C | LETIMER_LOCK_TGL      | W           | Configuration Lock Register    |
| 0x3040 | LETIMER_SYNCBUSY_TGL  | RH          | Synchronization Busy Register  |
| 0x3050 | LETIMER_PRSMODE_TGL   | RW          | PRS Input Mode Select Register |

## 18.14 LETIMER Register Description

#### **18.14.1 LETIMER\_IPVERSION - IP Version**

| Bit                                                                                                                                                           | Name      | Reset | Access | Description       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|-------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x1   | R      | <b>IP Version</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                   |

## 18.14.2 LETIMER\_EN - Module En

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                  |
|------|-----------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                            |
| 1    | DISABLING | 0x0   | R      | <b>Disablement busy status</b><br><br>When EN is cleared, DISABLING is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS, FIFOs etc.                                                                                                                      |
| 0    | EN        | 0x0   | RW     | <b>module en</b><br><br>Enable the LETIMER module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit. When EN is cleared(disablement), it halts module operation immediately, and initialize the core domain such that when the is re-enabled, it starts cleanly. |

## 18.14.3 LETIMER\_SWRST - Software Reset Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |       |        |      |           |   |   |       |     |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--|-------|--------|------|-----------|---|---|-------|-----|-----|---|
| 0x008         | 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 |  | Reset | Access | Name | RESETTING | R | W | SWRST | 0x0 | 0x0 | 0 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |       |        |      |           |   |   |       |     |     |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |       |        |      |           |   |   |       |     |     |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |  |       |        |      |           |   |   |       |     |     |   |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                    |
|------|-----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>              |
| 1    | RESETTING | 0x0   | R      | <b>Software reset busy status</b><br><br>When SWRST command is issued, resetting logic sets RESETTING status immediately, and later it is cleared when reset process finishes. |
| 0    | SWRST     | 0x0   | W      | <b>Software reset command</b><br><br>A software reset command field resets the module back to the initial condition, similar to a power on reset condition                     |

## 18.14.4 LETIMER\_CTRL - Control Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |          |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|----------|
| 0x00C         | 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 |  |          |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |          |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |          |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CNTPRESC |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | REP MODE |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DEBUGRUN |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |          |

| Bit   | Name                                                                                                              | Reset                                                                                                                                                             | Access                                         | Description                         |
|-------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------|
| 31:20 | <i>Reserved</i>                                                                                                   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |                                                |                                     |
| 19:16 | CNTPRESC                                                                                                          | 0x0                                                                                                                                                               | RW                                             | <b>Counter prescaler value</b>      |
|       | Configure counting frequency of the CNT register. - Note - its not recommended to change this setting on the fly. |                                                                                                                                                                   |                                                |                                     |
|       | Value                                                                                                             | Mode                                                                                                                                                              | Description                                    |                                     |
|       | 0                                                                                                                 | DIV1                                                                                                                                                              | CLK_CNT = (LETIMER LF CLK)/1                   |                                     |
|       | 1                                                                                                                 | DIV2                                                                                                                                                              | CLK_CNT = (LETIMER LF CLK)/2                   |                                     |
|       | 2                                                                                                                 | DIV4                                                                                                                                                              | CLK_CNT = (LETIMER LF CLK)/4                   |                                     |
|       | 3                                                                                                                 | DIV8                                                                                                                                                              | CLK_CNT = (LETIMER LF CLK)/8                   |                                     |
|       | 4                                                                                                                 | DIV16                                                                                                                                                             | CLK_CNT = (LETIMER LF CLK)/16                  |                                     |
|       | 5                                                                                                                 | DIV32                                                                                                                                                             | CLK_CNT = (LETIMER LF CLK)/32                  |                                     |
|       | 6                                                                                                                 | DIV64                                                                                                                                                             | CLK_CNT = (LETIMER LF CLK)/64                  |                                     |
|       | 7                                                                                                                 | DIV128                                                                                                                                                            | CLK_CNT = (LETIMER LF CLK)/128                 |                                     |
|       | 8                                                                                                                 | DIV256                                                                                                                                                            | CLK_CNT = (LETIMER LF CLK)/256                 |                                     |
| 15:13 | <i>Reserved</i>                                                                                                   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |                                                |                                     |
| 12    | DEBUGRUN                                                                                                          | 0x0                                                                                                                                                               | RW                                             | <b>Debug Mode Run Enable</b>        |
|       | Set to keep the LETIMER running in debug mode.                                                                    |                                                                                                                                                                   |                                                |                                     |
|       | Value                                                                                                             | Mode                                                                                                                                                              | Description                                    |                                     |
|       | 0                                                                                                                 | DISABLE                                                                                                                                                           | LETIMER is frozen in debug mode                |                                     |
|       | 1                                                                                                                 | ENABLE                                                                                                                                                            | LETIMER is running in debug mode               |                                     |
| 11:10 | <i>Reserved</i>                                                                                                   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |                                                |                                     |
| 9     | CNTTOPEN                                                                                                          | 0x0                                                                                                                                                               | RW                                             | <b>Compare Value 0 Is Top Value</b> |
|       | When set, TOP value will be used as Counter Top Value                                                             |                                                                                                                                                                   |                                                |                                     |
|       | Value                                                                                                             | Mode                                                                                                                                                              | Description                                    |                                     |
|       | 0                                                                                                                 | DISABLE                                                                                                                                                           | The top value of the LETIMER is 65535 (0xFFFF) |                                     |

| Bit | Name    | Reset   | Access | Description                                                                                                                               |
|-----|---------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|
|     | 1       | ENABLE  |        | The top value of the LETIMER is given by COMPO                                                                                            |
| 8   | BUFTOP  | 0x0     | RW     | <b>Buffered Top</b>                                                                                                                       |
|     |         |         |        | Set to load TOPBUFF into TOP when REP0 reaches 0 in BUFFERED mode, allowing a buffered top value.                                         |
|     | Value   | Mode    |        | Description                                                                                                                               |
|     | 0       | DISABLE |        | COMP0 is only written by software                                                                                                         |
|     | 1       | ENABLE  |        | COMP0 is set to COMP1 when REP0 reaches 0                                                                                                 |
| 7   | OPOL1   | 0x0     | RW     | <b>Output 1 Polarity</b>                                                                                                                  |
|     |         |         |        | Defines the idle value of output 1.                                                                                                       |
| 6   | OPOLO   | 0x0     | RW     | <b>Output 0 Polarity</b>                                                                                                                  |
|     |         |         |        | Defines the idle value of output 0.                                                                                                       |
| 5:4 | UFOA1   | 0x0     | RW     | <b>Underflow Output Action 1</b>                                                                                                          |
|     |         |         |        | Defines the action on OUT1 on a LETIMER underflow - IDLE/TOGGLE/PULSE/PWM                                                                 |
|     | Value   | Mode    |        | Description                                                                                                                               |
|     | 0       | NONE    |        | LETIMERn_OUT1 is held at its idle value as defined by OPOL1                                                                               |
|     | 1       | TOGGLE  |        | LETIMERn_OUT1 is toggled on CNT underflow                                                                                                 |
|     | 2       | PULSE   |        | LETIMERn_OUT1 is held active for one LETIMER0 clock cycle on CNT underflow. The output then returns to its idle value as defined by OPOL1 |
|     | 3       | PWM     |        | LETIMERn_OUT1 is set idle on CNT underflow, and active on compare match with COMP1                                                        |
| 3:2 | UFOA0   | 0x0     | RW     | <b>Underflow Output Action 0</b>                                                                                                          |
|     |         |         |        | Defines the action on OUT0 on a LETIMER underflow - IDLE/TOGGLE/PULSE/PWM                                                                 |
|     | Value   | Mode    |        | Description                                                                                                                               |
|     | 0       | NONE    |        | LETIMERn_OUT0 is held at its idle value as defined by OPOLO                                                                               |
|     | 1       | TOGGLE  |        | LETIMERn_OUT0 is toggled on CNT underflow                                                                                                 |
|     | 2       | PULSE   |        | LETIMERn_OUT0 is held active for one LETIMER0 clock cycle on CNT underflow. The output then returns to its idle value as defined by OPOLO |
|     | 3       | PWM     |        | LETIMERn_OUT0 is set idle on CNT underflow, and active on compare match with COMP1                                                        |
| 1:0 | REPMODE | 0x0     | RW     | <b>Repeat Mode</b>                                                                                                                        |
|     |         |         |        | Repeat Mode - FREE/ONESHOT/BUFFERED/DOUBLE                                                                                                |
|     | Value   | Mode    |        | Description                                                                                                                               |
|     | 0       | FREE    |        | When started, the LETIMER counts down until it is stopped by software                                                                     |
|     | 1       | ONESHOT |        | The counter counts REP0 times. When REP0 reaches zero, the counter stops                                                                  |

| Bit | Name | Reset    | Access | Description                                                                                                                         |
|-----|------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------|
| 2   |      | BUFFERED |        | The counter counts REP0 times. If REP1 has been written, it is loaded into REP0 when REP0 reaches zero, otherwise the counter stops |
| 3   |      | DOUBLE   |        | Both REP0 and REP1 are decremented when the LETIMER wraps around. The LETIMER counts until both REP0 and REP1 are zero              |

#### 18.14.5 LETIMER\_CMD - Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|
| 0x010  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | CTO1     | 0x0   | W(nB)  | <b>Clear Toggle Output 1</b><br><br>Set to drive toggle output 1 to its idle value                                                                                                |
| 3    | CTO0     | 0x0   | W(nB)  | <b>Clear Toggle Output 0</b><br><br>Set to drive toggle output 0 to its idle value                                                                                                |
| 2    | CLEAR    | 0x0   | W(nB)  | <b>Clear LETIMER</b><br><br>Set to clear LETIMER                                                                                                                                  |
| 1    | STOP     | 0x0   | W(nB)  | <b>Stop LETIMER</b><br><br>Set to stop LETIMER                                                                                                                                    |
| 0    | START    | 0x0   | W(nB)  | <b>Start LETIMER</b><br><br>Set to start LETIMER                                                                                                                                  |

#### **18.14.6 LETIMER\_STATUS - Status Register**

| Bit  | Name              | Reset                                        | Access | Description                                                                                                                                                                       |
|------|-------------------|----------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved          |                                              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | LETIMERLOCKSTATUS | 0x0                                          | R      | <b>LETIMER Lock Status</b>                                                                                                                                                        |
|      |                   | Indicates the current status of LETIMER Lock |        |                                                                                                                                                                                   |
|      | Value             | Mode                                         |        | Description                                                                                                                                                                       |
|      | 0                 | UNLOCKED                                     |        | LETIMER registers are unlocked                                                                                                                                                    |
|      | 1                 | LOCKED                                       |        | LETIMER registers are locked                                                                                                                                                      |
| 0    | RUNNING           | 0x0                                          | R      | <b>LETIMER Running</b>                                                                                                                                                            |
|      |                   | Set when LETIMER is running.                 |        |                                                                                                                                                                                   |

## 18.14.7 LETIMER\_CNT - Counter Value Register

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:0  | CNT      | 0x0   | RW     | <b>Counter Value</b><br><br>Use to read the current value of the LETIMER.                                                                                                         |

## 18.14.8 LETIMER\_COMP0 - Compare Value Register 0

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |       |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------|---|---|---|---|---|---|---|
| 0x01C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW    |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | COMP0 |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:0  | COMP0    | 0x0   | RW     | <b>Compare Value 0</b><br><br>Compare value for LETIMER.                                                                                                                          |

## 18.14.9 LETIMER\_COMP1 - Compare Value Register 1

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |       |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------|---|---|---|---|---|---|---|
| 0x020  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW    |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | COMP1 |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:0  | COMP1    | 0x0   | RW     | <b>Compare Value 1</b><br><br>Compare and optionally buffered top value for LETIMER.                                                                                              |

**18.14.10 LETIMER\_TOP - Counter TOP Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|---|---|---|---|---|---|
| 0x024  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TOP |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:0  | TOP      | 0x0   | RW     | <b>Counter TOP Value</b>                                                                                                                                                          |

TOP will be used as Counter TOP Value if CNTTOPEN is set to 1

**18.14.11 LETIMER\_TOPBUFF - Buffered Counter TOP Value**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x028  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TOPBUFF |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:0  | TOPBUFF  | 0x0   | RW     | <b>Buffered Counter TOP Value</b>                                                                                                                                                 |

TOPBUFF will be used as Counter TOP Value in BUFFERED Mode if CNTTOPEN and BUFFTOP is set to 1

**18.14.12 LETIMER\_REP0 - Repeat Counter Register 0**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |      |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|------|---|
| 0x02C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 |      |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW  |      |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     | REP0 |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | REP0            | 0x0   | RW     | <b>Repeat Counter 0</b><br><br>Optional repeat counter.                                                                                                                           |

**18.14.13 LETIMER\_REP1 - Repeat Counter Register 1**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |      |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|------|---|---|
| 0x030         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    | 0x0  |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW |      |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    | REP1 |   |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | REP1            | 0x0   | RW     | <b>Repeat Counter 1</b><br><br>Optional repeat counter or buffer for REP0.                                                                                                        |

## 18.14.14 LETIMER\_IF - Interrupt Flag Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |      |     |       |       |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|------|-----|-------|-------|---|---|
| 0x034  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  | 0x0  | 0x0 | 0x0   | 0x0   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   | RW   | RW  | RW    | RW    |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | REP1 | REP0 | UF  | COMP1 | COMP0 |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                       |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 4    | REP1     | 0x0   | RW     | <b>Repeat Counter 1 Interrupt Flag</b><br><br>Set when repeat counter 1 reaches zero.                                                                             |
| 3    | REP0     | 0x0   | RW     | <b>Repeat Counter 0 Interrupt Flag</b><br><br>Set when repeat counter 0 reaches zero or when the REP1 interrupt flag is loaded into the REP0 interrupt flag.      |
| 2    | UF       | 0x0   | RW     | <b>Underflow Interrupt Flag</b><br><br>Set on LETIMER underflow.                                                                                                  |
| 1    | COMP1    | 0x0   | RW     | <b>Compare Match 1 Interrupt Flag</b><br><br>Set when LETIMER reaches the value of COMP1.                                                                         |
| 0    | COMP0    | 0x0   | RW     | <b>Compare Match 0 Interrupt Flag</b><br><br>Set when LETIMER reaches the value of COMP0.                                                                         |

## 18.14.15 LETIMER\_IEN - Interrupt Enable Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |       |    |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------|----|---|
| 0x038         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   | 4  |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   | 3  |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REP1  | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | REP0  | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | UF    | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | COMP1 | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | COMP0 | RW |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                       |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 4    | REP1     | 0x0   | RW     | <b>Repeat Counter 1 Interrupt Enable</b><br>Repeat Counter 1 Interrupt Enable                                                                                     |
| 3    | REP0     | 0x0   | RW     | <b>Repeat Counter 0 Interrupt Enable</b><br>Repeat Counter 0 Interrupt Enable                                                                                     |
| 2    | UF       | 0x0   | RW     | <b>Underflow Interrupt Enable</b><br>Underflow Interrupt Enable                                                                                                   |
| 1    | COMP1    | 0x0   | RW     | <b>Compare Match 1 Interrupt Enable</b><br>Compare Match 1 Interrupt Enable                                                                                       |
| 0    | COMP0    | 0x0   | RW     | <b>Compare Match 0 Interrupt Enable</b><br>Compare Match 0 Interrupt Enable                                                                                       |

## 18.14.16 LETIMER\_LOCK - Configuration Lock Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------------|---|---|---|---|---|---|---|
| 0x03C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0            |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W              |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LETIMERLOCKKEY |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                                                                               | Name           | Reset | Access                                                  | Description                                                                                                                                                                       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                                                                                                                                                                                             | Reserved       |       |                                                         | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                                                                                                                                                                                                                              | LETIMERLOCKKEY | 0x0   | W                                                       | <b>Configuration Lock Key</b>                                                                                                                                                     |
| Write any other value than the unlock code to lock LETIMER_EN, LETIMER_SWRST, LETIMER_CTRL, LETIMER_CMD, LETIMER_CNT, LETIMER_COMP0, LETIMER_COMP1, LETIMER_TOP, LETIMER_TOPBUFF, LETIMER_REPO, LETIMER_REP1 and PRSMODE registers from editing. Write the unlock code to unlock. |                |       |                                                         |                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                   |                |       | <b>Description</b>                                      |                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                   |                |       | Value Mode Description                                  |                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                   |                |       | 52476 UNLOCK Write to unlock LETIMER lockable registers |                                                                                                                                                                                   |

## 18.14.17 LETIMER\_SYNCBUSY - Synchronization Busy Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x040         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 9  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 8  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 6  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 5  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 4  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 3  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 2  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1  |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9     | CTO1     | 0x0   | R      | <b>Sync busy for CTO1</b><br><br>Sync busy for CTO1                                                                                                                               |
| 8     | CTO0     | 0x0   | R      | <b>Sync busy for CTO0</b><br><br>Sync busy for CTO0                                                                                                                               |
| 7     | CLEAR    | 0x0   | R      | <b>Sync busy for CLEAR</b><br><br>Sync busy for CLEAR                                                                                                                             |
| 6     | STOP     | 0x0   | R      | <b>Sync busy for STOP</b><br><br>Sync busy for STOP                                                                                                                               |
| 5     | START    | 0x0   | R      | <b>Sync busy for START</b><br><br>Sync busy for START                                                                                                                             |
| 4     | REP1     | 0x0   | R      | <b>Sync busy for REP1</b><br><br>Sync busy for REP1                                                                                                                               |
| 3     | REP0     | 0x0   | R      | <b>Sync busy for REP0</b><br><br>Sync busy for REP0                                                                                                                               |
| 2     | TOP      | 0x0   | R      | <b>Sync busy for TOP</b><br><br>Sync busy for TOP                                                                                                                                 |
| 1     | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0     | CNT      | 0x0   | R      | <b>Sync busy for CNT</b><br><br>Sync busy for CNT                                                                                                                                 |

## 18.14.18 LETIMER\_PRSMODE - PRS Input Mode Select Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x050  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | PRSCLEARMODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|        | PRSSTOPMODE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|        | PRSSTARTMODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name                          | Reset                                                                                                                                                                      | Access | Description                                                                     |
|-------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------|
| 31:28 | Reserved                      | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                 |
| 27:26 | PRSCLEARMODE                  | 0x0                                                                                                                                                                        | RW     | <b>PRS Clear Mode</b>                                                           |
|       | Mode-NONE/RISING/FALLING/BOTH |                                                                                                                                                                            |        |                                                                                 |
|       | Value                         | Mode                                                                                                                                                                       |        | Description                                                                     |
|       | 0                             | NONE                                                                                                                                                                       |        | PRS cannot clear the LETIMER                                                    |
|       | 1                             | RISING                                                                                                                                                                     |        | Rising edge of selected PRS input can clear the LETIMER                         |
|       | 2                             | FALLING                                                                                                                                                                    |        | Falling edge of selected PRS input can clear the LETIMER                        |
|       | 3                             | BOTH                                                                                                                                                                       |        | Both the rising or falling edge of the selected PRS input can clear the LETIMER |
| 25:24 | Reserved                      | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                 |
| 23:22 | PRSSTOPMODE                   | 0x0                                                                                                                                                                        | RW     | <b>PRS Stop Mode</b>                                                            |
|       | Mode-NONE/RISING/FALLING/BOTH |                                                                                                                                                                            |        |                                                                                 |
|       | Value                         | Mode                                                                                                                                                                       |        | Description                                                                     |
|       | 0                             | NONE                                                                                                                                                                       |        | PRS cannot stop the LETIMER                                                     |
|       | 1                             | RISING                                                                                                                                                                     |        | Rising edge of selected PRS input can stop the LETIMER                          |
|       | 2                             | FALLING                                                                                                                                                                    |        | Falling edge of selected PRS input can stop the LETIMER                         |
|       | 3                             | BOTH                                                                                                                                                                       |        | Both the rising or falling edge of the selected PRS input can stop the LETIMER  |
| 21:20 | Reserved                      | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                 |
| 19:18 | PRSSTARTMODE                  | 0x0                                                                                                                                                                        | RW     | <b>PRS Start Mode</b>                                                           |
|       | Mode-NONE/RISING/FALLING/BOTH |                                                                                                                                                                            |        |                                                                                 |
|       | Value                         | Mode                                                                                                                                                                       |        | Description                                                                     |
|       | 0                             | NONE                                                                                                                                                                       |        | PRS cannot start the LETIMER                                                    |
|       | 1                             | RISING                                                                                                                                                                     |        | Rising edge of selected PRS input can start the LETIMER                         |

| Bit  | Name     | Reset   | Access | Description                                                                                                                                                                       |
|------|----------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 2        | FALLING |        | Falling edge of selected PRS input can start the LETIMER                                                                                                                          |
|      | 3        | BOTH    |        | Both the rising or falling edge of the selected PRS input can start the LETIMER                                                                                                   |
| 17:0 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 19. TIMER - Timer/Counter



### Quick Facts

#### What?

The TIMER (Timer/Counter) keeps track of timing and counts events, generates output waveforms, and triggers timed actions in other peripherals.

#### Why?

Most applications have activities that need to be timed accurately with as little CPU intervention and energy consumption as possible.

#### How?

The flexible 16/32-bit timer can be configured to provide PWM waveforms with optional dead-time insertion (e.g. motor control) or work as a frequency generator. The timer can also count events and control other peripherals through the PRS, which offloads the CPU and reduces energy consumption.

### 19.1 Introduction

The general purpose timer has 3 or 4 compare/capture channels for input capture and compare/Pulse-Width Modulation (PWM) output.

The TIMER module may be 16 or 32 bits wide. Some timers also include a Dead-Time Insertion module suitable for motor control applications.

Refer to the device data sheet to determine the capabilities (capture/compare channel count, width, and DTI) of each timer instance.

## 19.2 Features

- 16/32-bit auto reload up/down counter
  - Dedicated 16/32-bit reload register which serves as counter maximum
- 3 or 4 Compare/Capture channels
  - Individually configurable as either input capture or output compare/PWM
- Multiple Counter modes
  - Count up
  - Count down
  - Count up/down
  - Quadrature Decoder
    - Direction and count from external pins
- 2x Count Mode
- Counter control from PRS or external pin
  - Start
  - Stop
  - Reload and start
- Inter-Timer connection
  - Allows 32-bit counter mode
  - Start/stop synchronization between several timers
- Input Capture
  - Period measurement
  - Pulse width measurement
  - Two capture registers for each capture channel
    - Capture on either positive or negative edge
    - Capture on both edges
    - Optional digital noise filtering on capture inputs
- Output Compare
  - Compare output toggle/pulse on compare match
  - Immediate update of compare registers
- PWM
  - Up-count PWM
  - Up/down-count PWM
  - Predictable initial PWM output state (configured by SW)
  - Buffered compare register to ensure glitch-free update of compare values
  - Output re-timing to mitigate RF interference
- Clock sources
  - HFPERCLK<sub>TIMERn</sub>
    - 10-bit Prescaler
  - External pin
  - Peripheral Reflex System
- Debug mode
  - Configurable to either run or stop when processor is stopped (halt/breakpoint)
- Interrupts, PRS output and/or DMA request on:
  - Underflow
  - Overflow
  - Compare/Capture event

- Dead-Time Insertion Unit

- Complementary PWM outputs with programmable dead-time
  - Dead-time is specified independently for rising and falling edge
    - 10-bit prescaler
    - 6-bit time value
  - Outputs have configurable polarity
  - Outputs can be set inactive individually by software.
- Configurable action on fault
  - Set outputs inactive
  - Clear output
  - Tristate output
- Individual fault sources
  - One or two PRS signals
  - Debugger
    - Support for automatic restart
  - Core lockup
  - EM2/EM3 entry
- Configuration lock

### 19.3 Functional Description

An overview of the TIMER module is shown in [Figure 19.1 TIMER Block Overview on page 507](#) and it consists of a 16/32 bit up/down counter with 3 compare/capture channels connected to pins  $\text{TIMRn\_CC}0$ ,  $\text{TIMRn\_CC}1$ , and  $\text{TIMRn\_CC}2$ .



**Figure 19.1. TIMER Block Overview**

#### 19.3.1 Register Access

The timer module interface consists of multiple register types. Registers of type "RW CONFIG" should only be written when the module is disabled ( $\text{TIMERn\_EN\_EN} = 0$ ). Registers of type "W SYNC", "R SYNC" or "RW SYNC" should only be read or written when the module is enabled ( $\text{TIMERn\_EN\_EN} = 1$ ). A typical setup sequence for a TIMER module is as follows:

- With the TIMER disabled ( $\text{TIMERn\_EN\_EN} = 0$ ), program any CONFIG registers required for the application.
- Enable the TIMER by setting EN in  $\text{TIMERn\_EN}$  to 1.
- Program any non-CONFIG registers required for the application.
- The TIMER is then ready for use.

### 19.3.2 Counter Modes

The timer consists of a counter that can be configured to the following modes, using the MODE field in TIMERn\_CFG:

- Up-count: Counter counts up until it reaches the value in TIMERn\_TOP, where it is reset to 0 before counting up again.
- Down-count: The counter starts at the value in TIMERn\_TOP and counts down. When it reaches 0, it is reloaded with the value in TIMERn\_TOP.
- Up/Down-count: The counter starts at 0 and counts up. When it reaches the value in TIMERn\_TOP, it counts down until it reaches 0 and starts counting up again.
- Quadrature Decoder: Two input channels where one determines the count direction, while the other pin triggers a clock event.

In addition to the TIMER modes listed above, the TIMER also supports a 2x count mode. In this mode the counter increments/decrements by 2 on each clock edge. The 2x count mode can be used to double the PWM frequency when the compare/capture channel is put into PWM mode. The 2x count mode is enabled by setting the X2CNT bitfield in the TIMERn\_CTRL register.

The counter value can be read or written by software any time the module is enabled by accessing the CNT field in TIMERn\_CNT.

#### 19.3.2.1 Events

The main counter can generate overflow and underflow events during operation.

Overflow (TIMERn\_IF\_OF) is set when the counter value shifts from TIMERn\_TOP to the next value when counting up. In up-count mode and quadrature decoder mode the next value is 0. In up/down-count mode, the next value is TIMERn\_TOP-1.

Underflow (TIMERn\_IF\_UF) is set when the counter value shifts from 0 to the next value when counting down. In down-count mode and quadrature decoder mode, the next value is TIMERn\_TOP. In up/down-count mode the next value is 1.

An update event occurs on overflow in up-count mode and on underflow in down-count or up/down count mode. Additionally, an update event also occurs on overflow and underflow in quadrature decoder . This event is used to time updates of buffered values.

### 19.3.2.2 Operation

Figure 19.2 TIMER Hardware Timer/Counter Control on page 509 shows the hardware timer/counter control. Software can start or stop the counter by setting the START or STOP bits in `TIMERn_CMD`. The counter value (CNT in `TIMERn_CNT`) can always be written by software to any 16/32-bit value.

It is also possible to control the counter through either an external pin or PRS input. This is done through the input logic for the compare/capture Channel 0. The timer/counter allows individual actions (start, stop, reload) to be taken for rising and falling input edges. This is configured in the RISEA and FALLA fields in `TIMERn_CTRL`. The reload value is 0 in up-count and up/down-count mode and TOP in down-count mode.

The RUNNING bit in `TIMERn_STATUS` indicates if the timer is running or not. If the SYNC bit in `TIMERn_CFG` is set, the timer is started/stopped/reloaded (external pin or PRS) when any of the other timers are started/stopped/reloaded.

The DIR bit in `TIMERn_STATUS` indicates the counting direction of the timer at any given time. The counter value can be read or written by software through the CNT field in `TIMERn_CNT`. In Up/Down-Count mode the count direction will be set to up if the CNT value is written by software.



Figure 19.2. TIMER Hardware Timer/Counter Control

### 19.3.2.3 Clock Source

The counter can be clocked from several sources, which are all synchronized with the incoming peripheral clock for the timer. See Figure 19.3 TIMER Clock Selection on page 509.



Figure 19.3. TIMER Clock Selection

#### 19.3.2.4 Peripheral Clock

The peripheral clock for the timer ( $\text{HFPERCLK}_{\text{TIMERn}}$ ) clocks the logic for the timer block, even when it is not the selected clock source.

All TIMER instances in this device family use EM01GRPACLK selected in CMU\_EM01GRPACLKCTRL\_CLKSEL as their peripheral clock source ( $\text{HFPERCLK}_{\text{TIMERn}}$ ).

The peripheral clock to each timer can be used as a source with a configurable 10-bit prescaler. The PRESC bitfield in  $\text{TIMERn\_CFG}$  sets the prescaler value, and the incoming peripheral clock will be divided by a factor of  $(\text{PRESC}+1)$ . However, if 2x count mode is enabled and the compare/capture channels are configured for PWM mode, the CC output is updated on both clock edges, so prescaling the peripheral clock will produce an incorrect result. The internal prescale counter is stopped and reset when the timer is stopped.

#### 19.3.2.5 Compare/Capture Channel 1 Input

The timer can also be clocked by positive and/or negative edges on the compare/capture channel 1 input. This input can either come from the  $\text{TMn\_CC1}$  pin or one of the PRS channels. The input signal must not have a higher frequency than  $f_{\text{HFPERCLK\_TIMERn}}/3$  when running from a pin input or a PRS input with FILT enabled in  $\text{TIMERn\_CCx\_CFG}$ . When running from PRS without FILT, the frequency can be as high as  $f_{\text{HFPERCLK\_TIMERn}}$ . Note that when clocking the timer from the same pulse that triggers a start (through RISEA/FALLA in  $\text{TIMERn\_CTRL}$ ), the starting pulse will not update the counter value.

#### 19.3.2.6 Underflow/Overflow From Neighboring Timer

All timers are linked together (see [Figure 19.4 TIMER Connections on page 510](#)), allowing timers to count on overflow/underflow from the lower numbered neighbouring timers to form a larger timer. Note that all timers must be set to count the same direction and less significant timer(s) can only be set to count up or down.



**Figure 19.4. TIMER Connections**

#### 19.3.2.7 One-Shot Mode

By default, the counter counts continuously until it is stopped. If the OSMEN bit is set in the  $\text{TIMERn\_CFG}$  register, however, the counter is disabled by hardware on the first *update event* (see [19.3.2.1 Events](#)). Note that when the counter is running with CC1 as clock source and OSMEN is set, a CC1 capture event will not take place on the *update event* (CC1 rising edge) that stops the timer.

### 19.3.2.8 Top Value Buffer

The TIMERn\_TOP register can be altered either by writing it directly or by writing to the TIMER\_TOPB (buffer) register. When writing to the buffer register the TIMERn\_TOPB register will be written to TIMERn\_TOP on the next *update event*. Buffering ensures that the TOP value is not set below the actual count value. The TOPBV flag in TIMERn\_STATUS indicates whether the TIMERn\_TOPB register contains data that has not yet been written to the TIMERn\_TOP register (see [Figure 19.5 TIMER TOP Value Update Functionality on page 511](#)).

**Note:** When writing to TIMERn\_TOP register directly, the TIMERn\_TOPB register value will be invalidated and the TOPBV flag will be cleared. This prevents TIMERn\_TOP register from being immediately updated by an existing valid TIMERn\_TOPB value during the next *update event*.



**Figure 19.5. TIMER TOP Value Update Functionality**

### 19.3.2.9 Quadrature Decoder

Quadrature decoding mode is used to track motion and determine both rotation direction and position. The quadrature decoder uses two input channels that are 90 degrees out of phase (see [Figure 19.6 TIMER Quadrature Encoded Inputs on page 512](#)).



**Figure 19.6. TIMER Quadrature Encoded Inputs**

In the timer these inputs are tapped from the compare/capture channel 0 (Channel A) and 1 (Channel B) inputs before edge detection. The timer/counter then increments or decrements the counter, based on the phase relation between the two inputs. The DIRCHG flag in `TIMERn_IF` is set if the count direction changes in quadrature decoder mode. The quadrature decoder supports two channels, but if a third channel (Z-terminal) is available, this can be connected to an external interrupt and trigger a counter reset from the interrupt service routine. By connecting a periodic signal from another timer as input capture on compare/capture Channel 2, it is also possible to calculate speed and acceleration.

**Note:** In quadrature decoder mode, overflow and underflow triggers an *update event*.



**Figure 19.7. TIMER Quadrature Decoder Configuration**

The quadrature decoder can be set in either X2 or X4 mode, which is configured in the QDM bit in TIMERn\_CFG. See [Figure 19.7 TIMER Quadrature Decoder Configuration on page 512](#)

### 19.3.2.10 X2 Decoding Mode

In X2 Decoding mode, the counter increments or decrements on every edge of Channel A, see [Table 19.1 TIMER Counter Response in X2 Decoding Mode on page 513](#) and [Figure 19.8 TIMER X2 Decoding Mode on page 513](#).

**Table 19.1. TIMER Counter Response in X2 Decoding Mode**

| Channel B | Channel A |           |
|-----------|-----------|-----------|
|           | Rising    | Falling   |
| 0         | Increment | Decrement |
| 1         | Decrement | Increment |



**Figure 19.8. TIMER X2 Decoding Mode**

### 19.3.2.11 X4 Decoding Mode

In X4 Decoding mode, the counter increments or decrements on every edge of Channel A and Channel B, see [Figure 19.9 TIMER X4 Decoding Mode on page 513](#) and [Table 19.2 TIMER Counter Response in X4 Decoding Mode on page 513](#).

**Table 19.2. TIMER Counter Response in X4 Decoding Mode**

| Opposite Channel | Channel A |           | Channel B |           |
|------------------|-----------|-----------|-----------|-----------|
|                  | Rising    | Falling   | Rising    | Falling   |
| Channel A = 0    |           |           | Decrement | Increment |
| Channel A = 1    |           |           | Increment | Decrement |
| Channel B = 0    | Increment | Decrement |           |           |
| Channel B = 1    | Decrement | Increment |           |           |



**Figure 19.9. TIMER X4 Decoding Mode**

### 19.3.2.12 Rotational Position

To calculate a position Figure 19.10 TIMER Rotational Position Equation on page 514 can be used.

$$\text{pos}^\circ = (\text{CNT}/X \times N) \times 360^\circ$$

**Figure 19.10. TIMER Rotational Position Equation**

where X = Encoding type and N = Number of pulses per revolution.

### 19.3.3 Compare/Capture Channels

The timer contains compare/capture channels, which can be independently configured in the following modes:

1. Input Capture
2. Output Compare
3. PWM

#### 19.3.3.1 Input Pin Logic

Each compare/capture channel can be configured as an input source for the Capture Unit or as external clock source for the timer (see Figure 19.11 TIMER Input Pin Logic on page 514). Compare/capture channels 0 and 1 are the inputs for the quadrature decoder. The input channel can be filtered before it is used, which requires the input to remain stable for up to 5 cycles in a row before the input is propagated to the output.



**Figure 19.11. TIMER Input Pin Logic**

The capture input to the timer may be selected from the dedicated CCx signal for the channel, or a PRS signal. INSEL in `TIMERn_CCx_CFG` determines the input to the channel. When set to PIN, the selected CCx pin will be used. When INSEL is set to PRSSYNC, a synchronous PRS channel is selected as the source. The synchronous PRS channel is determined by the SPRSSEL field in the `PRS_TIMERn_CCx` register. Setting INSEL to PRSASYNCLEVEL or PRSASYNCPULSE selects an asynchronous PRS channel as the source. The asynchronous PRS channel is determined by the PRSSEL field in the `PRS_TIMERn_CCx` register.

The PIN and PRSASYNCLEVEL selections are qualified by a 2-clock input sampler. To recognize and capture the incoming signal, it must be at the new level for at least 2  $\text{HFPERCLK}_{\text{TIMER}_n}$  clock cycles. An additional 5  $\text{HFPERCLK}_{\text{TIMER}_n}$  cycles of filtering can be applied to the signal by enabling the FILT bit in `TIMERn_CCx_CFG`.

The PRSASYNCPULSE selection can be used to capture higher-speed pulses on an asynchronous PRS input. The input logic for this selection does not qualify the level of the incoming signal. Instead, it will recognize positive or negative edges directly. While the pulse time can be shorter than 1  $\text{HFPERCLK}_{\text{TIMER}_n}$ , this mode requires at least 3  $\text{HFPERCLK}_{\text{TIMER}_n}$  clocks between adjacent events. The FILT option is not used in this mode.

Synchronous PRS signals are inherently synchronized to the module clock, and the 2-clock input sampler is not used. However, it is possible to use FILT to enable the 5  $\text{HFPERCLK}_{\text{TIMER}_n}$  filter when using the PRSSYNC option.

#### 19.3.3.2 Compare/Capture Registers

The compare/capture channel registers are prefixed with `TIMERn_CCx_`, where the x stands for the channel number. Since the compare/capture channels serve three functions (input capture, compare, PWM), different registers are used, depending on the mode the channel is set in.

### 19.3.3.3 Input Capture

In input capture, the counter value (TIMERn\_CNT) can be captured in the Input Capture Register (TIMERn\_CCx\_ICF) (see [Figure 19.12 TIMER Input Capture on page 515](#)). The CCPOL bits in TIMERn\_STATUS indicate the polarity of the edge that triggered the capture in TIMERn\_CCx\_ICF.



**Figure 19.12. TIMER Input Capture**

Input captures are buffered into a 2-entry FIFO, allowing 2 subsequent capture events to take place before a read-out is required. Reading TIMERn\_CCx\_ICF from software or DMA pops the oldest unread value from the FIFO. If TIMERn\_CCx\_ICF is read when the FIFO is empty (ICFEMPTY in TIMERn\_STATUS = 1), the FIFO underflow flag for the channel (ICFUU in TIMERn\_IF) will be set. The Input Capture Overflow Register (TIMERn\_CCx\_ICOF) always contains the newest value in the FIFO. If a new capture is triggered while the FIFO is full, the value in TIMERn\_CCx\_ICOF will be over-written with the latest value and the FIFO overflow flag (ICFOF in TIMERn\_IF) for the channel will be set. Reading TIMERn\_CCx\_ICOF does not alter the FIFO contents.

The input capture FIFO also has a programmable watermark level that can be configured to generate interrupts or trigger DMA requests when a certain number of empty spots are left in the FIFO. The ICFWLFULL flag in TIMERn\_IF will be set when the number of empty spots left in the FIFO is less than or equal to the watermark level programmed in TIMERn\_CCx\_CFG\_ICFWL. At a minimum, a TIMER module will have two FIFO entries, but may have more on future devices.

The ICFEMPTY flag in TIMERn\_STATUS indicates when the capture buffer is empty. When this bit reads '0', there is a valid unread capture in the FIFO.

**Note:** In input capture mode, the timer will only trigger interrupts when it is running.

#### 19.3.3.4 Period/Pulse-Width Capture

Period and/or pulse-width capture can only be possible with Channel 0 (CC0), because this is the only channel that can start and stop the timer. This can be done by setting the RISEA field in TIMERn\_CTRL to Clear&Start, and selecting the desired input from either external pin or PRS, see [Figure 19.13 TIMER Period and/or Pulse Width Capture on page 516](#). For period capture, the compare/capture channel should then be set to input capture on a rising edge of the same input signal. To capture the width of a high pulse, the compare/capture channel should be set to capture on a falling edge of the input signal. To measure the low pulse-width of a signal, opposite polarities should be chosen.



**Figure 19.13. TIMER Period and/or Pulse Width Capture**

### 19.3.3.5 Compare

Each compare/capture channel contains a comparator which outputs a compare match if the contents of TIMERn\_CCx\_OC matches the counter value, see [Figure 19.14 TIMER Block Diagram Showing Comparison Functionality on page 517](#). In compare mode, each compare channel can be configured to either set, clear or toggle the output on an event (compare match, overflow or underflow). The output from each channel is represented as an alternative function on the port it is connected to, which needs to be enabled for the CC outputs to propagate to the pins.



**Figure 19.14. TIMER Block Diagram Showing Comparison Functionality**

The compare output is delayed by one cycle to allow for full 0% to 100% PWM generation. If occurring in the same cycle, match action will have priority over overflow or underflow action.

The input selected (through PRSSEL in PRS\_CONSUMER\_TIMERn\_CCx, INSEL and FILT in TIMERn\_CCx\_CFG) for the CC channel will also be sampled on compare match and the result is found in the CCPOL bits in TIMERn\_STATUS. It is also possible to configure the CCPOL to always track the inputs by setting ATI in TIMERn\_CFG.

**Note:** When using synchronous PRS sources, it is recommended to configure the PRS consumer registers prior to selecting PRS triggering to avoid any false triggers.

The COIST bit in TIMERn\_CCx\_CFG is the initial state of the compare/PWM output. The COIST bit can also be used as an initial value to the compare outputs on a reload-start when RSSCOIST is set in TIMERn\_CFG. Also the resulting output can be inverted by setting OUTINV in TIMERn\_CCx\_CTRL. It is recommended to turn off the CC channel before configuring the output state to avoid any unwanted pulses on the output. The CC channel can be turned off by setting MODE to OFF in TIMER\_CCx\_CFG. The following figure shows the output logic for the TIMER module.



Figure 19.15. TIMER Output Logic

### 19.3.3.6 Compare Mode Registers

When running in output compare or PWM mode, the value in `TIMERn_CCx_OC` will be compared against the count value. In Compare mode the output can be configured to toggle, clear or set on compare match, overflow, and underflow through the CMOA, COFOA and CUFOA fields in `TIMERn_CCx_CTRL`. `TIMERn_CCx_OC` can be accessed directly or through the buffer register `TIMERn_CCx_OCB`, see [Figure 19.16 TIMER Output Compare/PWM Buffer Functionality Detail on page 518](#). When writing to the buffer register, the value in `TIMERn_CCx_OCB` will be written to `TIMERn_CCx_OC` on the next *update event*. This functionality ensures glitch free PWM outputs. The OCBV flag in `TIMERn_STATUS` indicates whether the `TIMERn_CCx_OCB` register contains data that has not yet been written to the `TIMERn_CCx_OC` register. Note that when writing 0 to `TIMERn_CCx_OCB` in up-down count mode the OC value is updated when the timer counts from 0 to 1. Thus, the compare match for the next period will not happen until the timer reaches 0 again on the way down.



Figure 19.16. TIMER Output Compare/PWM Buffer Functionality Detail

### 19.3.3.7 Frequency Generation (FRG)

Frequency generation (see [Figure 19.17 TIMER Up-count Frequency Generation on page 519](#)) can be achieved in compare mode by:

- Setting the counter in up-count mode
- Enabling buffering of the TOP value.
- Setting the CC channels overflow action to toggle



**Figure 19.17. TIMER Up-count Frequency Generation**

The output frequency is given by [Figure 19.18 TIMER Up-count Frequency Generation Equation on page 519](#)

$$f_{FRG} = f_{HFPERCLK\_TIMERn} / [2 \times (\text{PRESC} + 1) \times (\text{TOP} + 1)]$$

**Figure 19.18. TIMER Up-count Frequency Generation Equation**

The figure below provides cycle accurate timing and event generation information for frequency generation.



**Figure 19.19. TIMER Up-count Frequency Generation Detail**

### 19.3.3.8 Pulse-Width Modulation (PWM)

In PWM mode, `TIMERn_CCx_OC` is buffered to avoid glitches in the output. The settings in the Compare Output Action configuration bits are ignored in PWM mode and PWM generation is only supported for up-count and up/down-count mode.

### 19.3.3.9 Up-count (Single-slope) PWM

If the counter is set to up-count and the compare/capture channel is put in PWM mode, single slope PWM output will be generated (see [Figure 19.20 TIMER Up-count PWM Generation on page 520](#)). In up-count mode the PWM period is TOP+1 cycles and the PWM output will be high for a number of cycles equal to `TIMERn_CCx_OC`. This means that a constant high output is achieved by setting `TIMERn_CCx_OC` to TOP+1 or higher. The PWM resolution (in bits) is then given by [Figure 19.21 TIMER Up-count PWM Resolution Equation on page 520](#).



**Figure 19.20. TIMER Up-count PWM Generation**

$$R_{\text{PWM}_{\text{up}}} = \log(\text{TOP}+1)/\log(2)$$

**Figure 19.21. TIMER Up-count PWM Resolution Equation**

The PWM frequency is given by [Figure 19.22 TIMER Up-count PWM Frequency Equation on page 520](#):

$$f_{\text{PWM}_{\text{up}}} = f_{\text{HFPERCLK\_TIMER}_n} / [(\text{PRESC} + 1) \times (\text{TOP} + 1)]$$

**Figure 19.22. TIMER Up-count PWM Frequency Equation**

The high duty cycle is given by [Figure 19.23 TIMER Up-count Duty Cycle Equation on page 520](#)

$$DS_{\text{up}} = OCx/(\text{TOP}+1)$$

**Figure 19.23. TIMER Up-count Duty Cycle Equation**

The figure below provides cycle accurate timing and event generation information for up-count mode.



**Figure 19.24. TIMER Up-count PWM Generation Detail**

**19.3.3.10 2x Count Mode (Up-count)**

When the timer is set in 2x mode, the TIMER will count up by two for every (prescaled) clock. This will in effect make any odd Top value be rounded down to the closest even number. Similarly, any odd OC value will generate a match on the closest lower even value as shown in [Figure 19.25 TIMER CC Out in 2x Mode on page 521](#)

**Figure 19.25. TIMER CC Out in 2x Mode**

The PWM resolution is given by [Figure 19.26 TIMER 2x PWM Resolution Equation on page 521](#).

$$R_{\text{PWM}_{2\text{xmode}}} = \log(\text{TOP}/2+1)/\log(2)$$

**Figure 19.26. TIMER 2x PWM Resolution Equation**

The PWM frequency is given by [Figure 19.27 TIMER 2x Mode PWM Frequency Equation \(Up-count\) on page 521](#):

$$f_{\text{PWM}_{2\text{xmode}}} = f_{\text{HFPERCLK\_TIMER}_n} / [(\text{PRESC} + 1) \times (\text{floor}(\text{TOP}/2)+1)]$$

**Figure 19.27. TIMER 2x Mode PWM Frequency Equation (Up-count)**

The high duty cycle is given by [Figure 19.28 TIMER 2x Mode Duty Cycle Equation on page 521](#)

$$DS_{2\text{xmode}} = OC_x / ((\text{floor}(\text{TOP}/2)+1)*2)$$

**Figure 19.28. TIMER 2x Mode Duty Cycle Equation**

### 19.3.3.11 Up/Down-count (Dual-slope) PWM

If the counter is set to up-down count and the compare/capture channel is put in PWM mode, dual slope PWM output will be generated by [Figure 19.29 TIMER Up/Down-count PWM Generation on page 522](#). The resolution (in bits) is given by [Figure 19.30 TIMER Up/Down-count PWM Resolution Equation on page 522](#).



**Figure 19.29. TIMER Up/Down-count PWM Generation**

$$R_{PWM_{up/down}} = \log(TOP+1)/\log(2)$$

**Figure 19.30. TIMER Up/Down-count PWM Resolution Equation**

The PWM frequency is given by [Figure 19.31 TIMER Up/Down-count PWM Frequency Equation on page 522](#):

$$f_{PWM_{up/down}} = f_{HPPERCLK\_TIMERn} / (2 \times (PRESC + 1) \times TOP)$$

**Figure 19.31. TIMER Up/Down-count PWM Frequency Equation**

The high duty cycle is given by [Figure 19.32 TIMER Up/Down-count Duty Cycle Equation on page 522](#)

$$DS_{up/down} = OCx/TOP$$

**Figure 19.32. TIMER Up/Down-count Duty Cycle Equation**

The figure below provides cycle accurate timing and event generation information for up-count mode.



**Figure 19.33. TIMER Up/Down-count PWM Generation**

**19.3.3.12 2x Count Mode (Up/Down-count)**

When the timer is set in 2x mode, the TIMER will count up/down by two. This will in effect make any odd Top value be rounded down to the closest even number. Similarly, any odd OC value will generate a match on the closest lower even value as shown in [Figure 19.34 TIMER CC Out in 2x mode on page 523](#)

**Figure 19.34. TIMER CC Out in 2x mode**

[Figure 19.35 TIMER 2x PWM Resolution Equation on page 523](#).

$$R_{\text{PWM}_{2\text{xmode}}} = \log(\text{TOP}/2+1)/\log(2)$$

**Figure 19.35. TIMER 2x PWM Resolution Equation**

The PWM frequency is given by [Figure 19.36 TIMER 2x Mode PWM Frequency Equation \(Up/Down-count\) on page 523](#):

$$f_{\text{PWM}_{2\text{xmode}}} = f_{\text{HFPERCLK\_TIMERn}} / (2 \times (\text{PRESC} + 1) \times (\text{floor}(\text{TOP}/2)))$$

**Figure 19.36. TIMER 2x Mode PWM Frequency Equation (Up/Down-count)**

The high duty cycle is given by two equations based on the OCx values. [Figure 19.37 TIMER 2x Mode Duty Cycle Equation for OCx = 1 or OCx = Even on page 523](#) and [Figure 19.38 TIMER 2x Mode Duty Cycle Equation for all Other OCx = Odd Values on page 523](#)

$$DS_{2\text{xmode}} = (\text{OCx}^*2)/(\text{floor}(\text{TOP}/2)^*4)$$

**Figure 19.37. TIMER 2x Mode Duty Cycle Equation for OCx = 1 or OCx = Even**

$$DS_{2\text{xmode}} = (\text{OCx}^*2 - \text{OCx})/(\text{floor}(\text{TOP}/2)^*4)$$

**Figure 19.38. TIMER 2x Mode Duty Cycle Equation for all Other OCx = Odd Values****19.3.3.13 Re-Timing PWM Outputs**

PWM outputs are normally synchronous to the TIMER peripheral clock. However for radio applications, it can be desirable to synchronize PWM edges to radio clocks to reduce the interference with RF signalling.

Re-timing is enabled by setting the RETIMEEN bit in TIMERn\_CFG to 1. When RETIMEEN is enabled, PWM X2CNT mode should not be enabled. Doing so may result in unpredictable PWM behavior.

Direct re-timing is supported at peripheral clock frequencies up to 50 MHz. For higher peripheral clock frequencies, set the RETIMESEL bit in TIMERn\_CFG to 1. This allows PWM outputs to be re-timed at frequencies up to 80 MHz, but will introduce up to 1 HFPERCLKTIMERn cycle of jitter between the PWM outputs.

#### 19.3.3.14 Timer Configuration Lock

To prevent software errors from making changes to the timer configuration, a configuration lock is available. Writing any value but 0xCE80 to LOCKKEY in TIMERn\_LOCK will lock writes to TIMERn\_CTRL, TIMERn\_CFG, TIMERn\_CMD, TIMERn\_TOP, TIMERn\_TOPB, TIMERn\_CNT, TIMERn\_CCx\_CTRL, TIMERn\_CCx\_CFG, TIMERn\_CCx\_OC, and TIMERn\_CCx\_OCB. To unlock the registers, write 0xCE80 to LOCKKEY in TIMERn\_LOCK. The value of TIMERLOCKSTATUS in TIMERn\_STATUS is 1 when the lock is active, and 0 when the registers are unlocked.

#### 19.3.4 Dead-Time Insertion Unit

Some timer modules include a Dead-Time Insertion unit suitable for motor control applications. Refer to the device data sheet to check which timer instances have this feature. The example settings in this section are for TIMER0, but identical settings can be used for other timers with DTI as well. The Dead-Time Insertion Unit aims to make control of brushless DC (BLDC) motors safer and more efficient by introducing complementary PWM outputs with dead-time insertion and fault handling, see [Figure 19.39 TIMER Dead-Time Insertion Unit Overview on page 525](#).



**Figure 19.39. TIMER Dead-Time Insertion Unit Overview**

When used for motor control, the PWM outputs TIM0\_CC0, TIM0\_CC1 and TIM0\_CC2 are often connected to the high-side transistors of a triple half-bridge setup (UH, VH and WH), and the complementary outputs connected to the respective low-side transistors (UL, VL, WL shown in [Figure 19.40 TIMER Triple Half-Bridge on page 525](#)). Transistors used in such a bridge often do not open/close instantaneously, and using the exact complementary inputs for the high and low side of a half-bridge may result in situations where both gates are open. This can give unnecessary current-draw and short circuit the power supply. The DTI unit provides dead-time insertion to deal with this problem.



**Figure 19.40. TIMER Triple Half-Bridge**

For each of the 3 compare-match outputs of TIMER0, an additional complementary output is provided by the DTI unit. These outputs, named TIM0\_CDTI0, TIM0\_CDTI1 and TIM0\_CDTI2 are provided to make control of e.g. 3-channel BLDC or permanent magnet AC (PMAC) motors possible using only a single timer, see [Figure 19.41 TIMER Overview of Dead-Time Insertion Block for a Single PWM Channel on page 526](#).



**Figure 19.41. TIMER Overview of Dead-Time Insertion Block for a Single PWM Channel**

The DTI unit is enabled by setting DTEN in TIMER0\_DTCFG. In addition to providing the complementary outputs, the DTI unit then also overrides the compare match outputs from the timer.

The DTI unit gives the rising edges of the PWM outputs and the rising edges of the complementary PWM outputs a configurable time delay. By doing this, the DTI unit introduces a dead-time where both the primary and complementary outputs in a pair are inactive as seen in [Figure 19.42 TIMER Polarity of Both Signals are Set as Active-High on page 526](#).



**Figure 19.42. TIMER Polarity of Both Signals are Set as Active-High**

Dead-time is specified individually for the rising and falling edge of the original PWM. These values are shared across all the three PWM channels of the DTI unit. A single prescaler value is provided for the DTI unit, meaning that both the rising and falling edge dead-times share prescaler value. The prescaler divides the HFPERCLK<sub>TIMER0</sub> by a configurable factor between 1 and 1024, which is set in the DTPRESC field in TIMER0\_DTTIMECFG. The rising and falling edge dead-times are configured in DTRISET and DTFALLT in TIMER0\_DTTIMECFG to any number between 1-64 HFPERCLK<sub>TIMER0</sub> cycles.

The DTAR and DTFATS bits in TIMER0\_DTCFG control the DTI output behavior when the timer stops. By default the DTI block stops when the timer is stopped. Setting the DTAR bit will cause the DTI output on channel 0 to continue when the timer is stopped. DTAR effects only channel 0. See [19.3.4.2 PRS Channel as a Source](#) for an example of when this can be used. While in this mode the undivided HFPERCLK<sub>TIMER0</sub> (DTPRESC=0) is always used regardless of the programmed DTPRESC value in TIMER0\_DTTIMECFG. This means that rise and fall dead times are calculated assuming DTPRESC = 0.

When the timer stops, DTI outputs are frozen by default, preserving their last state. To allow the outputs to go to a safe state, program the DTFA field of the TIMER0\_DTCFG register to the safe values and set the DTFATS bitfield in the TIMER0\_DTCFG register. Note that when DTAR is also set, DTAR has priority over DTFATS for DTI channel 0 output.

The following table shows the DTI output when the timer is halted.

**Table 19.3. DTI Output When Timer Halted**

| DTAR | DTFATS | State   |
|------|--------|---------|
| 0    | 0      | frozen  |
| 0    | 1      | safe    |
| 1    | 0      | running |
| 1    | 1      | running |

**19.3.4.1 Output Polarity**

The value of the primary and complementary outputs in a pair will never be set active at the same time by the DTI unit. The polarity of the outputs can be changed if this is required by the application. The active values of the primary and complementary outputs are set by the DTIPOL and DTCINV bits in the TIMER0\_DTCTRL register. The DTIPOL bit of this register specifies the base polarity. If DTIPOL = 0, then the outputs are active-high, and if DTIPOL = 1 they are active-low. The relative phase of the primary and complementary outputs is not changed by DTIPOL, as the polarity of both outputs is changed, see [Figure 19.43 TIMER Output Polarities on page 527](#).

In some applications, it may be required that the primary outputs are active-high, while the complementary outputs are active-low. This can be accomplished by manipulating the DTCINV bit of the TIMER0\_DTCTRL register, which inverts the polarity of the complementary outputs relative to the primary outputs. As an example, DTIPOL = 0 and DTCINV = 0 results in outputs with opposite phase and active-high states. Similarly, DTIPOL = 1 and DTCINV = 1 results in outputs with equal phase and the primary output will be active-high while the complementary will be active-low.

**Figure 19.43. TIMER Output Polarities**

Output generation on the individual DTI outputs can be disabled by configuring TIMER0\_DTOGEN. When output generation on an output is disabled that output will go to and stay in its inactive state.

#### 19.3.4.2 PRS Channel as a Source

A PRS channel can be used as input to the DTI module instead of the PWM output from the timer for DTI channel 0. Setting DTPRSEN in TIMER0\_DTCFG will override the source of the first DTI channel, driving TIM0\_CC0 and TIM0\_CDTI0, with the value on the PRS channel. The rest of the DTI channels will continue to be driven by the PWM output from the timer. The input PRS channel is chosen within the PRS module with PRSSEL in the PRS\_CONSUMER\_TIMERn\_DTI register. Note that the timer must be running even when PRS is used as the DTI source. However, if it is required to keep the DTI channel 0 running even when the timer is stopped, set DTAR in TIMER0\_DTCFG. When this bit is set, it uses DTPRESC=0 regardless of the value programmed in DTPRESC in TIMER0\_DTTIMECFG.

**Note:** When using synchronous PRS sources, it is recommended to configure the PRS consumer registers prior to selecting PRS triggering to avoid any false triggers.

The DTI prescaler, set by DTPRESC in TIMER0\_DTTIMECFG determines the accuracy with which the DTI can insert dead-time into a PRS signal. The maximum dead-time error equals DTIPRESC+1 clock cycles. With DTIPRESC = 0, the inserted dead-times are therefore accurate, but they may be inaccurate for larger prescaler settings.

#### 19.3.4.3 Fault Handling

The fault handling system of the DTI unit allows the outputs of the DTI unit to be put in a well-defined state in case of a fault. This hardware fault handling system enables a fast reaction to faults, reducing the possibility of damage to the system.

The fault sources which trigger a fault in the DTI module are determined by the bitfields of TIMER0\_DTFcfg register. Any combination of the available error sources can be selected:

- PRS source 1, determined by PRSSEL in PRS\_CONSUMER\_TIMERn\_DTIFS1
- PRS source 2, determined by PRSSEL in PRS\_CONSUMER\_TIMERn\_DTIFS2
- Debugger
- Core Lockup
- EM2 or EM3 Entry

One or two PRS channels can be used as an error source. When PRS source 1 is selected as an error source, PRSSEL in PRS\_CONSUMER\_TIMERn\_DTIFS1 determines which PRS channel is used for this source. PRSSEL in PRS\_CONSUMER\_TIMERn\_DTIFS2 determines which PRS channel is selected as PRS source 2. Note that for Core Lockup, the LOCKUPRDIS in RMU\_CTRL must be set. Otherwise this will generate a full reset of the chip.

**Note:** When using synchronous PRS sources, it is recommended to configure the PRS consumer registers prior to selecting PRS triggering to avoid any false triggers.

#### 19.3.4.4 Action on Fault

When a fault occurs, the bit representing the fault source is set in TIMER0\_DTFault register, and the outputs from the DTI unit are set to a well-defined state. The following options are available, and can be enabled by configuring DTFA in TIMER0\_DTFcfg:

- Set outputs to inactive level
- Clear outputs
- Tristate outputs

With the first option enabled, the output state in case of a fault depends on the polarity settings for the individual outputs. An output set to be active high will be set low if a fault is detected, while an output set to be active low will be driven high.

When a fault occurs, the fault source(s) can be read out from TIMER0\_DTFault register.

Additionally a fault action can also be triggered when the timer stops if DTFATS in TIMER0\_DTCFG is set. This allows the DTI output to go to safe state specified by DTFA in TIMER0\_DTFcfg when the timer stops. When DTAR and DTFATS in TIMER0\_DTCFG are both set, DTI channel 0 keeps running even when the timer stops. This is useful when DTI channel 0 has an input coming from PRS.

#### 19.3.4.5 Exiting Fault State

When a fault is triggered by the PRS system, software intervention is required to re-enable the outputs of the DTI unit. This is done by manually clearing bits in the TIMER0\_DTFault register. If the fault source as determined by checking TIMER0\_DTFault is the debugger alone, the outputs can be automatically restarted when the debugger exits. To enable automatic restart set DTDAS in TIMER0\_DCTFG. When an automatic restart occurs the DTDBGF bit in TIMER0\_DTFault will be automatically cleared by hardware. If any other bits in the TIMER0\_DTFault register are set when the hardware clears DTDBGF the DTI module will not exit the fault state.

#### 19.3.4.6 DTI Configuration Lock

To prevent software errors from making changes to the DTI configuration, a configuration lock is available. Writing any value but 0xCE80 to LOCKKEY in TIMER0\_DTLOCK locks writes to registers TIMER0\_DTCFG, TIMER0\_DTCFCFG, TIMER0\_DTCCTRL, and TIMER0\_DTTIMECFG. To unlock the registers, write 0xCE80 to LOCKKEY in TIMER0\_DTLOCK. The value of DTILOCKSTATUS in TIMERn\_STATUS is 1 when the lock is active, and 0 when the registers are unlocked.

#### 19.3.5 Debug Mode

When the CPU is halted in debug mode, the timer can be configured to either continue to run or to be frozen. This is configured in DEBUGRUN in TIMERn\_CFG.

#### 19.3.6 Interrupts, DMA and PRS Output

The timer can generate several type of output events:

- Counter Underflow
- Counter Overflow
- Quadrature Decoder Direction Change
- Compare match or input capture (one per compare/capture channel)

Each of the events has its own interrupt flag. Also, there are interrupt flags for each compare/capture channel which are set on FIFO overflow or underflow in capture mode. FIFO overflow happens when a new capture over-writes an old unread capture in TIMERn\_CCx\_ICF. FIFO underflow happens when software reads TIMERn\_CCx\_ICF while the FIFO is empty.

If the interrupt flags are set and the corresponding interrupt enable bits in TIMERn\_IEN are set high, the timer will send out an interrupt request. Each of the events may optionally trigger signals to PRS channels. The PRSCONF field in TIMERn\_CCx\_CFG determines how PRS events are generated. When PRSCONF is set to PULSE, and event will lead to a one HFFPERCLK<sub>TIMERn</sub> cycle high pulse on individual PRS outputs. Setting PRSCONF to LEVEL will make the PRS output follow the compare match output. Interrupts are cleared by setting the corresponding bit in the TIMERn\_IFC register.

Each of the events will also set a DMA request when they occur. The different DMA requests are cleared when certain acknowledge conditions are met, see [Table 19.4 TIMER DMA Events on page 529](#). Events which clear the DMA requests do not clear interrupt flags. Software must still manually clear the interrupt flag if interrupts are in use.

If DMACLRACT is set in TIMERn\_CFG, the DMA request is cleared when the triggered DMA channel is active, without having to access any timer registers. This is useful in cases where a timer event is used to trigger a DMA transfer in output compare or PWM mode that does not target the OC or OCB registers. DMACLRACT is not applicable in input capture mode.

**Table 19.4. TIMER DMA Events**

| Event                                   | Acknowledge/Clear                                 |
|-----------------------------------------|---------------------------------------------------|
| Underflow/Overflow                      | Read or write to TIMERn_CNT or TIMERn_TOPB        |
| CC0 Input Capture - ICFWLFULL0 flag set | ICFEMPTY0 flag set (read FIFO via TIMERn_CC0_ICF) |
| CC1 Input Capture - ICFWLFULL1 flag set | ICFEMPTY1 flag set (read FIFO via TIMERn_CC1_ICF) |
| CC2 Input Capture - ICFWLFULL2 flag set | ICFEMPTY2 flag set (read FIFO via TIMERn_CC2_ICF) |
| CC3 Input Capture - ICFWLFULL3 flag set | ICFEMPTY3 flag set (read FIFO via TIMERn_CC3_ICF) |
| CC0 Output Compare / PWM - Match event  | Write TIMERn_CC0_OC or TIMERn_CC0_OCB             |
| CC1 Output Compare / PWM - Match event  | Write TIMERn_CC1_OC or TIMERn_CC1_OCB             |
| CC2 Output Compare / PWM - Match event  | Write TIMERn_CC2_OC or TIMERn_CC2_OCB             |
| CC3 Output Compare / PWM - Match event  | Write TIMERn_CC3_OC or TIMERn_CC3_OCB             |

#### 19.3.7 GPIO Input/Output

The TIMn\_CCx inputs/outputs and TIMn\_CDTIx outputs are accessible as alternate functions through GPIO. Each pin connection can be enabled/disabled separately using the GPIO module control registers. See the device data sheet for the available locations for each signal.

#### 19.4 TIMER Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description                           |
|--------|---------------------|-------------|---------------------------------------|
| 0x000  | TIMER_IPVERSION     | R           | IP Version ID                         |
| 0x004  | TIMER_CFG           | RW CONFIG   | Configuration Register                |
| 0x008  | TIMER_CTRL          | RW SYNC     | Control Register                      |
| 0x00C  | TIMER_CMD           | W SYNC      | Command Register                      |
| 0x010  | TIMER_STATUS        | RH          | Status Register                       |
| 0x014  | TIMER_IF            | RWH INTFLAG | Interrupt Flag Register               |
| 0x018  | TIMER_IEN           | RW          | Interrupt Enable Register             |
| 0x01C  | TIMER_TOP           | RWH SYNC    | Counter Top Value Register            |
| 0x020  | TIMER_TOPB          | RW SYNC     | Counter Top Value Buffer Register     |
| 0x024  | TIMER_CNT           | RWH SYNC    | Counter Value Register                |
| 0x02C  | TIMER_LOCK          | W           | TIMER Configuration Lock Register     |
| 0x030  | TIMER_EN            | RW ENABLE   | Module En                             |
| 0x060  | TIMER_CCx_CFG       | RW CONFIG   | CC Channel Configuration Register     |
| 0x064  | TIMER_CCx_CTRL      | RW SYNC     | CC Channel Control Register           |
| 0x068  | TIMER_CCx_OC        | RWH SYNC    | OC Channel Value Register             |
| 0x070  | TIMER_CCx_OCB       | RW SYNC     | OC Channel Value Buffer Register      |
| 0x074  | TIMER_CCx_ICF       | RH(r)       | IC Channel Value Register             |
| 0x078  | TIMER_CCx_ICOF      | RH SYNC     | IC Channel Value Overflow Register    |
| 0x0E0  | TIMER_DTCFG         | RW CONFIG   | DTI Configuration Register            |
| 0x0E4  | TIMER_DTTIMECFG     | RW CONFIG   | DTI Time Configuration Register       |
| 0x0E8  | TIMER_DTFCFG        | RW CONFIG   | DTI Fault Configuration Register      |
| 0x0EC  | TIMER_DTCTRL        | RW SYNC     | DTI Control Register                  |
| 0x0F0  | TIMER.DTOGEN        | RW SYNC     | DTI Output Generation Enable Register |
| 0x0F4  | TIMER_DTFault       | RH          | DTI Fault Register                    |
| 0x0F8  | TIMER_DTFaultC      | W SYNC      | DTI Fault Clear Register              |
| 0x0FC  | TIMER_DTLock        | W           | DTI Configuration Lock Register       |
| 0x1000 | TIMER_IPVERSION_SET | R           | IP Version ID                         |
| 0x1004 | TIMER_CFG_SET       | RW CONFIG   | Configuration Register                |
| 0x1008 | TIMER_CTRL_SET      | RW SYNC     | Control Register                      |
| 0x100C | TIMER_CMD_SET       | W SYNC      | Command Register                      |
| 0x1010 | TIMER_STATUS_SET    | RH          | Status Register                       |
| 0x1014 | TIMER_IF_SET        | RWH INTFLAG | Interrupt Flag Register               |
| 0x1018 | TIMER_IEN_SET       | RW          | Interrupt Enable Register             |
| 0x101C | TIMER_TOP_SET       | RWH SYNC    | Counter Top Value Register            |
| 0x1020 | TIMER_TOPB_SET      | RW SYNC     | Counter Top Value Buffer Register     |

| Offset | Name                | Type        | Description                           |
|--------|---------------------|-------------|---------------------------------------|
| 0x1024 | TIMER_CNT_SET       | RWH SYNC    | Counter Value Register                |
| 0x102C | TIMER_LOCK_SET      | W           | TIMER Configuration Lock Register     |
| 0x1030 | TIMER_EN_SET        | RW ENABLE   | Module En                             |
| 0x1060 | TIMER_CCx_CFG_SET   | RW CONFIG   | CC Channel Configuration Register     |
| 0x1064 | TIMER_CCx_CTRL_SET  | RW SYNC     | CC Channel Control Register           |
| 0x1068 | TIMER_CCx_OC_SET    | RWH SYNC    | OC Channel Value Register             |
| 0x1070 | TIMER_CCx_OCB_SET   | RW SYNC     | OC Channel Value Buffer Register      |
| 0x1074 | TIMER_CCx_ICF_SET   | RH(r)       | IC Channel Value Register             |
| 0x1078 | TIMER_CCx ICOF_SET  | RH SYNC     | IC Channel Value Overflow Register    |
| 0x10E0 | TIMER_DTCFG_SET     | RW CONFIG   | DTI Configuration Register            |
| 0x10E4 | TIMER_DTTIMECFG_SET | RW CONFIG   | DTI Time Configuration Register       |
| 0x10E8 | TIMER_DTFCFG_SET    | RW CONFIG   | DTI Fault Configuration Register      |
| 0x10EC | TIMER_DTCTRL_SET    | RW SYNC     | DTI Control Register                  |
| 0x10F0 | TIMER.DTOGEN_SET    | RW SYNC     | DTI Output Generation Enable Register |
| 0x10F4 | TIMER_DTFault_SET   | RH          | DTI Fault Register                    |
| 0x10F8 | TIMER_DTFaultTC_SET | W SYNC      | DTI Fault Clear Register              |
| 0x10FC | TIMER_DTLOCK_SET    | W           | DTI Configuration Lock Register       |
| 0x2000 | TIMER_IPVERSION_CLR | R           | IP Version ID                         |
| 0x2004 | TIMER_CFG_CLR       | RW CONFIG   | Configuration Register                |
| 0x2008 | TIMER_CTRL_CLR      | RW SYNC     | Control Register                      |
| 0x200C | TIMER_CMD_CLR       | W SYNC      | Command Register                      |
| 0x2010 | TIMER_STATUS_CLR    | RH          | Status Register                       |
| 0x2014 | TIMER_IF_CLR        | RWH INTFLAG | Interrupt Flag Register               |
| 0x2018 | TIMER_IEN_CLR       | RW          | Interrupt Enable Register             |
| 0x201C | TIMER_TOP_CLR       | RWH SYNC    | Counter Top Value Register            |
| 0x2020 | TIMER_TOPB_CLR      | RW SYNC     | Counter Top Value Buffer Register     |
| 0x2024 | TIMER_CNT_CLR       | RWH SYNC    | Counter Value Register                |
| 0x202C | TIMER_LOCK_CLR      | W           | TIMER Configuration Lock Register     |
| 0x2030 | TIMER_EN_CLR        | RW ENABLE   | Module En                             |
| 0x2060 | TIMER_CCx_CFG_CLR   | RW CONFIG   | CC Channel Configuration Register     |
| 0x2064 | TIMER_CCx_CTRL_CLR  | RW SYNC     | CC Channel Control Register           |
| 0x2068 | TIMER_CCx_OC_CLR    | RWH SYNC    | OC Channel Value Register             |
| 0x2070 | TIMER_CCx_OCB_CLR   | RW SYNC     | OC Channel Value Buffer Register      |
| 0x2074 | TIMER_CCx_ICF_CLR   | RH(r)       | IC Channel Value Register             |
| 0x2078 | TIMER_CCx ICOF_CLR  | RH SYNC     | IC Channel Value Overflow Register    |
| 0x20E0 | TIMER_DTCFG_CLR     | RW CONFIG   | DTI Configuration Register            |
| 0x20E4 | TIMER_DTTIMECFG_CLR | RW CONFIG   | DTI Time Configuration Register       |

| Offset | Name                | Type        | Description                           |
|--------|---------------------|-------------|---------------------------------------|
| 0x20E8 | TIMER_DTFCFG_CLR    | RW CONFIG   | DTI Fault Configuration Register      |
| 0x20EC | TIMER_DTCTRL_CLR    | RW SYNC     | DTI Control Register                  |
| 0x20F0 | TIMER.DTOGEN_CLR    | RW SYNC     | DTI Output Generation Enable Register |
| 0x20F4 | TIMER_DTFault_CLR   | RH          | DTI Fault Register                    |
| 0x20F8 | TIMER_DTFaultTC_CLR | W SYNC      | DTI Fault Clear Register              |
| 0x20FC | TIMER_DTLOCK_CLR    | W           | DTI Configuration Lock Register       |
| 0x3000 | TIMER_IPVERSION_TGL | R           | IP Version ID                         |
| 0x3004 | TIMER_CFG_TGL       | RW CONFIG   | Configuration Register                |
| 0x3008 | TIMER_CTRL_TGL      | RW SYNC     | Control Register                      |
| 0x300C | TIMER_CMD_TGL       | W SYNC      | Command Register                      |
| 0x3010 | TIMER_STATUS_TGL    | RH          | Status Register                       |
| 0x3014 | TIMER_IF_TGL        | RWH INTFLAG | Interrupt Flag Register               |
| 0x3018 | TIMER_IEN_TGL       | RW          | Interrupt Enable Register             |
| 0x301C | TIMER_TOP_TGL       | RWH SYNC    | Counter Top Value Register            |
| 0x3020 | TIMER_TOPB_TGL      | RW SYNC     | Counter Top Value Buffer Register     |
| 0x3024 | TIMER_CNT_TGL       | RWH SYNC    | Counter Value Register                |
| 0x302C | TIMER_LOCK_TGL      | W           | TIMER Configuration Lock Register     |
| 0x3030 | TIMER_EN_TGL        | RW ENABLE   | Module En                             |
| 0x3060 | TIMER_CCx_CFG_TGL   | RW CONFIG   | CC Channel Configuration Register     |
| 0x3064 | TIMER_CCx_CTRL_TGL  | RW SYNC     | CC Channel Control Register           |
| 0x3068 | TIMER_CCx_OC_TGL    | RWH SYNC    | OC Channel Value Register             |
| 0x3070 | TIMER_CCx_OCB_TGL   | RW SYNC     | OC Channel Value Buffer Register      |
| 0x3074 | TIMER_CCx_ICF_TGL   | RH(r)       | IC Channel Value Register             |
| 0x3078 | TIMER_CCx_ICOF_TGL  | RH SYNC     | IC Channel Value Overflow Register    |
| 0x30E0 | TIMER_DTCFG_TGL     | RW CONFIG   | DTI Configuration Register            |
| 0x30E4 | TIMER_DTTIMECFG_TGL | RW CONFIG   | DTI Time Configuration Register       |
| 0x30E8 | TIMER_DTFCFG_TGL    | RW CONFIG   | DTI Fault Configuration Register      |
| 0x30EC | TIMER_DTCTRL_TGL    | RW SYNC     | DTI Control Register                  |
| 0x30F0 | TIMER.DTOGEN_TGL    | RW SYNC     | DTI Output Generation Enable Register |
| 0x30F4 | TIMER_DTFault_TGL   | RH          | DTI Fault Register                    |
| 0x30F8 | TIMER_DTFaultTC_TGL | W SYNC      | DTI Fault Clear Register              |
| 0x30FC | TIMER_DTLOCK_TGL    | W           | DTI Configuration Lock Register       |

## 19.5 TIMER Register Description

### 19.5.1 TIMER\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|-----------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 0x000  | 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 |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x1 |    |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | R  |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    | IPVERSION |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bit  | Name      | Reset | Access | Description          |
|------|-----------|-------|--------|----------------------|
| 31:0 | IPVERSION | 0x1   | R      | <b>IP Version ID</b> |

The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION.

## 19.5.2 TIMER\_CFG - Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |     |    |    |     |    |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|-----|----|----|-----|----|----|-----|---|----|-----|---|----|-----|---|----|-----|---|----|-----|---|----|-----|---|----|-----|---|----|-----|---|--|
| 0x004  | 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 |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |     |    |    |     |    |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |     |    |    |     |    |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |  |
| Name   | PRESC        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RSSCOIST | RW | 0x0 | 17 | RW | 0x0 | 12 | RW | 0x0 | 7 | RW | 0x0 | 6 | RW | 0x0 | 5 | RW | 0x0 | 4 | RW | 0x0 | 3 | RW | 0x0 | 2 | RW | 0x0 | 1 | RW | 0x0 | 0 |  |
|        | ATI          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |     |    |    |     |    |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |    |     |   |  |

| Bit   | Name       | Reset   | Access | Description                                                                                                                                                                                                                                                                                             |
|-------|------------|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved   |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                       |
| 27:18 | PRESC      | 0x0     | RW     | <b>Prescaler Setting</b>                                                                                                                                                                                                                                                                                |
|       |            |         |        | These bits select the prescaling factor for the counter clock. The selected timer clock will be divided by PRESC+1 before clocking the counter. The following modes are provided for easier software porting from Series 0 or Series 1 devices. However, the prescaler is not limited to these options. |
|       | Value      | Mode    |        | Description                                                                                                                                                                                                                                                                                             |
|       | 0          | DIV1    |        | No prescaling                                                                                                                                                                                                                                                                                           |
|       | 1          | DIV2    |        | Prescale by 2                                                                                                                                                                                                                                                                                           |
|       | 3          | DIV4    |        | Prescale by 4                                                                                                                                                                                                                                                                                           |
|       | 7          | DIV8    |        | Prescale by 8                                                                                                                                                                                                                                                                                           |
|       | 15         | DIV16   |        | Prescale by 16                                                                                                                                                                                                                                                                                          |
|       | 31         | DIV32   |        | Prescale by 32                                                                                                                                                                                                                                                                                          |
|       | 63         | DIV64   |        | Prescale by 64                                                                                                                                                                                                                                                                                          |
|       | 127        | DIV128  |        | Prescale by 128                                                                                                                                                                                                                                                                                         |
|       | 255        | DIV256  |        | Prescale by 256                                                                                                                                                                                                                                                                                         |
|       | 511        | DIV512  |        | Prescale by 512                                                                                                                                                                                                                                                                                         |
|       | 1023       | DIV1024 |        | Prescale by 1024                                                                                                                                                                                                                                                                                        |
| 17    | RSSCOIST   | 0x0     | RW     | <b>Reload-Start Sets COIST</b>                                                                                                                                                                                                                                                                          |
|       |            |         |        | When enabled, compare output is set to COIST value on a Reload-Start event.                                                                                                                                                                                                                             |
| 16    | ATI        | 0x0     | RW     | <b>Always Track Inputs</b>                                                                                                                                                                                                                                                                              |
|       |            |         |        | Enabling ATI makes CCPOL always track the polarity of the inputs.                                                                                                                                                                                                                                       |
| 15:13 | Reserved   |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                       |
| 12    | RETIMESEL  | 0x0     | RW     | <b>PWM output retime select</b>                                                                                                                                                                                                                                                                         |
|       |            |         |        | When RETIMEEN is set, the PWM output stage will be re-timed to synchronize edges with radio clocks and reduce RF interference. This will introduce up to 1 cycle of clock jitter between PWM outputs.                                                                                                   |
| 11    | DISSYNCOUT | 0x0     | RW     | <b>Disable Timer Start/Stop/Reload output</b>                                                                                                                                                                                                                                                           |
|       |            |         |        | When this bit is set, the Timer does not start/stop/reload other timers with SYNC bit set.                                                                                                                                                                                                              |

| Bit | Name                                                                                                                                                                            | Reset            | Access | Description                                                                                          |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------|------------------------------------------------------------------------------------------------------|
|     | Value                                                                                                                                                                           | Mode             |        | Description                                                                                          |
|     | 0                                                                                                                                                                               | EN               |        | Timer can start/stop/reload other timers with SYNC bit set                                           |
|     | 1                                                                                                                                                                               | DIS              |        | Timer cannot start/stop/reload other timers with SYNC bit set                                        |
| 10  | RETIMEEN                                                                                                                                                                        | 0x0              | RW     | <b>PWM output retimed enable</b>                                                                     |
|     | Enable retiming of PWM output.                                                                                                                                                  |                  |        |                                                                                                      |
|     | Value                                                                                                                                                                           | Mode             |        | Description                                                                                          |
|     | 0                                                                                                                                                                               | DISABLE          |        | PWM outputs are not re-timed.                                                                        |
|     | 1                                                                                                                                                                               | ENABLE           |        | PWM outputs are re-timed.                                                                            |
| 9:8 | CLKSEL                                                                                                                                                                          | 0x0              | RW     | <b>Clock Source Select</b>                                                                           |
|     | These bits select the clock source for the timer.                                                                                                                               |                  |        |                                                                                                      |
|     | Value                                                                                                                                                                           | Mode             |        | Description                                                                                          |
|     | 0                                                                                                                                                                               | PRESCEM01GRPACLK |        | Prescaled EM01GRPACLK                                                                                |
|     | 1                                                                                                                                                                               | CC1              |        | Compare/Capture Channel 1 Input                                                                      |
|     | 2                                                                                                                                                                               | TIMEROUF         |        | Timer is clocked by underflow(down-count) or overflow(up-count) in the lower numbered neighbor Timer |
| 7   | DMACLRACT                                                                                                                                                                       | 0x0              | RW     | <b>DMA Request Clear on Active</b>                                                                   |
|     | When this bit is set, the DMA requests are cleared when the corresponding DMA channel is active. This enables the timer DMA requests to be cleared without accessing the timer. |                  |        |                                                                                                      |
| 6   | DEBUGRUN                                                                                                                                                                        | 0x0              | RW     | <b>Debug Mode Run Enable</b>                                                                         |
|     | Set this bit to enable timer to run in debug mode.                                                                                                                              |                  |        |                                                                                                      |
|     | Value                                                                                                                                                                           | Mode             |        | Description                                                                                          |
|     | 0                                                                                                                                                                               | HALT             |        | Timer is halted in debug mode                                                                        |
|     | 1                                                                                                                                                                               | RUN              |        | Timer is running in debug mode                                                                       |
| 5   | QDM                                                                                                                                                                             | 0x0              | RW     | <b>Quadrature Decoder Mode Selection</b>                                                             |
|     | This bit sets the mode for the quadrature decoder.                                                                                                                              |                  |        |                                                                                                      |
|     | Value                                                                                                                                                                           | Mode             |        | Description                                                                                          |
|     | 0                                                                                                                                                                               | X2               |        | X2 mode selected                                                                                     |
|     | 1                                                                                                                                                                               | X4               |        | X4 mode selected                                                                                     |
| 4   | OSMEN                                                                                                                                                                           | 0x0              | RW     | <b>One-shot Mode Enable</b>                                                                          |
|     | Enable/disable one shot mode.                                                                                                                                                   |                  |        |                                                                                                      |
| 3   | SYNC                                                                                                                                                                            | 0x0              | RW     | <b>Timer Start/Stop/Reload Synchronization</b>                                                       |
|     | When this bit is set, the Timer is started/stopped/reloaded by start/stop/reload commands in the other timers.                                                                  |                  |        |                                                                                                      |
|     | Value                                                                                                                                                                           | Mode             |        | Description                                                                                          |
|     | 0                                                                                                                                                                               | DISABLE          |        | Timer operation is unaffected by other timers.                                                       |

| Bit | Name     | Reset  | Access | Description                                                                                                                                                                                    |
|-----|----------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | 1        | ENABLE |        | Timer may be started, stopped and re-loaded from other timer instances.                                                                                                                        |
| 2   | Reserved |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>              |
| 1:0 | MODE     | 0x0    | RW     | <b>Timer Mode</b>                                                                                                                                                                              |
|     |          |        |        | These bits set the counting mode for the Timer. Note, when Quadrature Decoder Mode is selected (MODE = 'b11), the CLKSEL is don't care. The Timer is clocked by the Decoder Mode clock output. |
|     | Value    | Mode   |        | Description                                                                                                                                                                                    |
|     | 0        | UP     |        | Up-count mode                                                                                                                                                                                  |
|     | 1        | DOWN   |        | Down-count mode                                                                                                                                                                                |
|     | 2        | UPDOWN |        | Up/down-count mode                                                                                                                                                                             |
|     | 3        | QDEC   |        | Quadrature decoder mode                                                                                                                                                                        |

## 19.5.3 TIMER\_CTRL - Control Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |       |       |       |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-------|-------|-------|-----|---|
| 0x008         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0   | 0x0   | 0x0   | 0x0 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW    | RW    | RW    | RW  |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | X2CNT | FALLA | RISEA |     |   |

| Bit  | Name                                                                                       | Reset       | Access | Description                                                                                                                                                       |
|------|--------------------------------------------------------------------------------------------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved                                                                                   |             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 4    | X2CNT                                                                                      | 0x0         | RW     | <b>2x Count Mode</b>                                                                                                                                              |
|      | Enable 2x count mode                                                                       |             |        |                                                                                                                                                                   |
| 3:2  | FALLA                                                                                      | 0x0         | RW     | <b>Timer Falling Input Edge Action</b>                                                                                                                            |
|      | These bits select the action taken in the counter when a falling edge occurs on the input. |             |        |                                                                                                                                                                   |
|      | Value                                                                                      | Mode        |        | Description                                                                                                                                                       |
|      | 0                                                                                          | NONE        |        | No action                                                                                                                                                         |
|      | 1                                                                                          | START       |        | Start counter without reload                                                                                                                                      |
|      | 2                                                                                          | STOP        |        | Stop counter without reload                                                                                                                                       |
|      | 3                                                                                          | RELOADSTART |        | Reload and start counter                                                                                                                                          |
| 1:0  | RISEA                                                                                      | 0x0         | RW     | <b>Timer Rising Input Edge Action</b>                                                                                                                             |
|      | These bits select the action taken in the counter when a rising edge occurs on the input.  |             |        |                                                                                                                                                                   |
|      | Value                                                                                      | Mode        |        | Description                                                                                                                                                       |
|      | 0                                                                                          | NONE        |        | No action                                                                                                                                                         |
|      | 1                                                                                          | START       |        | Start counter without reload                                                                                                                                      |
|      | 2                                                                                          | STOP        |        | Stop counter without reload                                                                                                                                       |
|      | 3                                                                                          | RELOADSTART |        | Reload and start counter                                                                                                                                          |

## 19.5.4 TIMER\_CMD - Command Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |       |       |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------|-------|-----|
| 0x00C         | 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     |     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0   | 1     |     |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | W(nB) | 0x0   |     |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | STOP  | W(nB) | 0x0 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | START | W(nB) | 0x0 |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                    |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------|
| 31:2 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                |
| 1    | STOP     | 0x0                                                                                                                                                                               | W(nB)  | <b>Stop Timer</b><br><br>Write a 1 to this bit to stop timer   |
| 0    | START    | 0x0                                                                                                                                                                               | W(nB)  | <b>Start Timer</b><br><br>Write a 1 to this bit to start timer |

## 19.5.5 TIMER\_STATUS - Status Register

| Offset | Bit Position |        |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |       |       |       |          |              |                 |   |       |     |         |  |  |  |  |  |
|--------|--------------|--------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-------|-------|-------|----------|--------------|-----------------|---|-------|-----|---------|--|--|--|--|--|
| 0x010  | 31           | 30     | 29     | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 |   |       |       |       |          |              |                 |   |       |     |         |  |  |  |  |  |
| Reset  |              |        |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |       |       |       |          |              |                 |   |       |     |         |  |  |  |  |  |
| Access | R            | R      | R      | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R | R     | R     | R     | R        | R            | R               | R | R     | R   | R       |  |  |  |  |  |
| Name   | CCPOL2       | CCPOL1 | CCPOL0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | OCBV2 | OCBV1 | OCBV0 | SYNCBUSY | DTLOCKSTATUS | TIMERLOCKSTATUS | R | TOPBV | DIR | RUNNING |  |  |  |  |  |

| Bit   | Name      | Reset                                | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |             |   |         |                                    |   |          |                                      |
|-------|-----------|--------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|---------|------------------------------------|---|----------|--------------------------------------|
| 31:27 | Reserved  |                                      |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |         |                                    |   |          |                                      |
| 26    | CCPOL2    | 0x0                                  | R      | <b>Compare/Capture Polarity</b><br><br>In Input Capture mode, this bit indicates the polarity of the edge that triggered capture in TIMERn_CCx_CCV. In Compare/PWM mode, this bit indicates the polarity of the selected input to CC channel x. These bits are cleared when CCMODE is written to 0b00 (Off).<br><br><table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>LOWRISE</td> <td>CCx polarity low level/rising edge</td> </tr> <tr> <td>1</td> <td>HIGHFALL</td> <td>CCx polarity high level/falling edge</td> </tr> </tbody> </table> | Value | Mode | Description | 0 | LOWRISE | CCx polarity low level/rising edge | 1 | HIGHFALL | CCx polarity high level/falling edge |
| Value | Mode      | Description                          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 0     | LOWRISE   | CCx polarity low level/rising edge   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 1     | HIGHFALL  | CCx polarity high level/falling edge |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 25    | CCPOL1    | 0x0                                  | R      | <b>Compare/Capture Polarity</b><br><br>In Input Capture mode, this bit indicates the polarity of the edge that triggered capture in TIMERn_CCx_CCV. In Compare/PWM mode, this bit indicates the polarity of the selected input to CC channel x. These bits are cleared when CCMODE is written to 0b00 (Off).<br><br><table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>LOWRISE</td> <td>CCx polarity low level/rising edge</td> </tr> <tr> <td>1</td> <td>HIGHFALL</td> <td>CCx polarity high level/falling edge</td> </tr> </tbody> </table> | Value | Mode | Description | 0 | LOWRISE | CCx polarity low level/rising edge | 1 | HIGHFALL | CCx polarity high level/falling edge |
| Value | Mode      | Description                          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 0     | LOWRISE   | CCx polarity low level/rising edge   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 1     | HIGHFALL  | CCx polarity high level/falling edge |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 24    | CCPOL0    | 0x0                                  | R      | <b>Compare/Capture Polarity</b><br><br>In Input Capture mode, this bit indicates the polarity of the edge that triggered capture in TIMERn_CCx_CCV. In Compare/PWM mode, this bit indicates the polarity of the selected input to CC channel x. These bits are cleared when CCMODE is written to 0b00 (Off).<br><br><table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>LOWRISE</td> <td>CCx polarity low level/rising edge</td> </tr> <tr> <td>1</td> <td>HIGHFALL</td> <td>CCx polarity high level/falling edge</td> </tr> </tbody> </table> | Value | Mode | Description | 0 | LOWRISE | CCx polarity low level/rising edge | 1 | HIGHFALL | CCx polarity high level/falling edge |
| Value | Mode      | Description                          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 0     | LOWRISE   | CCx polarity low level/rising edge   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 1     | HIGHFALL  | CCx polarity high level/falling edge |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |         |                                    |   |          |                                      |
| 23:19 | Reserved  |                                      |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |         |                                    |   |          |                                      |
| 18    | ICFEMPTY2 | 0x0                                  | R      | <b>Input capture fifo empty</b><br><br>Set when input capture FIFO is empty                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |             |   |         |                                    |   |          |                                      |

| Bit   | Name            | Reset    | Access | Description                                                                                                                                                                                                                                                               |
|-------|-----------------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17    | ICFEMPTY1       | 0x0      | R      | <b>Input capture fifo empty</b><br><br>Set when input capture FIFO is empty                                                                                                                                                                                               |
| 16    | ICFEMPTY0       | 0x0      | R      | <b>Input capture fifo empty</b><br><br>Set when input capture FIFO is empty                                                                                                                                                                                               |
| 15:11 | Reserved        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                         |
| 10    | OCBV2           | 0x0      | R      | <b>Output Compare Buffer Valid</b><br><br>This field indicates that the TIMERn_CCx_CCVB registers contain data which have not been written to TIMERn_CCx_CCV. These bits are only used in OUTPUTCOMPARE or PWM mode and are cleared when CCMODE is written to 0b00 (Off). |
| 9     | OCBV1           | 0x0      | R      | <b>Output Compare Buffer Valid</b><br><br>This field indicates that the TIMERn_CCx_CCVB registers contain data which have not been written to TIMERn_CCx_CCV. These bits are only used in OUTPUTCOMPARE or PWM mode and are cleared when CCMODE is written to 0b00 (Off). |
| 8     | OCBV0           | 0x0      | R      | <b>Output Compare Buffer Valid</b><br><br>This field indicates that the TIMERn_CCx_CCVB registers contain data which have not been written to TIMERn_CCx_CCV. These bits are only used in OUTPUTCOMPARE or PWM mode and are cleared when CCMODE is written to 0b00 (Off). |
| 7     | Reserved        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                         |
| 6     | SYNCBUSY        | 0x0      | R      | <b>Sync Busy</b><br><br>Indicates synchronization ongoing                                                                                                                                                                                                                 |
| 5     | DTILOCKSTATUS   | 0x0      | R      | <b>DTI lock status</b><br><br>Indicates current status of DTI lock                                                                                                                                                                                                        |
|       | Value           | Mode     |        | Description                                                                                                                                                                                                                                                               |
|       | 0               | UNLOCKED |        | DTI registers are unlocked                                                                                                                                                                                                                                                |
|       | 1               | LOCKED   |        | DTI registers are locked                                                                                                                                                                                                                                                  |
| 4     | TIMERLOCKSTATUS | 0x0      | R      | <b>Timer lock status</b><br><br>Indicates current status of Timer lock                                                                                                                                                                                                    |
|       | Value           | Mode     |        | Description                                                                                                                                                                                                                                                               |
|       | 0               | UNLOCKED |        | TIMER registers are unlocked                                                                                                                                                                                                                                              |
|       | 1               | LOCKED   |        | TIMER registers are locked                                                                                                                                                                                                                                                |
| 3     | Reserved        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                         |
| 2     | TOPBV           | 0x0      | R      | <b>TOP Buffer Valid</b><br><br>This indicates that TIMERn_TOPB contains valid data that has not been written to TIMERn_TOP. This bit is also cleared when TIMERn_TOP is written.                                                                                          |
| 1     | DIR             | 0x0      | R      | <b>Direction</b><br><br>Indicates count direction.                                                                                                                                                                                                                        |
|       | Value           | Mode     |        | Description                                                                                                                                                                                                                                                               |

| Bit | Name                                  | Reset | Access | Description    |
|-----|---------------------------------------|-------|--------|----------------|
|     | 0                                     | UP    |        | Counting up    |
|     | 1                                     | DOWN  |        | Counting down  |
| 0   | RUNNING                               | 0x0   | R      | <b>Running</b> |
|     | Indicates if timer is running or not. |       |        |                |

## 19.5.6 TIMER\_IF - Interrupt Flag Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |        |     |     |     |     |     |     |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|-----|-----|-----|-----|-----|-----|
| 0x014  | 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   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0    | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0    | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DIRCHG | RW  | RW  | RW  | UF  | OF  | RW  |

| Bit   | Name       | Reset                                                                                                                                                             | Access | Description                                                                                                                                                                                                  |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                                                                                                                                              |
| 26    | ICFUF2     | 0x0                                                                                                                                                               | RW     | <b>Input capture FIFO underflow</b><br><br>Indicates that software tried to read an empty FIFO on channel 2.                                                                                                 |
| 25    | ICFUF1     | 0x0                                                                                                                                                               | RW     | <b>Input capture FIFO underflow</b><br><br>Indicates that software tried to read an empty FIFO on channel 1.                                                                                                 |
| 24    | ICFUF0     | 0x0                                                                                                                                                               | RW     | <b>Input capture FIFO underflow</b><br><br>Indicates that software tried to read an empty FIFO on channel 0.                                                                                                 |
| 23    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                                                                                                                                              |
| 22    | ICFOF2     | 0x0                                                                                                                                                               | RW     | <b>Input Capture FIFO overflow</b><br><br>Indicates that input capture FIFO for channel 2 has overflowed, and a prior captured value was lost. The latest captured value can be read from the ICOF register. |
| 21    | ICFOF1     | 0x0                                                                                                                                                               | RW     | <b>Input Capture FIFO overflow</b><br><br>Indicates that input capture FIFO for channel 1 has overflowed, and a prior captured value was lost. The latest captured value can be read from the ICOF register. |
| 20    | ICFOF0     | 0x0                                                                                                                                                               | RW     | <b>Input Capture FIFO overflow</b><br><br>Indicates that input capture FIFO for channel 0 has overflowed, and a prior captured value was lost. The latest captured value can be read from the ICOF register. |
| 19    | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                                                                                                                                              |
| 18    | ICFWLFULL2 | 0x0                                                                                                                                                               | RW     | <b>Input Capture Watermark Level Full</b><br><br>This bit indicates that the Input capture FIFO watermark for channel 2 has been exceeded.                                                                   |
| 17    | ICFWLFULL1 | 0x0                                                                                                                                                               | RW     | <b>Input Capture Watermark Level Full</b><br><br>This bit indicates that the Input capture FIFO watermark for channel 1 has been exceeded.                                                                   |
| 16    | ICFWLFULL0 | 0x0                                                                                                                                                               | RW     | <b>Input Capture Watermark Level Full</b><br><br>This bit indicates that the Input capture FIFO watermark for channel 0 has been exceeded.                                                                   |
| 15:7  | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                                                                                                                                              |
| 6     | CC2        | 0x0                                                                                                                                                               | RW     | <b>Capture Compare Channel 2 Interrupt Flag</b>                                                                                                                                                              |

| Bit | Name     | Reset | Access | Description                                                                                                                                                                       |
|-----|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          |       |        | In INPUT CAPTURE mode this bit indicates that a new Capture event has taken place. In OUTPUTCOMPARE or PWM mode this bit indicates that a match event has taken place             |
| 5   | CC1      | 0x0   | RW     | <b>Capture Compare Channel 1 Interrupt Flag</b>                                                                                                                                   |
|     |          |       |        | In INPUT CAPTURE mode this bit indicates that a new Capture event has taken place. In OUTPUTCOMPARE or PWM mode this bit indicates that a match event has taken place             |
| 4   | CC0      | 0x0   | RW     | <b>Capture Compare Channel 0 Interrupt Flag</b>                                                                                                                                   |
|     |          |       |        | In INPUT CAPTURE mode this bit indicates that a new Capture event has taken place. In OUTPUTCOMPARE or PWM mode this bit indicates that a match event has taken place             |
| 3   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2   | DIRCHG   | 0x0   | RW     | <b>Direction Change Detect Interrupt Flag</b>                                                                                                                                     |
|     |          |       |        | This bit is set when count direction changes. Set only in Quadrature Decoder mode                                                                                                 |
| 1   | UF       | 0x0   | RW     | <b>Underflow Interrupt Flag</b>                                                                                                                                                   |
|     |          |       |        | This bit indicates that there has been an underflow.                                                                                                                              |
| 0   | OF       | 0x0   | RW     | <b>Overflow Interrupt Flag</b>                                                                                                                                                    |
|     |          |       |        | This bit indicates that there has been an overflow.                                                                                                                               |

## 19.5.7 TIMER\_IEN - Interrupt Enable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |       |       |       |        |        |        |            |            |            |     |     |     |        |    |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-------|-------|-------|--------|--------|--------|------------|------------|------------|-----|-----|-----|--------|----|----|
| 0x018  | 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  |    |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 | RW | ICFU2 | ICFU1 | ICFU0 | ICFOF2 | ICFOF1 | ICFOF0 | ICFWLFULL2 | ICFWLFULL1 | ICFWLFULL0 | CC2 | CC1 | CC0 | DIRCHG | UF | OF |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 | RW | ICFU2 | ICFU1 | ICFU0 | ICFOF2 | ICFOF1 | ICFOF0 | ICFWLFULL2 | ICFWLFULL1 | ICFWLFULL0 | CC2 | CC1 | CC0 | DIRCHG | UF | OF |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 | RW | ICFU2 | ICFU1 | ICFU0 | ICFOF2 | ICFOF1 | ICFOF0 | ICFWLFULL2 | ICFWLFULL1 | ICFWLFULL0 | CC2 | CC1 | CC0 | DIRCHG | UF | OF |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                       |
|-------|------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 26    | ICFU2      | 0x0   | RW     | <b>ICFU2 Interrupt Enable</b><br>Enable/Disable the ICFU2 interrupt                                                                                               |
| 25    | ICFU1      | 0x0   | RW     | <b>ICFU1 Interrupt Enable</b><br>Enable/Disable the ICFU1 interrupt                                                                                               |
| 24    | ICFU0      | 0x0   | RW     | <b>ICFU0 Interrupt Enable</b><br>Enable/Disable the ICFU0 interrupt                                                                                               |
| 23    | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 22    | ICFOF2     | 0x0   | RW     | <b>ICFOF2 Interrupt Enable</b><br>Enable/Disable the ICFOF2 interrupt                                                                                             |
| 21    | ICFOF1     | 0x0   | RW     | <b>ICFOF1 Interrupt Enable</b><br>Enable/Disable the ICFOF1 interrupt                                                                                             |
| 20    | ICFOF0     | 0x0   | RW     | <b>ICFOF0 Interrupt Enable</b><br>Enable/Disable the ICFOF0 interrupt                                                                                             |
| 19    | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 18    | ICFWLFULL2 | 0x0   | RW     | <b>ICFWLFULL2 Interrupt Enable</b><br>Enable/Disable the ICFWLFULL2 interrupt                                                                                     |
| 17    | ICFWLFULL1 | 0x0   | RW     | <b>ICFWLFULL1 Interrupt Enable</b><br>Enable/Disable the ICFWLFULL1 interrupt                                                                                     |
| 16    | ICFWLFULL0 | 0x0   | RW     | <b>ICFWLFULL0 Interrupt Enable</b><br>Enable/Disable the ICFWLFULL0 interrupt                                                                                     |
| 15:7  | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 6     | CC2        | 0x0   | RW     | <b>CC2 Interrupt Enable</b><br>Enable/Disable the CC2 interrupt                                                                                                   |
| 5     | CC1        | 0x0   | RW     | <b>CC1 Interrupt Enable</b>                                                                                                                                       |

| Bit | Name     | Reset | Access | Description                                                                                                                                                       |
|-----|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          |       |        | Enable/Disable the CC1 interrupt                                                                                                                                  |
| 4   | CC0      | 0x0   | RW     | <b>CC0 Interrupt Enable</b>                                                                                                                                       |
|     |          |       |        | Enable/Disable the CC0 interrupt                                                                                                                                  |
| 3   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 2   | DIRCHG   | 0x0   | RW     | <b>Direction Change Detect Interrupt Enable</b>                                                                                                                   |
|     |          |       |        | Enable/Disable the DIRCHG interrupt                                                                                                                               |
| 1   | UF       | 0x0   | RW     | <b>Underflow Interrupt Enable</b>                                                                                                                                 |
|     |          |       |        | Enable/Disable the UF interrupt                                                                                                                                   |
| 0   | OF       | 0x0   | RW     | <b>Overflow Interrupt Enable</b>                                                                                                                                  |
|     |          |       |        | Enable/Disable the OF interrupt                                                                                                                                   |

#### 19.5.8 TIMER\_TOP - Counter Top Value Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| 0x01C  | 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      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0xFFFF |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TOP    |

| Bit                                           | Name | Reset  | Access | Description              |
|-----------------------------------------------|------|--------|--------|--------------------------|
| 31:0                                          | TOP  | 0xFFFF | RW     | <b>Counter Top Value</b> |
| These bits hold the TOP value for the counter |      |        |        |                          |

#### 19.5.9 TIMER\_TOPB - Counter Top Value Buffer Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |      |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------|---|
| 0x020  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0  |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | TOPB |   |

| Bit                                   | Name | Reset | Access | Description                        |
|---------------------------------------|------|-------|--------|------------------------------------|
| 31:0                                  | TOPB | 0x0   | RW     | <b>Counter Top Buffer Register</b> |
| These bits hold the TOP buffer value. |      |       |        |                                    |

**19.5.10 TIMER\_CNT - Counter Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x024  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | CNT          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                | Name | Reset | Access | Description          |
|------------------------------------|------|-------|--------|----------------------|
| 31:0                               | CNT  | 0x0   | RW     | <b>Counter Value</b> |
| These bits hold the counter value. |      |       |        |                      |

**19.5.11 TIMER\_LOCK - TIMER Configuration Lock Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x02C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | W            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | LOCKKEY      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                               | Name     | Reset                                                                                                                                                                      | Access | Description           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------|
| 31:16                                                                                                                                                                                                                             | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                       |
| 15:0                                                                                                                                                                                                                              | LOCKKEY  | 0x0                                                                                                                                                                        | W      | <b>Timer Lock Key</b> |
| Write any other value than the unlock code to lock TIMERn_CTRL, TIMERn_CFG, TIMERn_CMD, TIMERn_TOP, TIMERn_CNT, TIMERn_CCx_CTRL, TIMERn_CCx_CFG, and TIMERn_CCx_OC from editing. Write the unlock code to unlock these registers. |          |                                                                                                                                                                            |        |                       |
| Value                                                                                                                                                                                                                             | Mode     | Description                                                                                                                                                                |        |                       |
| 52864                                                                                                                                                                                                                             | UNLOCK   | Write to unlock TIMER registers                                                                                                                                            |        |                       |

## 19.5.12 TIMER\_EN - Module En

| Offset    | Bit Position |     |    |    |    |           |    |     |    |           |    |     |    |    |    |           |    |     |    |           |    |     |   |   |    |           |    |     |    |           |   |     |   |   |  |
|-----------|--------------|-----|----|----|----|-----------|----|-----|----|-----------|----|-----|----|----|----|-----------|----|-----|----|-----------|----|-----|---|---|----|-----------|----|-----|----|-----------|---|-----|---|---|--|
| 0x030     | 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   |   |   |  |
| Reset     | 0x0          |     |    |    |    |           |    |     |    |           |    |     |    |    |    |           |    |     |    |           |    |     |   |   |    |           |    |     |    |           |   |     |   |   |  |
| Access    |              |     |    |    |    |           |    |     |    |           |    |     |    |    |    |           |    |     |    |           |    |     |   |   |    |           |    |     |    |           |   |     |   |   |  |
| Name      |              |     |    |    |    |           |    |     |    |           |    |     |    |    |    |           |    |     |    |           |    |     |   |   |    |           |    |     |    |           |   |     |   |   |  |
| DISABLING | R            | 0x0 | 1  | 0  | EN | DISABLING | RW | 0x0 | EN | DISABLING | R  | 0x0 | 1  | 0  | EN | DISABLING | RW | 0x0 | EN | DISABLING | R  | 0x0 | 1 | 0 | EN | DISABLING | RW | 0x0 | EN | DISABLING | R | 0x0 | 1 | 0 |  |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                                                                                                 |
|------|-----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                           |
| 1    | DISABLING | 0x0   | R      | <b>Disablement busy status</b><br><br>When EN is cleared, DISABLING status is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS and FIFO |
| 0    | EN        | 0x0   | RW     | <b>Timer Module Enable</b><br><br>The ENABLE bit enables the module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit.                          |

## 19.5.13 TIMER\_CCx\_CFG - CC Channel Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |       |   |   |      |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------|---|---|------|---|---|---|
| 0x060  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0   |   |   |      |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW    |   |   |      |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | COIST |   |   | MODE |   |   |   |

| Bit   | Name     | Reset         | Access | Description                                                                                                                                                                                                                                                      |
|-------|----------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                |
| 21    | ICFWL    | 0x0           | RW     | <b>Input Capture FIFO watermark level</b><br><br>Sets the watermark level for generation of the ICFWLFULL interrupt and DMA requests. ICFWLFULL will be set and DMA requests may be generated if the number of free FIFO entries is less than or equal to ICFWL. |
| 20    | FILT     | 0x0           | RW     | <b>Digital Filter</b><br><br>Enable digital filter.<br><br>Value Mode Description                                                                                                                                                                                |
|       | 0        | DISABLE       |        | Digital Filter Disabled                                                                                                                                                                                                                                          |
|       | 1        | ENABLE        |        | Digital Filter Enabled                                                                                                                                                                                                                                           |
| 19    | PRSCONF  | 0x0           | RW     | <b>PRS Configuration</b><br><br>Select PRS pulse or level for PRS output.<br><br>Value Mode Description                                                                                                                                                          |
|       | 0        | PULSE         |        | Each CC event will generate a one EM01GRPACLK cycle high pulse                                                                                                                                                                                                   |
|       | 1        | LEVEL         |        | The PRS channel will follow CC out                                                                                                                                                                                                                               |
| 18:17 | INSEL    | 0x0           | RW     | <b>Input Selection</b><br><br>Select Compare/Capture channel input.<br><br>Value Mode Description                                                                                                                                                                |
|       | 0        | PIN           |        | TIMERnCCx pin is selected                                                                                                                                                                                                                                        |
|       | 1        | PRSSYNC       |        | Synchronous PRS selected                                                                                                                                                                                                                                         |
|       | 2        | PRSASYNCLEVEL |        | Asynchronous Level PRS selected                                                                                                                                                                                                                                  |
|       | 3        | PRSASYNCPULSE |        | Asynchronous Pulse PRS selected                                                                                                                                                                                                                                  |
| 16:5  | Reserved |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                |
| 4     | COIST    | 0x0           | RW     | <b>Compare Output Initial State</b>                                                                                                                                                                                                                              |

| Bit                                                                                                                                                                                                                                                                                                                                                                                                   | Name          | Reset                              | Access | Description                                                                                                                                                                       |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|-----|------------------------------------|---|--------------|---------------|---|---------------|----------------|---|-----|------------------------|
| This bit is only used in Output Compare and PWM mode. When this bit is set in Compare or PWM mode, the output is set high when the counter is disabled. When counting resumes, this value will represent the initial value for the output. If the bit is cleared, the output will be cleared when the counter is disabled.                                                                            |               |                                    |        |                                                                                                                                                                                   |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| 3:2                                                                                                                                                                                                                                                                                                                                                                                                   | Reserved      |                                    |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| 1:0                                                                                                                                                                                                                                                                                                                                                                                                   | MODE          | 0x0                                | RW     | <b>CC Channel Mode</b>                                                                                                                                                            |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| These bits select the mode for Compare/Capture channel.                                                                                                                                                                                                                                                                                                                                               |               |                                    |        |                                                                                                                                                                                   |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>OFF</td><td>Compare/Capture channel turned off</td></tr> <tr> <td>1</td><td>INPUTCAPTURE</td><td>Input Capture</td></tr> <tr> <td>2</td><td>OUTPUTCOMPARE</td><td>Output Compare</td></tr> <tr> <td>3</td><td>PWM</td><td>Pulse-Width Modulation</td></tr> </tbody> </table> |               |                                    |        |                                                                                                                                                                                   | Value | Mode | Description | 0 | OFF | Compare/Capture channel turned off | 1 | INPUTCAPTURE | Input Capture | 2 | OUTPUTCOMPARE | Output Compare | 3 | PWM | Pulse-Width Modulation |
| Value                                                                                                                                                                                                                                                                                                                                                                                                 | Mode          | Description                        |        |                                                                                                                                                                                   |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| 0                                                                                                                                                                                                                                                                                                                                                                                                     | OFF           | Compare/Capture channel turned off |        |                                                                                                                                                                                   |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| 1                                                                                                                                                                                                                                                                                                                                                                                                     | INPUTCAPTURE  | Input Capture                      |        |                                                                                                                                                                                   |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| 2                                                                                                                                                                                                                                                                                                                                                                                                     | OUTPUTCOMPARE | Output Compare                     |        |                                                                                                                                                                                   |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |
| 3                                                                                                                                                                                                                                                                                                                                                                                                     | PWM           | Pulse-Width Modulation             |        |                                                                                                                                                                                   |       |      |             |   |     |                                    |   |              |               |   |               |                |   |     |                        |

## 19.5.14 TIMER\_CCx\_CTRL - CC Channel Control Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x064         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name            | Reset                                                                                                                              | Access          | Description                                                                                                                                                                       |
|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | <b>Reserved</b> |                                                                                                                                    |                 | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:26 | ICEVCTRL        | 0x0                                                                                                                                | RW              | <b>Input Capture Event Control</b>                                                                                                                                                |
|       |                 | These bits control when a Compare/Capture PRS output pulse and interrupt flag is set. DMA request however is set on every capture. |                 |                                                                                                                                                                                   |
|       |                 | Value                                                                                                                              | Mode            | Description                                                                                                                                                                       |
|       |                 | 0                                                                                                                                  | EVERYEDGE       | PRS output pulse and interrupt flag set on every capture                                                                                                                          |
|       |                 | 1                                                                                                                                  | EVERYSECONDEDGE | PRS output pulse and interrupt flag set on every second capture                                                                                                                   |
|       |                 | 2                                                                                                                                  | RISING          | PRS output pulse and interrupt flag set on rising edge only (if ICEDGE = BOTH)                                                                                                    |
|       |                 | 3                                                                                                                                  | FALLING         | PRS output pulse and interrupt flag set on falling edge only (if ICEDGE = BOTH)                                                                                                   |
| 25:24 | ICEDGE          | 0x0                                                                                                                                | RW              | <b>Input Capture Edge Select</b>                                                                                                                                                  |
|       |                 | These bits control which edges the edge detector triggers on. The output is used for input capture and external clock input.       |                 |                                                                                                                                                                                   |
|       |                 | Value                                                                                                                              | Mode            | Description                                                                                                                                                                       |
|       |                 | 0                                                                                                                                  | RISING          | Rising edges detected                                                                                                                                                             |
|       |                 | 1                                                                                                                                  | FALLING         | Falling edges detected                                                                                                                                                            |
|       |                 | 2                                                                                                                                  | BOTH            | Both edges detected                                                                                                                                                               |
|       |                 | 3                                                                                                                                  | NONE            | No edge detection, signal is left as it is                                                                                                                                        |
| 23:14 | <b>Reserved</b> |                                                                                                                                    |                 | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13:12 | CUFOA           | 0x0                                                                                                                                | RW              | <b>Counter Underflow Output Action</b>                                                                                                                                            |
|       |                 | Select output action on counter underflow.                                                                                         |                 |                                                                                                                                                                                   |
|       |                 | Value                                                                                                                              | Mode            | Description                                                                                                                                                                       |
|       |                 | 0                                                                                                                                  | NONE            | No action on counter underflow                                                                                                                                                    |
|       |                 | 1                                                                                                                                  | TOGGLE          | Toggle output on counter underflow                                                                                                                                                |
|       |                 | 2                                                                                                                                  | CLEAR           | Clear output on counter underflow                                                                                                                                                 |
|       |                 | 3                                                                                                                                  | SET             | Set output on counter underflow                                                                                                                                                   |

| Bit   | Name                                                                                  | Reset                                                                                                                                                                             | Access | Description                           |
|-------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------|
| 11:10 | COFOA                                                                                 | 0x0                                                                                                                                                                               | RW     | <b>Counter Overflow Output Action</b> |
|       | Select output action on counter overflow.                                             |                                                                                                                                                                                   |        |                                       |
|       | Value                                                                                 | Mode                                                                                                                                                                              |        | Description                           |
|       | 0                                                                                     | NONE                                                                                                                                                                              |        | No action on counter overflow         |
|       | 1                                                                                     | TOGGLE                                                                                                                                                                            |        | Toggle output on counter overflow     |
|       | 2                                                                                     | CLEAR                                                                                                                                                                             |        | Clear output on counter overflow      |
|       | 3                                                                                     | SET                                                                                                                                                                               |        | Set output on counter overflow        |
| 9:8   | CMOA                                                                                  | 0x0                                                                                                                                                                               | RW     | <b>Compare Match Output Action</b>    |
|       | Select output action on compare match.                                                |                                                                                                                                                                                   |        |                                       |
|       | Value                                                                                 | Mode                                                                                                                                                                              |        | Description                           |
|       | 0                                                                                     | NONE                                                                                                                                                                              |        | No action on compare match            |
|       | 1                                                                                     | TOGGLE                                                                                                                                                                            |        | Toggle output on compare match        |
|       | 2                                                                                     | CLEAR                                                                                                                                                                             |        | Clear output on compare match         |
|       | 3                                                                                     | SET                                                                                                                                                                               |        | Set output on compare match           |
| 7:3   | Reserved                                                                              | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                       |
| 2     | OUTINV                                                                                | 0x0                                                                                                                                                                               | RW     | <b>Output Invert</b>                  |
|       | Setting this bit inverts the output from the CC channel (Output compare or PWM mode). |                                                                                                                                                                                   |        |                                       |
| 1:0   | Reserved                                                                              | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                       |

### 19.5.15 TIMER\_CCx\_OC - OC Channel Value Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x068  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | OC           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name                                       | Reset | Access | Description                 |
|------|--------------------------------------------|-------|--------|-----------------------------|
| 31:0 | OC                                         | 0x0   | RW     | <b>Output Compare Value</b> |
|      | This fields holds the output compare value |       |        |                             |

**19.5.16 TIMER\_CCx\_OCB - OC Channel Value Buffer Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x070  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | OCB          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                                                                                                              | Name | Reset | Access | Description                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------|------------------------------------|
| 31:0                                                                                                                                             | OCB  | 0x0   | RW     | <b>Output Compare Value Buffer</b> |
| This field holds the Output Compare buffer value which will be written to TIMERn_CCx_OC on an update event if TIMERn_CCx_OCB contains valid data |      |       |        |                                    |

**19.5.17 TIMER\_CCx\_ICF - IC Channel Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x074  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R(r)         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | ICF          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                          | Name | Reset | Access | Description               |
|------------------------------------------------------------------------------------------------------------------------------|------|-------|--------|---------------------------|
| 31:0                                                                                                                         | ICF  | 0x0   | R(r)   | <b>Input Capture FIFO</b> |
| This FIFO holds captured values in input capture mode. Reading this register will pop the oldest unread value from the FIFO. |      |       |        |                           |

**19.5.18 TIMER\_CCx\_ICOF - IC Channel Value Overflow Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x078  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | ICOF         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                          | Name | Reset | Access | Description                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------|------------------------------------|
| 31:0                                                                                                                                                                                                         | ICOF | 0x0   | R      | <b>Input Capture FIFO Overflow</b> |
| This register always contains the most recent input capture value. If the input capture FIFO is full and a new capture occurs, this register will be updated and the previous capture value is over-written. |      |       |        |                                    |

### 19.5.19 TIMER\_DTCFG - DTI Configuration Register

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                                                                                  |
|-------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                            |
| 11    | DTPRSEN  | 0x0   | RW     | <b>DTI PRS Source Enable</b><br><br>Enable/disable PRS as DTI input.                                                                                                                                                                                                                                         |
| 10    | DTFATS   | 0x0   | RW     | <b>DTI Fault Action on Timer Stop</b><br><br>When Timer stops, DTI block outputs go to safe state as programmed in DTFA field of TIMERn_DTC register. However, when DTAR is also set, DTAR having higher priority allows channel0 to output the incoming PRS input while the other channels go to safe state |
| 9     | DTAR     | 0x0   | RW     | <b>DTI Always Run</b><br><br>This is used only for DTI channel 0. It Allows DTI channel 0 to keep running even when the timer is stopped. This is useful when its input source is PRS. However, here the undivided peripheral clock is always used regardless of the programmed value in DTPRESC.            |
| 8:2   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                            |
| 1     | DTDAS    | 0x0   | RW     | <b>DTI Automatic Start-up Functionality</b><br><br>Configure DTI restart on debugger exit.                                                                                                                                                                                                                   |
| <hr/> |          |       |        |                                                                                                                                                                                                                                                                                                              |
| Value |          |       |        |                                                                                                                                                                                                                                                                                                              |
| 0     |          |       |        |                                                                                                                                                                                                                                                                                                              |
| 1     |          |       |        |                                                                                                                                                                                                                                                                                                              |
| <hr/> |          |       |        |                                                                                                                                                                                                                                                                                                              |
| 0     | DTEN     | 0x0   | RW     | <b>DTI Enable</b><br><br>Enable/disable DTI.                                                                                                                                                                                                                                                                 |

## 19.5.20 TIMER\_DTTIMECFG - DTI Time Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| 0x0E4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |    |    |    |    |   |   | 0x0     |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    | RW      |    |    |    |    |    |    |    |    |    |   |   | RW      |   |   |   |   |   |   |   |
| Name   | DTFALLT      |    |    |    |    |    |    |    |    |    |    |    | DTRISET |    |    |    |    |    |    |    |    |    |   |   | DTPRESC |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 21:16 | DTFALLT  | 0x0   | RW     | <b>DTI Fall-time</b><br><br>Set time span for the falling edge. The fall time is DTFALLT+1 prescaled peripheral clock cycles                                                      |
| 15:10 | DTRISET  | 0x0   | RW     | <b>DTI Rise-time</b><br><br>Set time span for the rising edge. The rise time is DTRISET+1 prescaled peripheral clock cycles                                                       |
| 9:0   | DTPRESC  | 0x0   | RW     | <b>DTI Prescaler Setting</b><br><br>These bits select the prescaling factor for DTI. The selected timer clock will be divided by DTPRESC+1 before clocking the DTI logic.         |

## 19.5.21 TIMER\_DTFCFG - DTI Fault Configuration Register

| Offset | Bit Position |           |             |           |           |           |     |    |     |    |     |    |     |    |    |    |    |    |    |    |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|--------|--------------|-----------|-------------|-----------|-----------|-----------|-----|----|-----|----|-----|----|-----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 0x0E8  | 31           | 30        | 29          | 28        | 0x0       | 27        | 0x0 | 26 | 0x0 | 25 | 0x0 | 24 | 0x0 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Reset  |              |           |             |           |           |           |     |    |     |    |     |    |     |    |    |    |    |    |    |    | 0x0  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Access |              |           |             | RW        | RW        | RW        | RW  | RW | RW  | RW | RW  | RW | RW  |    |    |    |    |    |    | RW |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name   |              | DTEM23FEN | DTLOCKUPFEN | DTDBGFFEN | DTPRS1FEN | DTPRS0FEN |     |    |     |    |     |    |     |    |    |    |    |    |    |    | DTFA |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bit   | Name        | Reset    | Access | Description                                                                                                                                                                       |
|-------|-------------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved    |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 28    | DTEM23FEN   | 0x0      | RW     | <b>DTI EM23 Fault Enable</b><br><br>Set this bit to 1 to enable EM2 or EM3 entry as a fault source                                                                                |
| 27    | DTLOCKUPFEN | 0x0      | RW     | <b>DTI Lockup Fault Enable</b><br><br>Set this bit to 1 to enable core lockup as a fault source                                                                                   |
| 26    | DTDBGFFEN   | 0x0      | RW     | <b>DTI Debugger Fault Enable</b><br><br>Set this bit to 1 to enable debugger as a fault source                                                                                    |
| 25    | DTPRS1FEN   | 0x0      | RW     | <b>DTI PRS 1 Fault Enable</b><br><br>Set this bit to 1 to enable PRS source 1 as a fault source                                                                                   |
| 24    | DTPRS0FEN   | 0x0      | RW     | <b>DTI PRS 0 Fault Enable</b><br><br>Set this bit to 1 to enable PRS source 0 as a fault source                                                                                   |
| 23:18 | Reserved    |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17:16 | DTFA        | 0x0      | RW     | <b>DTI Fault Action</b><br><br>Select fault action.                                                                                                                               |
|       | Value       | Mode     |        | Description                                                                                                                                                                       |
|       | 0           | NONE     |        | No action on fault                                                                                                                                                                |
|       | 1           | INACTIVE |        | Set outputs inactive                                                                                                                                                              |
|       | 2           | CLEAR    |        | Clear outputs                                                                                                                                                                     |
|       | 3           | TRISTATE |        | Tristate outputs                                                                                                                                                                  |
| 15:0  | Reserved    |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 19.5.22 TIMER\_DTCTRL - DTI Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |        |        |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|--------|--------|---|
| 0x0EC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |        |        |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |        |        |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | DTIPOL | DTCINV |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | DTIPOL   | 0x0   | RW     | <b>DTI Inactive Polarity</b><br><br>Set inactive polarity of outputs                                                                                                              |
| 0    | DTCINV   | 0x0   | RW     | <b>DTI Complementary Output Invert.</b><br><br>DTI Complementary Output Invert.                                                                                                   |

## 19.5.23 TIMER\_DTOGEN - DTI Output Generation Enable Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|
| 0x0F0         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 5 |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 4 |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 3 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 2 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 1 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                       |
|------|-------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 5    | DTOGCDTI2EN | 0x0   | RW     | <b>DTI CDTIn Output Generation Enable</b><br><br>This bit enables/disables output generation for the CDTI output from the DTI.                                    |
| 4    | DTOGCDTI1EN | 0x0   | RW     | <b>DTI CDTIn Output Generation Enable</b><br><br>This bit enables/disables output generation for the CDTI output from the DTI.                                    |
| 3    | DTOGCDTI0EN | 0x0   | RW     | <b>DTI CDTIn Output Generation Enable</b><br><br>This bit enables/disables output generation for the CDTI output from the DTI.                                    |
| 2    | DTOGCC2EN   | 0x0   | RW     | <b>DTI CCn Output Generation Enable</b><br><br>This bit enables/disables output generation for the CC output from the DTI.                                        |
| 1    | DTOGCC1EN   | 0x0   | RW     | <b>DTI CCn Output Generation Enable</b><br><br>This bit enables/disables output generation for the CC output from the DTI.                                        |
| 0    | DTOGCC0EN   | 0x0   | RW     | <b>DTI CCn Output Generation Enable</b><br><br>This bit enables/disables output generation for the CC output from the DTI.                                        |

## 19.5.24 TIMER\_DFAULT - DTI Fault Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |           |        |         |         |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|-----------|--------|---------|---------|---|---|
| 0x0F4  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     | 0x0       | 0x0    | 0x0     | 0x0     |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | R       | R         | R      | R       | R       |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DTEM23F | DTLOCKUPF | DTDBGF | DTPRS1F | DTPRS0F |   |   |

| Bit  | Name      | Reset                                                                                                                                                                             | Access | Description                                                                                                                                                                       |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                   |
| 4    | DTEM23F   | 0x0                                                                                                                                                                               | R      | <b>DTI EM23 Entry Fault</b><br><br>This bit is set to 1 if EM2 or EM3 entry has occurred and DTEM23FEN is set to 1. The TIMER0_DFAULTC register can be used to clear fault bits.  |
| 3    | DTLOCKUPF | 0x0                                                                                                                                                                               | R      | <b>DTI Lockup Fault</b><br><br>This bit is set to 1 if a core lockup fault has occurred and DTLOCKUPFEN is set to 1. The TIMER0_DFAULTC register can be used to clear fault bits. |
| 2    | DTDBGF    | 0x0                                                                                                                                                                               | R      | <b>DTI Debugger Fault</b><br><br>This bit is set to 1 if a debugger fault has occurred and DTDBGFEN is set to 1. The TIMER0_DFAULTC register can be used to clear fault bits.     |
| 1    | DTPRS1F   | 0x0                                                                                                                                                                               | R      | <b>DTI PRS 1 Fault</b><br><br>This bit is set to 1 if a PRS 1 fault has occurred and DTPRS1FEN is set to 1. The TIMER0_DFAULTC register can be used to clear fault bits.          |
| 0    | DTPRS0F   | 0x0                                                                                                                                                                               | R      | <b>DTI PRS 0 Fault</b><br><br>This bit is set to 1 if a PRS 0 fault has occurred and DTPRS0FEN is set to 1. The TIMER0_DFAULTC register can be used to clear fault bits.          |

## 19.5.25 TIMER\_DTFaultTC - DTI Fault Clear Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |       |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------|---|---|
| 0x0F8         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   | 4 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W(nB) | 3 |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W(nB) | 0 |   |

| Bit  | Name                                            | Reset | Access | Description                                                                                                                                                                       |
|------|-------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved                                        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | DTEM23FC                                        | 0x0   | W(nB)  | <b>DTI EM23 Fault Clear</b>                                                                                                                                                       |
|      | Write 1 to this bit to clear EM23 entry fault.  |       |        |                                                                                                                                                                                   |
| 3    | DTLOCKUPFC                                      | 0x0   | W(nB)  | <b>DTI Lockup Fault Clear</b>                                                                                                                                                     |
|      | Write 1 to this bit to clear core lockup fault. |       |        |                                                                                                                                                                                   |
| 2    | DTDBGFC                                         | 0x0   | W(nB)  | <b>DTI Debugger Fault Clear</b>                                                                                                                                                   |
|      | Write 1 to this bit to clear debugger fault.    |       |        |                                                                                                                                                                                   |
| 1    | DTPRS1FC                                        | 0x0   | W(nB)  | <b>DTI PRS1 Fault Clear</b>                                                                                                                                                       |
|      | Write 1 to this bit to clear PRS 1 fault.       |       |        |                                                                                                                                                                                   |
| 0    | DTPRS0FC                                        | 0x0   | W(nB)  | <b>DTI PRS0 Fault Clear</b>                                                                                                                                                       |
|      | Write 1 to this bit to clear PRS 0 fault.       |       |        |                                                                                                                                                                                   |

## 19.5.26 TIMER\_DTLOCK - DTI Configuration Lock Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |            |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|------------|---|---|---|---|---|---|
| 0x0FC         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |            |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W   |            |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | DTILOCKKEY |   |   |   |   |   |   |

| Bit                                                                                                                                                                                          | Name       | Reset  | Access | Description                                                                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                                                                                                        | Reserved   |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                                                                                                                                         | DTILOCKKEY | 0x0    | W      | <b>DTI Lock Key</b>                                                                                                                                                               |
| Write any other value than the unlock code to lock TIMER_ROUTE, TIMER_DTCTRL, TIMER_DTCFG, TIMER_DTTIMECFG and TIMER_DTFCFG from editing. Write the unlock code to unlock the DTI registers. |            |        |        |                                                                                                                                                                                   |
|                                                                                                                                                                                              | Value      | Mode   |        | Description                                                                                                                                                                       |
|                                                                                                                                                                                              | 52864      | UNLOCK |        | Write to unlock TIMER DTI registers                                                                                                                                               |

## 20. USART - Universal Synchronous Asynchronous Receiver/Transmitter



### Quick Facts

#### What?

The USART handles high-speed UART, SPI-bus, SmartCards, and IrDA communication.

#### Why?

Serial communication is frequently used in embedded systems and the USART allows efficient communication with a wide range of external devices.

#### How?

The USART has a wide selection of operating modes, frame formats and baud rates. The multi-processor mode allows the USART to remain idle when not addressed. Triple buffering and DMA support makes high data-rates possible with minimal CPU intervention and it is possible to transmit and receive large frames while the MCU remains in EM1 Sleep.

### 20.1 Introduction

The Universal Synchronous Asynchronous serial Receiver and Transmitter (USART) is a very flexible serial I/O module. It supports full duplex asynchronous UART communication as well as RS-485, SPI, MicroWire and 3-wire. It can also interface with ISO7816 Smart Cards, and IrDA devices.

## 20.2 Features

- Asynchronous and synchronous (SPI) communication
- Full duplex and half duplex
- Separate TX/RX enable
- Separate receive / transmit multiple entry buffers, with additional separate shift registers
- Programmable baud rate, generated as an fractional division from the peripheral clock ( $PCLK_{USARTn}$ )
- Max bit-rate
  - Main SPI mode, peripheral clock rate/2
  - Secondary SPI mode, peripheral clock rate/6
  - UART mode, peripheral clock rate/16, 8, 6, or 4
- Asynchronous mode supports
  - Majority vote baud-reception
  - False start-bit detection
  - Break generation/detection
  - Multi-processor mode
- Synchronous mode supports
  - All 4 SPI clock polarity/phase configurations
  - Main and Secondary interface modes
- Data can be transmitted LSB first or MSB first
- Configurable number of data bits, 4-16 (plus the parity bit, if enabled)
  - HW parity bit generation and check
- Configurable number of stop bits in asynchronous mode: 0.5, 1, 1.5, 2
- HW collision detection
- Multi-processor mode
- IrDA modulator
- SmartCard (ISO7816) mode
- I2S mode
- Separate interrupt vectors for receive and transmit interrupts
- Loopback mode
  - Half duplex communication
  - Communication debugging
- PRS RX input
- 8 bit Timer
- Hardware Flow Control
- Automatic Baud Rate Detection

## 20.3 Functional Description

An overview of the USART module is shown in [Figure 20.1 USART Overview on page 563](#).

This section describes all possible USART features. Please refer to the Device Datasheet to see what features a specific USART instance supports.



Figure 20.1. USART Overview

### 20.3.1 Modes of Operation

The USART operates in either asynchronous or synchronous mode.

In synchronous mode, a separate clock signal is transmitted with the data. This clock signal is generated by the main interface on the bus, and both the main and secondary devices sample and transmit data according to this clock. Both main and secondary interface modes are supported by the USART. The synchronous communication mode is compatible with the Serial Peripheral Interface Bus (SPI) standard.

In asynchronous mode, no separate clock signal is transmitted with the data on the bus. The USART receiver thus has to determine where to sample the data on the bus from the actual data. To make this possible, additional synchronization bits are added to the data when operating in asynchronous mode, resulting in a slight overhead.

Asynchronous or synchronous mode can be selected by configuring SYNC in USARTn\_CTRL. The options are listed with supported protocols in [Table 20.1 USART Asynchronous vs. Synchronous Mode on page 564](#). Full duplex and half duplex communication is supported in both asynchronous and synchronous mode.

**Table 20.1. USART Asynchronous vs. Synchronous Mode**

| SYNC | Communication Mode | Supported Protocols                                |
|------|--------------------|----------------------------------------------------|
| 0    | Asynchronous       | RS-232, RS-485 (w/external driver), IrDA, ISO 7816 |
| 1    | Synchronous        | SPI, MicroWire, 3-wire                             |

[Table 20.2 USART Pin Usage on page 564](#) explains the functionality of the different USART pins when the USART operates in different modes. Pin functionality enclosed in square brackets is optional, and depends on additional configuration parameters. LOOPBK and MASTER are discussed in [20.3.2.14 Local Loopback](#) and [20.3.3.3 Synchronous Main Interface Mode](#) respectively.

**Table 20.2. USART Pin Usage**

| SYNC | LOOPBK | MASTER | Pin functionality |                 |           |                         |
|------|--------|--------|-------------------|-----------------|-----------|-------------------------|
|      |        |        | U(S)n_TX (MOSI)   | U(S)n_RX (MISO) | USn_CLK   | USn_CS                  |
| 0    | 0      | x      | Data out          | Data in         | -         | [Driver enable]         |
| 0    | 1      | x      | Data out/in       | -               | -         | [Driver enable]         |
| 1    | 0      | 0      | Data in           | Data out        | Clock in  | Secondary select        |
| 1    | 0      | 1      | Data out          | Data in         | Clock out | [Auto secondary select] |
| 1    | 1      | 0      | Data out/in       | -               | Clock in  | Secondary select        |
| 1    | 1      | 1      | Data out/in       | -               | Clock out | [Auto secondary select] |

### 20.3.2 Asynchronous Operation

### 20.3.2.1 Frame Format

The frame format used in asynchronous mode consists of a set of data bits in addition to bits for synchronization and optionally a parity bit for error checking. A frame starts with one start-bit (S), where the line is driven low for one bit-period. This signals the start of a frame, and is used for synchronization. Following the start bit are 4 to 16 data bits and an optional parity bit. Finally, a number of stop-bits, where the line is driven high, end the frame. An example frame is shown in [Figure 20.2 USART Asynchronous Frame Format on page 565](#).



**Figure 20.2. USART Asynchronous Frame Format**

The number of data bits in a frame is set by DATABITS in USARTn\_FRAME, see [Table 20.3 USART Data Bits on page 565](#), and the number of stop-bits is set by STOPBITS in USARTn\_FRAME, see [Table 20.4 USART Stop Bits on page 565](#). Whether or not a parity bit should be included, and whether it should be even or odd is defined by PARITY, also in USARTn\_FRAME. For communication to be possible, all parties of an asynchronous transfer must agree on the frame format being used.

**Table 20.3. USART Data Bits**

| DATA BITS [3:0] | Number of Data bits |
|-----------------|---------------------|
| 0001            | 4                   |
| 0010            | 5                   |
| 0011            | 6                   |
| 0100            | 7                   |
| 0101            | 8 (Default)         |
| 0110            | 9                   |
| 0111            | 10                  |
| 1000            | 11                  |
| 1001            | 12                  |
| 1010            | 13                  |
| 1011            | 14                  |
| 1100            | 15                  |
| 1101            | 16                  |

**Table 20.4. USART Stop Bits**

| STOP BITS [1:0] | Number of Stop bits |
|-----------------|---------------------|
| 00              | 0.5                 |
| 01              | 1 (Default)         |
| 10              | 1.5                 |
| 11              | 2                   |

The order in which the data bits are transmitted and received is defined by MSBF in USARTn\_CTRL. When MSBF is cleared, data in a frame is sent and received with the least significant bit first. When it is set, the most significant bit comes first.

The frame format used by the transmitter can be inverted by setting TXINV in USARTn\_CTRL, and the format expected by the receiver can be inverted by setting RXINV in USARTn\_CTRL. These bits affect the entire frame, not only the data bits. An inverted frame has a low idle state, a high start-bit, inverted data and parity bits, and low stop-bits.

### 20.3.2.2 Parity Bit Calculation and Handling

When parity bits are enabled, hardware automatically calculates and inserts any parity bits into outgoing frames, and verifies the received parity bits in incoming frames. This is true for both asynchronous and synchronous modes, even though it is mostly used in asynchronous communication. The possible parity modes are defined in [Table 20.5 USART Parity Bits on page 566](#). When even parity is chosen, a parity bit is inserted to make the number of high bits (data + parity) even. If odd parity is chosen, the parity bit makes the total number of high bits odd.

**Table 20.5. USART Parity Bits**

| PARITY BITS [1:0] | Description             |
|-------------------|-------------------------|
| 00                | No parity bit (Default) |
| 01                | Reserved                |
| 10                | Even parity             |
| 11                | Odd parity              |

### 20.3.2.3 Clock Generation

The USART clock defines the transmission and reception data rate. When operating in asynchronous mode, the baud rate (bit-rate) is given by [Figure 20.3 USART Baud Rate on page 567](#).

$$br = f_{PCLK}/(\text{oversample} \times (1 + \text{USARTn\_CLKDIV}/256))$$

**Figure 20.3. USART Baud Rate**

where  $f_{PCLK}$  is the peripheral clock ( $PCLK_{USARTn}$ ) frequency and oversample is the oversampling rate as defined by OVS in  $\text{USARTn\_CTRL}$ , see [Table 20.6 USART Oversampling on page 567](#).

**Table 20.6. USART Oversampling**

| OVS [1:0] | oversample |
|-----------|------------|
| 00        | 16         |
| 01        | 8          |
| 10        | 6          |
| 11        | 4          |

The USART has a fractional clock divider to allow the USART clock to be controlled more accurately than what is possible with a standard integral divider.

The clock divider used in the USART is a 20-bit value, with a 15-bit integral part and an 5-bit fractional part. The fractional part is configured in the lower 5 bits of DIV in  $\text{USART\_CLKDIV}$ . The lowest achievable baud rate at 32 MHz is about 61 bauds/sec.

Fractional clock division is implemented by distributing the selected fraction over four baud periods. The fractional part of the divider tells how many of these periods should be extended by one peripheral clock cycle.

Given a desired baud rate  $br_{desired}$ , the clock divider  $\text{USARTn\_CLKDIV}$  can be calculated by using [Figure 20.4 USART Desired Baud Rate on page 567](#):

$$\text{USARTn\_CLKDIV} = 256 \times (f_{PCLK}/(\text{oversample} \times br_{desired})) - 1$$

**Figure 20.4. USART Desired Baud Rate**

[Table 20.7 USART Baud Rates @ 4MHz Peripheral Clock with 20 bit CLKDIV on page 567](#) shows a set of desired baud rates and how accurately the USART is able to generate these baud rates when running at a 4 MHz peripheral clock, using 16x or 8x oversampling.

**Table 20.7. USART Baud Rates @ 4MHz Peripheral Clock with 20 bit CLKDIV**

| Desired baud rate [baud/s] | USARTn_OVS =00                       |                           |         | USARTn_OVS =01                       |                           |         |
|----------------------------|--------------------------------------|---------------------------|---------|--------------------------------------|---------------------------|---------|
|                            | USARTn_CLKDIV/256 (to 32nd position) | Actual baud rate [baud/s] | Error % | USARTn_CLKDIV/256 (to 32nd position) | Actual baud rate [baud/s] | Error % |
| 600                        | 415,6563                             | 600,015                   | 0,003   | 832,3438                             | 599,9925                  | -0,001  |
| 1200                       | 207,3438                             | 1199,94                   | -0,005  | 415,6563                             | 1200,03                   | 0,003   |
| 2400                       | 103,1563                             | 2400,24                   | 0,010   | 207,3438                             | 2399,88                   | -0,005  |
| 4800                       | 51,09375                             | 4799,04                   | -0,020  | 103,1563                             | 4800,48                   | 0,010   |
| 9600                       | 25,03125                             | 9603,842                  | 0,040   | 51,09375                             | 9598,08                   | -0,020  |
| 14400                      | 16,375                               | 14388,49                  | -0,080  | 33,71875                             | 14401,44                  | 0,010   |
| 19200                      | 12,03125                             | 19184,65                  | -0,080  | 25,03125                             | 19207,68                  | 0,040   |
| 28800                      | 7,6875                               | 28776,98                  | -0,080  | 16,375                               | 28776,98                  | -0,080  |

| Desired baud rate [baud/s] | USARTn_OVS =00                          |                           |         | USARTn_OVS =01                          |                           |         |
|----------------------------|-----------------------------------------|---------------------------|---------|-----------------------------------------|---------------------------|---------|
|                            | USARTn_CLKDIV/256<br>(to 32nd position) | Actual baud rate [baud/s] | Error % | USARTn_CLKDIV/256<br>(to 32nd position) | Actual baud rate [baud/s] | Error % |
| 38400                      | 5,5                                     | 38461,54                  | 0,160   | 12,03125                                | 38369,3                   | -0,080  |
| 57600                      | 3,34375                                 | 57553,96                  | -0,080  | 7,6875                                  | 57553,96                  | -0,080  |
| 76800                      | 2,25                                    | 76923,08                  | 0,160   | 5,5                                     | 76923,08                  | 0,160   |
| 115200                     | 1,15625                                 | 115942                    | 0,644   | 3,34375                                 | 115107,9                  | -0,080  |
| 230400                     | 0,09375                                 | 228571,4                  | -0,794  | 1,15625                                 | 231884,1                  | 0,644   |

#### 20.3.2.4 Auto Baud Detection

Setting AUTOBAUDEN in USARTn\_CLKDIV uses the first frame received to automatically set the baud rate provided that it contains 0x55 (IrDA uses 0x00). AUTOBAUDEN can be used in a simple LIN configuration to auto detect the SYNC byte. The receiver will measure the number of local clock cycles between the beginning of the START bit and the beginning of the 8th data bit. The DIV field in USARTn\_CLKDIV will be overwritten with the new value. The OVS in USARTn\_CTRL and the +1 count of the Baud Rate equation are already factored into the result that gets written into the DIV field. To restart autobaud detection, clear AUTOBAUDEN and set it high again. Since the auto baud detection is done over 8 baud times, only the upper 3 bits of the fractional part of the clock divider are populated.

#### 20.3.2.5 Data Transmission

Asynchronous data transmission is initiated by writing data to the transmit buffer using one of the methods described in [20.3.2.6 Transmit Buffer Operation](#). When the transmission shift register is empty and ready for new data, a frame from the transmit buffer is loaded into the shift register, and if the transmitter is enabled, transmission begins. When the frame has been transmitted, a new frame is loaded into the shift register if available, and transmission continues. If the transmit buffer is empty, the transmitter goes to an idle state, waiting for a new frame to become available.

Transmission is enabled through the command register USARTn\_CMD by setting TXEN, and disabled by setting TXDIS in the same command register. When the transmitter is disabled using TXDIS, any ongoing transmission is aborted, and any frame currently being transmitted is discarded. When disabled, the TX output goes to an idle state, which by default is a high value. Whether or not the transmitter is enabled at a given time can be read from TXENS in USARTn\_STATUS.

When the USART transmitter is enabled and there is no data in the transmit shift register or transmit buffer, the TXC flag in USARTn\_STATUS and the TXC interrupt flag in USARTn\_IF are set, signaling that the transmission is complete. The TXC status flag is cleared when a new frame becomes available for transmission, but the TXC interrupt flag must be cleared by software.

### 20.3.2.6 Transmit Buffer Operation

The transmit-buffer is a multiple entry FIFO buffer. A frame can be loaded into the buffer by writing to USARTn\_TXDATA, USARTn\_TXDATAx, USARTn\_TXDOUBLE or USARTn\_TXDOUBLEx. Using USARTn\_TXDATA allows 8 bits to be written to the buffer, while using USARTn\_TXDOUBLE will write 2 frames of 8 bits to the buffer. If 9-bit frames are used, the 9th bit of the frames will in these cases be set to the value of BIT8DV in USARTn\_CTRL.

To set the 9th bit directly and/or use transmission control, USARTn\_TXDATAx and USARTn\_TXDOUBLEx must be used. USARTn\_TXDATAx allows 9 data bits to be written, as well as a set of control bits regarding the transmission of the written frame. Every frame in the buffer is stored with 9 data bits and additional transmission control bits. USARTn\_TXDOUBLEx allows two frames, complete with control bits to be written at once. When data is written to the transmit buffer using USARTn\_TXDATAx and USARTn\_TXDOUBLEx, the 9th bit(s) written to these registers override the value in BIT8DV in USARTn\_CTRL, and alone define the 9th bits that are transmitted if 9-bit frames are used. [Figure 20.5 USART Transmit Buffer Operation on page 569](#) shows the basics of the transmit buffer when DATABITS in USARTn\_FRAME is configured to less than 10 bits.



**Figure 20.5. USART Transmit Buffer Operation**

When writing more frames to the transmit buffer than there is free space for, the TXOF interrupt flag in USARTn\_IF will be set, indicating the overflow. The data already in the transmit buffer is preserved in this case, and no data is written.

In addition to the interrupt flag TXC in USARTn\_IF and status flag TXC in USARTn\_STATUS which are set when the transmission is complete, TXBL in USARTn\_STATUS and the TXBL interrupt flag in USARTn\_IF are used to indicate the level of the transmit buffer. TXBIL in USARTn\_CTRL controls the level at which these bits are set. If TXBIL is cleared, they are set whenever the transmit buffer becomes empty, and if TXBIL is set, they are set whenever the transmit buffer goes from full to half-full or empty. Both the TXBL status flag and the TXBL interrupt flag are cleared automatically when their condition becomes false.

The transmit buffer, including the transmit shift register can be cleared by setting CLEARTX in USARTn\_CMD. This will prevent the USART from transmitting the data in the buffer and shift register, and will make them available for new data. Any frame currently being transmitted will not be aborted. Transmission of this frame will be completed.

### 20.3.2.7 Frame Transmission Control

The transmission control bits, which can be written using USARTn\_TXDATAx and USARTn\_TXDOUBLEx, affect the transmission of the written frame. The following options are available:

- Generate break: By setting TXBREAK, the output will be held low during the stop-bit period to generate a framing error. A receiver that supports break detection detects this state, allowing it to be used e.g. for framing of larger data packets. The line is driven high before the next frame is transmitted so the next start condition can be identified correctly by the recipient. Continuous breaks lasting longer than a USART frame are thus not supported by the USART. GPIO can be used for this.
- Disable transmitter after transmission: If TXDISAT is set, the transmitter is disabled after the frame has been fully transmitted.
- Enable receiver after transmission: If RXENAT is set, the receiver is enabled after the frame has been fully transmitted. It is enabled in time to detect a start-bit directly after the last stop-bit has been transmitted.
- Unblock receiver after transmission: If UBRXAT is set, the receiver is unblocked and RXBLOCK is cleared after the frame has been fully transmitted.
- Tristate transmitter after transmission: If TXTRIAT is set, TXTRI is set after the frame has been fully transmitted, tristating the transmitter output. Tristating of the output can also be performed automatically by setting AUTOTRI. If AUTOTRI is set TXTRI is always read as 0.

**Note:** When in SmartCard mode with repeat enabled, none of the actions, except generate break, will be performed until the frame is transmitted without failure. Generation of a break in SmartCard mode with repeat enabled will cause the USART to detect a NACK on every frame.

### 20.3.2.8 Data Reception

Data reception is enabled by setting RXEN in USARTn\_CMD. When the receiver is enabled, it actively samples the input looking for a transition from high to low indicating the start baud of a new frame. When a start baud is found, reception of the new frame begins if the receive shift register is empty and ready for new data. When the frame has been received, it is pushed into the receive buffer, making the shift register ready for another frame of data, and the receiver starts looking for another start baud. If the receive buffer is full, the received frame remains in the shift register until more space in the receive buffer is available. If an incoming frame is detected while both the receive buffer and the receive shift register are full, the data in the shift register is overwritten, and the RXOF interrupt flag in USARTn\_IF is set to indicate the buffer overflow.

The receiver can be disabled by setting the command bit RXDIS in USARTn\_CMD. Any frame currently being received when the receiver is disabled is discarded. Whether or not the receiver is enabled at a given time can be read out from RXENS in USARTn\_STATUS.

### 20.3.2.9 Receive Buffer Operation

When data becomes available in the receive buffer, the RXDATAV flag in USARTn\_STATUS, and the RXDATAV interrupt flag in USARTn\_IF are set, and when the buffer becomes full, RXFULL in USARTn\_STATUS and the RXFULL interrupt flag in USARTn\_IF are set. The status flags RXDATAV and RXFULL are automatically cleared by hardware when their condition is no longer true. This also goes for the RXDATAV interrupt flag, but the RXFULL interrupt flag must be cleared by software. When the RXFULL flag is set, notifying that the buffer is full, space is still available in the receive shift register for one more frame.

Data can be read from the receive buffer in a number of ways. USARTn\_RXDATA gives access to the 8 least significant bits of the received frame, and USARTn\_RXDOUBLE makes it possible to read the 8 least significant bits of two frames at once, pulling two frames from the buffer. To get access to the 9th, most significant bit, USARTn\_RXDATAX must be used. This register also contains status information regarding the frame. USARTn\_RXDOUBLEXP can be used to get two frames complete with the 9th bits and status bits.

When a frame is read from the receive buffer using USARTn\_RXDATA or USARTn\_RXDATAX, the frame is pulled out of the buffer, making room for a new frame. USARTn\_RXDOUBLE and USARTn\_RXDOUBLEXP pull two frames out of the buffer. If an attempt is done to read more frames from the buffer than what is available, the RXUF interrupt flag in USARTn\_IF is set to signal the underflow, and the data read from the buffer is undefined.

Frames can be read from the receive buffer without removing the data by using USARTn\_RXDATAXP and USARTn\_RXDOUBLEXP. USARTn\_RXDATAXP gives access the first frame in the buffer with status bits, while USARTn\_RXDOUBLEXP gives access to both frames with status bits. The data read from these registers when the receive buffer is empty is undefined. If the receive buffer contains one valid frame, the first frame in USARTn\_RXDOUBLEXP will be valid. No underflow interrupt is generated by a read using these registers, i.e. RXUF in USARTn\_IF is never set as a result of reading from USARTn\_RXDATAXP or USARTn\_RXDOUBLEXP.

The basic operation of the receive buffer when DATABITS in USARTn\_FRAME is configured to less than 10 bits is shown in [Figure 20.6 USART Receive Buffer Operation on page 571](#).



**Figure 20.6. USART Receive Buffer Operation**

The receive buffer, including the receive shift register can be cleared by setting CLEARRX in USARTn\_CMD. Any frame currently being received will not be discarded.

### 20.3.2.10 Blocking Incoming Data

When using hardware frame recognition, as detailed in [20.3.2.20 Multi-Processor Mode](#) and [20.3.2.21 Collision Detection](#), it is necessary to be able to let the receiver sample incoming frames without passing the frames to software by loading them into the receive buffer. This is accomplished by blocking incoming data.

Incoming data is blocked as long as RXBLOCK in USARTn\_STATUS is set. When blocked, frames received by the receiver will not be loaded into the receive buffer, and software is not notified by the RXDATAV flag in USARTn\_STATUS or the RXDATAV interrupt flag in USARTn\_IF at their arrival. For data to be loaded into the receive buffer, RXBLOCK must be cleared in the instant a frame is fully received by the receiver. RXBLOCK is set by setting RXBLOCKEN in USARTn\_CMD and disabled by setting RXBLOCKDIS also in USARTn\_CMD. There is one exception where data is loaded into the receive buffer even when RXBLOCK is set. This is when an address frame is received when operating in multi-processor mode. See [20.3.2.20 Multi-Processor Mode](#) for more information.

Frames received containing framing or parity errors will not result in the FERR and PERR interrupt flags in USARTn\_IF being set while RXBLOCK in USARTn\_STATUS is set. Hardware recognition is not applied to these erroneous frames, and they are silently discarded.

**Note:** If a frame is received while RXBLOCK in USARTn\_STATUS is cleared, but stays in the receive shift register because the receive buffer is full, the received frame will be loaded into the receive buffer when space becomes available even if RXBLOCK is set at that time. The overflow interrupt flag RXOF in USARTn\_IF will be set if a frame in the receive shift register, waiting to be loaded into the receive buffer is overwritten by an incoming frame even though RXBLOCK in USARTn\_STATUS is set.

### 20.3.2.11 Clock Recovery and Filtering

The receiver samples the incoming signal at a rate 16, 8, 6 or 4 times higher than the given baud rate, depending on the oversampling mode given by OVS in USARTn\_CTRL. Lower oversampling rates make higher baud rates possible, but give less room for errors.

When a high-to-low transition is registered on the input while the receiver is idle, this is recognized as a start-bit, and the baud rate generator is synchronized with the incoming frame.

For oversampling modes 16, 8 and 6, every bit in the incoming frame is sampled three times to gain a level of noise immunity. These samples are aimed at the middle of the bit-periods, as visualized in [Figure 20.7 USART Sampling of Start and Data Bits on page 573](#). With OVS=0 in USARTn\_CTRL, the start and data bits are thus sampled at locations 8, 9 and 10 in the figure, locations 4, 5 and 6 for OVS=1 and locations 3, 4, and 5 for OVS=2. The value of a sampled bit is determined by majority vote. If two or more of the three bit-samples are high, the resulting bit value is high. If the majority is low, the resulting bit value is low.

Majority vote is used for all oversampling modes except 4x oversampling. In this mode, a single sample is taken at position 3 as shown in [Figure 20.7 USART Sampling of Start and Data Bits on page 573](#).

Majority vote can be disabled by setting MVDIS in USARTn\_CTRL.

If the value of the start bit is found to be high, the reception of the frame is aborted, filtering out false start bits possibly generated by noise on the input.



**Figure 20.7. USART Sampling of Start and Data Bits**

If the baud rate of the transmitter and receiver differ, the location each bit is sampled will be shifted towards the previous or next bit in the frame. This is acceptable for small errors in the baud rate, but for larger errors, it will result in transmission errors.

When the number of stop bits is 1 or more, stop bits are sampled like the start and data bits as seen in [Figure 20.8 USART Sampling of Stop Bits when Number of Stop Bits are 1 or More on page 574](#). When a stop bit has been detected by sampling at positions 8, 9 and 10 for normal mode, or 4, 5 and 6 for smart mode, the USART is ready for a new start bit. As seen in [Figure 20.8 USART Sampling of Stop Bits when Number of Stop Bits are 1 or More on page 574](#), a stop-bit of length 1 normally ends at c, but the next frame will be received correctly as long as the start-bit comes after position a for OVS=0 and OVS=3, and b for OVS=1 and OVS=2.



**Figure 20.8. USART Sampling of Stop Bits when Number of Stop Bits are 1 or More**

When working with stop bit lengths of half a baud period, the above sampling scheme no longer suffices. In this case, the stop-bit is not sampled, and no framing error is generated in the receiver if the stop-bit is not generated. The line must still be driven high before the next start bit however for the USART to successfully identify the start bit.

#### 20.3.2.12 Parity Error

When parity bits are enabled, a parity check is automatically performed on incoming frames. When a parity error is detected in an incoming frame, the data parity error bit PERR in the frame is set, as well as the interrupt flag PERR in USARTn\_IF. Frames with parity errors are loaded into the receive buffer like regular frames.

PERR can be accessed by reading the frame from the receive buffer using the USARTn\_RXDATAx, USARTn\_RXDATAXP, USARTn\_RXDOUBLEx or USARTn\_RXDOUBLEXP registers.

If ERRSTX in USARTn\_CTRL is set, the transmitter is disabled on received parity and framing errors. If ERRSRX in USARTn\_CTRL is set, the receiver is disabled on parity and framing errors.

#### 20.3.2.13 Framing Error and Break Detection

A framing error is the result of an asynchronous frame where the stop bit was sampled to a value of 0. This can be the result of noise and baud rate errors, but can also be the result of a break generated by the transmitter on purpose.

When a framing error is detected in an incoming frame, the framing error bit FERR in the frame is set. The interrupt flag FERR in USARTn\_IF is also set. Frames with framing errors are loaded into the receive buffer like regular frames.

FERR can be accessed by reading the frame from the receive buffer using the USARTn\_RXDATAx, USARTn\_RXDATAXP, USARTn\_RXDOUBLEx or USARTn\_RXDOUBLEXP registers.

If ERRSTX in USARTn\_CTRL is set, the transmitter is disabled on parity and framing errors. If ERRSRX in USARTn\_CTRL is set, the receiver is disabled on parity and framing errors.

### 20.3.2.14 Local Loopback

The USART receiver samples U(S)n\_RX by default, and the transmitter drives U(S)n\_TX by default. This is not the only option however. When LOOPBK in USARTn\_CTRL is set, the receiver is connected to the U(S)n\_TX pin as shown in [Figure 20.9 USART Local Loopback on page 575](#). This is useful for debugging, as the USART can receive the data it transmits, but it is also used to allow the USART to read and write to the same pin, which is required for some half duplex communication modes. In this mode, the U(S)n\_TX pin must be enabled as an output in the GPIO.



**Figure 20.9. USART Local Loopback**

### 20.3.2.15 Asynchronous Half Duplex Communication

When doing full duplex communication, two data links are provided, making it possible for data to be sent and received at the same time. In half duplex mode, data is only sent in one direction at a time. There are several possible half duplex setups, as described in the following sections.

### 20.3.2.16 Single Data-link

In this setup, the USART both receives and transmits data on the same pin. This is enabled by setting LOOPBK in USARTn\_CTRL, which connects the receiver to the transmitter output. Because they are both connected to the same line, it is important that the USART transmitter does not drive the line when receiving data, as this would corrupt the data on the line.

When communicating over a single data-link, the transmitter must thus be tristated whenever not transmitting data. This is done by setting the command bit TXTRIEN in USARTn\_CMD, which tristates the transmitter. Before transmitting data, the command bit TXTRI-DIS, also in USARTn\_CMD, must be set to enable transmitter output again. Whether or not the output is tristated at a given time can be read from TXTRI in USARTn\_STATUS. If TXTRI is set when transmitting data, the data is shifted out of the shift register, but is not put out on U(S)n\_TX.

When operating a half duplex data bus, it is common to have a main bus controller, which first transmits a request to one of the secondary devices on the bus, then receives a reply. In this case, the frame transmission control bits, which can be set by writing to USARTn\_TXDATAX, can be used to make the USART automatically disable transmission, tristate the transmitter and enable reception when the request has been transmitted, making it ready to receive a response from the secondary device.

The timer, [20.3.10 Timer](#), can also be used to add delay between the RX and TX frames so that the interrupt service routine has time to process data that was just received before transmitting more data. Also hardware flow control is another method to insert time for processing the frame. RTS and CTS can be used to halt either the link partner's transmitter or the local transmitter. See the section on hardware flow control, [20.3.4 Hardware Flow Control](#), for more details.

Tristating the transmitter can also be performed automatically by the USART by using AUTOTRI in USARTn\_CTRL. When AUTOTRI is set, the USART automatically tristates U(S)n\_TX whenever the transmitter is idle, and enables transmitter output when the transmitter goes active. If AUTOTRI is set TXTRI is always read as 0.

**Note:** Another way to tristate the transmitter is to enable wired-and or wired-or mode in GPIO. For wired-and mode, outputting a 1 will be the same as tristating the output, and for wired-or mode, outputting a 0 will be the same as tristating the output. This can only be done on buses with a pull-up or pull-down resistor respectively.

### 20.3.2.17 Single Data-link with External Driver

Some communication schemes, such as RS-485 rely on an external driver. Here, the driver has an extra input which enables it, and instead of tristating the transmitter when receiving data, the external driver must be disabled.

This can be done manually by assigning a GPIO to turn the driver on or off, or it can be handled automatically by the USART. If AUTOCS in USARTn\_CTRL is set, the USn\_CS output is automatically activated a configurable number of baud periods before the transmitter starts transmitting data, and deactivated a configurable number of baud periods after the last bit has been transmitted and there is no more data in the transmit buffer to transmit. The number of baud periods are controlled by CSSETUP and CSHOLD in USARTn\_TIMING. This feature can be used to turn the external driver on when transmitting data, and turn it off when the data has been transmitted.

The timer, [20.3.10 Timer](#), can also be used to configure CSSETUP and CSHOLD values between 1 to 256 baud-times by using TCMPVAL0, TCMPVAL1, or TCMPVAL2 for the TX sequencer.

USn\_CS is immediately deasserted when the transmitter becomes disabled.

**Note:** When using CSSETUP in asynchronous mode with AUTOCS (USARTn\_CTRL.SYNC = 0, USARTn\_CTRL.AUTOCS = 1), TXDELAY in USARTn\_TIMING should be set to 1.

[Figure 20.10 USART Half Duplex Communication with External Driver on page 576](#) shows an example configuration where USn\_CS is used to automatically enable and disable an external driver.



**Figure 20.10. USART Half Duplex Communication with External Driver**

The USn\_CS output is active low by default, but its polarity can be changed with CSINV in USARTn\_CTRL. AUTOCS works regardless of which mode the USART is in, so this functionality can also be used for automatic chip select when in synchronous mode (e.g. SPI).

### 20.3.2.18 Two Data-links

Some limited devices only support half duplex communication even though two data links are available. In this case software is responsible for making sure data is not transmitted when incoming data is expected.

TXARXnEN in USARTn\_TRIGCTRL may be used to automatically start transmission after the end of the RX frame plus any TXSTDELAY and CSSETUP delay in USARTn\_TIMING. For enabling the receiver either use RXENAT in USARTn\_RXDATAx or RXATXnEN in USARTn\_TRIGCTRL.

### 20.3.2.19 Large Frames

As each frame in the transmit and receive buffers holds a maximum of 9 bits, both the elements in the buffers are combined when working with USART-frames of 10 or more data bits.

To transmit such a frame, at least two elements must be available in the transmit buffer. If only one element is available, the USART will wait for the second element before transmitting the combined frame. Both the elements making up the frame are consumed when transmitting such a frame.

When using large frames, the 9th bits in the buffers are unused. For an 11 bit frame, the 8 least significant bits are thus taken from the first element in the buffer, and the 3 remaining bits are taken from the second element as shown in [Figure 20.11 USART Transmission of Large Frames on page 577](#). The first element in the transmit buffer, i.e. element 0 in [Figure 20.11 USART Transmission of Large Frames on page 577](#) is the first element written to the FIFO, or the least significant byte when writing two bytes at a time using USARTn\_TXDOUBLE.



**Figure 20.11. USART Transmission of Large Frames**

As shown in [Figure 20.11 USART Transmission of Large Frames on page 577](#), frame transmission control bits are taken from the second element in FIFO.

The two buffer elements can be written at the same time using the USARTn\_TXDOUBLE or USARTn\_TXDOUBLEX register. The TXDATAx0 bitfield then refers to buffer element 0, and TXDATAx1 refers to buffer element 1.



**Figure 20.12. USART Transmission of Large Frames, MSBF**

[Figure 20.12 USART Transmission of Large Frames, MSBF on page 577](#) illustrates the order of the transmitted bits when an 11 bit frame is transmitted with MSBF set. If MSBF is set and the frame is smaller than 10 bits, only the contents of transmit buffer 0 will be transmitted.

When receiving a large frame, BYTESWAP in USARTn\_CTRL determines the order the way the large frame is split into the two buffer elements. If BYTESWAP is cleared, the least significant 8 bits of the received frame are loaded into the first element of the receive buffer, and the remaining bits are loaded into the second element, as shown in [Figure 20.13 USART Reception of Large Frames on page 578](#). The first byte read from the buffer thus contains the 8 least significant bits. Set BYTESWAP to reverse the order.

The status bits are loaded into both elements of the receive buffer. The frame is not moved from the receive shift register before there are two free spaces in the receive buffer.



**Figure 20.13. USART Reception of Large Frames**

The two buffer elements can be read at the same time using the USARTn\_RXDOUBLE or USARTn\_RXDOUBLEX register. RXDATA0 then refers to buffer element 0 and RXDATA1 refers to buffer element 1.

Large frames can be used in both asynchronous and synchronous modes.

#### 20.3.2.20 Multi-Processor Mode

To simplify communication between multiple processors, the USART supports a special multi-processor mode. In this mode the 9th data bit in each frame is used to indicate whether the content of the remaining 8 bits is data or an address.

When multi-processor mode is enabled, an incoming 9-bit frame with the 9th bit equal to the value of MPAB in USARTn\_CTRL is identified as an address frame. When an address frame is detected, the MPAF interrupt flag in USARTn\_IF is set, and the address frame is loaded into the receive register. This happens regardless of the value of RXBLOCK in USARTn\_STATUS.

Multi-processor mode is enabled by setting MPM in USARTn\_CTRL, and the value of the 9th bit in address frames can be set in MPAB. Note that the receiver must be enabled for address frames to be detected. The receiver can be blocked however, preventing data from being loaded into the receive buffer while looking for address frames.

When a device has received an address frame and wants to receive the following data, it must make sure the receiver is unblocked before the next frame has been completely received in order to prevent data loss.

BIT8DV in USARTn\_CTRL can be used to specify the value of the 9th bit without writing to the transmit buffer with USARTn\_TXDATAx or USARTn\_TXDOUBLEX, giving higher efficiency in multi-processor mode, as the 9th bit is only set when writing address frames, and 8-bit writes to the USART can be used when writing the data frames.

#### 20.3.2.21 Collision Detection

The USART supports a basic form of collision detection. When the receiver is connected to the output of the transmitter, either by using the LOOPBK bit in USARTn\_CTRL or through an external connection, this feature can be used to detect whether data transmitted on the bus by the USART did get corrupted by a simultaneous transmission by another device on the bus.

For collision detection to be enabled, CCEN in USARTn\_CTRL must be set, and the receiver enabled. The data sampled by the receiver is then continuously compared with the data output by the transmitter. If they differ, the CCF interrupt flag in USARTn\_IF is set. The collision check includes all bits of the transmitted frames. The CCF interrupt flag is set once for each bit sampled by the receiver that differs from the bit output by the transmitter. When the transmitter output is disabled, i.e. the transmitter is tristated, collisions are not registered.

### 20.3.2.22 SmartCard Mode

In SmartCard mode, the USART supports the ISO 7816 I/O line T0 mode. With exception of the stop-bits (guard time), the 7816 data frame is equal to the regular asynchronous frame. In this mode, the receiver pulls the line low for one baud, half a baud into the guard time to indicate a parity error. This NAK can for instance be used by the transmitter to re-transmit the frame. SmartCard mode is a half duplex asynchronous mode, so the transmitter must be tristated whenever not transmitting data.

To enable SmartCard mode, set SCMODE in USARTn\_CTRL, set the number of databits in a frame to 8, and configure the number of stopbits to 1.5 by writing to STOPBITS in USARTn\_FRAME.

The SmartCard mode relies on half duplex communication on a single line, so for it to work, both the receiver and transmitter must work on the same line. This can be achieved by setting LOOPBK in USARTn\_CTRL or through an external connection. The TX output should be configured as open-drain in the GPIO module.

When no parity error is identified by the receiver, the data frame is as shown in [Figure 20.14 USART ISO 7816 Data Frame Without Error on page 579](#). The frame consists of 8 data bits, a parity bit, and 2 stop bits. The transmitter does not drive the output line during the guard time.



**Figure 20.14. USART ISO 7816 Data Frame Without Error**

If a parity error is detected by the receiver, it pulls the line I/O line low after half a stop bit, see [Figure 20.15 USART ISO 7816 Data Frame With Error on page 579](#). It holds the line low for one bit-period before it releases the line. In this case, the guard time is extended by one bit period before a new transmission can start, resulting in a total of 3 stop bits.



**Figure 20.15. USART ISO 7816 Data Frame With Error**

On a parity error, the NAK is generated by hardware. The NAK generated by the receiver is sampled as the stop-bit of the frame. Because of this, parity errors when in SmartCard mode are reported with both a parity error and a framing error.

When transmitting a T0 frame, the USART receiver on the transmitting side samples position 16, 17 and 18 in the stop-bit to detect the error signal when in 16x oversampling mode as shown in [Figure 20.16 USART SmartCard Stop Bit Sampling on page 580](#). Sampling at this location places the stop-bit sample in the middle of the bit-period used for the error signal (NAK).

If a NAK is transmitted by the receiver, it will thus appear as a framing error at the transmitter, and the FERR interrupt flag in USARTn\_IF will be set. If SCRETRANS USARTn\_CTRL is set, the transmitter will automatically retransmit a NACK'ed frame. The transmitter will retransmit the frame until it is ACK'ed by the receiver. This only works when the number of databits in a frame is configured to 8.

Set SKIPERRF in USARTn\_CTRL to make the receiver discard frames with parity errors. The PERR interrupt flag in USARTn\_IF is set when a frame is discarded because of a parity error.



**Figure 20.16. USART SmartCard Stop Bit Sampling**

For communication with a SmartCard, a clock signal needs to be generated for the card. This clock output can be generated using one of the timers. See the ISO 7816 specification for more info on this clock signal.

SmartCard T1 mode is also supported. The T1 frame format used is the same as the asynchronous frame format with parity bit enabled and one stop bit. The USART must then be configured to operate in asynchronous half duplex mode.

### 20.3.3 Synchronous Operation

Most of the features in asynchronous mode are available in synchronous mode. Multi-processor mode can be enabled for 9-bit frames, loopback is available and collision detection can be performed.

#### 20.3.3.1 Frame Format

The frames used in synchronous mode need no start and stop bits since a single clock is available to all parts participating in the communication. Parity bits cannot be used in synchronous mode.

The USART supports frame lengths of 4 to 16 bits per frame. Larger frames can be simulated by transmitting multiple smaller frames, i.e. a 22 bit frame can be sent using two 11-bit frames, and a 21 bit frame can be generated by transmitting three 7-bit frames. The number of bits in a frame is set using DATABITS in USARTn\_FRAME.

The frames in synchronous mode are by default transmitted with the least significant bit first like in asynchronous mode. The bit-order can be reversed by setting MSBF in USARTn\_CTRL.

The frame format used by the transmitter can be inverted by setting TXINV in USARTn\_CTRL, and the format expected by the receiver can be inverted by setting RXINV, also in USARTn\_CTRL.

### 20.3.3.2 Clock Generation

The bit-rate in synchronous mode is given by [Figure 20.17 USART Synchronous Mode Bit Rate on page 581](#). As in the case of asynchronous operation, the clock division factor have a 15-bit integral part and a 5-bit fractional part.

$$br = f_{PCLK}/(2 \times (1 + \text{USARTn\_CLKDIV}/256))$$

**Figure 20.17. USART Synchronous Mode Bit Rate**

Given a desired baud rate  $br_{desired}$ , the clock divider  $\text{USARTn\_CLKDIV}$  can be calculated using [Figure 20.18 USART Synchronous Mode Clock Division Factor on page 581](#)

$$\text{USARTn\_CLKDIV} = 256 \times (f_{PCLK}/(2 \times br_{desired}) - 1)$$

**Figure 20.18. USART Synchronous Mode Clock Division Factor**

When the USART operates as a synchronous main interface, the highest possible bit rate is half the peripheral clock rate. When operating as a secondary interface however, the highest bit rate is one sixth of the peripheral clock:

- Main interface mode:  $br_{max} = f_{PCLK}/2$
- Secondary interface mode:  $br_{max} = f_{PCLK}/6$

On every clock edge data on the data lines, MOSI and MISO, is either set up or sampled. When  $\text{CLKPHA}$  in  $\text{USARTn\_CTRL}$  is cleared, data is sampled on the leading clock edge and set-up is done on the trailing edge. If  $\text{CLKPHA}$  is set however, data is set-up on the leading clock edge, and sampled on the trailing edge. In addition to this, the polarity of the clock signal can be changed by setting  $\text{CLKPOL}$  in  $\text{USARTn\_CTRL}$ , which also defines the idle state of the clock. This results in four different modes which are summarized in [Table 20.8 USART SPI Modes on page 581](#). [Figure 20.19 USART SPI Timing on page 581](#) shows the resulting timing of data set-up and sampling relative to the bus clock.

**Table 20.8. USART SPI Modes**

| SPI mode | CLKPOL | CLKPHA | Leading edge    | Trailing edge   |
|----------|--------|--------|-----------------|-----------------|
| 0        | 0      | 0      | Rising, sample  | Falling, set-up |
| 1        | 0      | 1      | Rising, set-up  | Falling, sample |
| 2        | 1      | 0      | Falling, sample | Rising, set-up  |
| 3        | 1      | 1      | Falling, set-up | Rising, sample  |



**Figure 20.19. USART SPI Timing**

If CPHA=1, the TX underflow flag, TXUF, will be set on the first setup clock edge of a frame in secondary mode if TX data is not available. If CPHA=0, TXUF is set if data is not available in the transmit buffer three PCLK cycles prior to the first sample clock edge. The RXDATAV flag is updated on the last sample clock edge of a transfer, while the RX overflow interrupt flag, RXOF, is set on the first

sample clock edge if the receive buffer overflows. When a transfer has been performed, interrupt flags TXBL and TXC are updated on the first setup clock edge of the succeeding frame, or when CS is deasserted.

### 20.3.3.3 Synchronous Main Interface Mode

When configured as a main interface, the USART is in full control of the data flow on the synchronous bus. When operating in full duplex mode, the secondary devices cannot transmit data to the main device without the main device transmitting to the secondary. The main device outputs the bus clock on USn\_CLK.

Communication starts whenever there is data in the transmit buffer and the transmitter is enabled. The USART clock then starts, and the main device shifts bits out from the transmit shift register using the internal clock.

When there are no more frames in the transmit buffer and the transmit shift register is empty, the clock stops, and communication ends. When the receiver is enabled, it samples data using the internal clock when the transmitter transmits data. Operation of the RX and TX buffers is as in asynchronous mode.

### 20.3.3.4 Operation of USn\_CS Pin

When operating as a synchronous main interface, the USn\_CS pin can have one of two functions, or it can be disabled.

If USn\_CS is configured as an output, it can be used to automatically generate a chip select for a secondary device by setting AUTOCS in USARTn\_CTRL. If AUTOCS is set, USn\_CS is activated before a transmission begins, and deactivated after the last bit has been transmitted and there is no more data in the transmit buffer.

The time between when CS is asserted and the first bit is transmitted can be controlled using the USART Timer and with CSSETUP in USARTn\_TIMING. Any of the three comparators can be used to set this delay. If new data is ready for transmission before CS is deasserted, the data is sent without deasserting CS in between. CSHOLD in USARTn\_TIMING keeps CS asserted after the end of frame for the number of baud-times specified.

By default, USn\_CS is active low, but its polarity can be inverted by setting CSINV in USARTn\_CTRL.

When USn\_CS is configured as an input, it can be used by another synchronous main device that wants control of the bus to make the USART release it. When USn\_CS is driven low, or high if CSINV is set, the interrupt flag SSM in USARTn\_IF is set, and if CSMA in USARTn\_CTRL is set, the USART goes to secondary mode.

### 20.3.3.5 AUTOTX

The main device on a synchronous bus is required to transmit data to a secondary device in order to receive data from that device. In some cases, only a few words are transmitted and a lot of data is then received from the secondary device. In that case, one solution is to keep feeding the TX with data to transmit, but that consumes system bandwidth. Instead AUTOTX can be used.

When AUTOTX in USARTn\_CTRL is set, the USART transmits data as long as there is available space in the RX shift register for the chosen frame size. This happens even though there is no data in the TX buffer. The TX underflow interrupt flag TXUF in USARTn\_IF is set on the first word that is transmitted which does not contain valid data.

During AUTOTX the USART will always send the previous sent bit, thus reducing the number of transitions on the TX output. So if the last bit sent was a 0, 0's will be sent during AUTOTX and if the last bit sent was a 1, 1's will be sent during AUTOTX.

### 20.3.3.6 Synchronous Secondary Interface Mode

When the USART is in synchronous secondary interface mode, data transmission is not controlled by the USART, but by an external synchronous main device. The USART is therefore not able to initiate a transmission, and has no control over the number of bytes written to the external main device.

The output and input to the USART are also swapped when in secondary mode, making the receiver take its input from USn\_TX (MOSI) and the transmitter drive USn\_RX (MISO).

To transmit data when in secondary mode, the device must load data into the transmit buffer and enable the transmitter. The data will remain in the USART until the main device starts a transmission by pulling the USn\_CS input low and transmitting data. For every frame transmitted from main to secondary device, a frame is transferred from secondary to main as well. After a transmission, MISO remains in the same state as the last bit transmitted. This also applies if the main transmits to the secondary and the secondary TX buffer is empty.

If the transmitter is enabled in secondary synchronous mode and the main device starts transmission of a frame, the underflow interrupt flag TXUF in USARTn\_IF will be set if no data is available for transmission.

If the secondary device needs to control its own chip select signal, this can be achieved by clearing CSPEN in the GPIO\_USARTn\_ROUTEEEN register. The internal chip select signal can then be controlled through CSINV in the CTRL register. The chip select signal will be CSINV inverted, i.e. if CSINV is cleared, the chip select is active and vice versa.

### 20.3.3.7 Synchronous Half Duplex Communication

Half duplex communication in synchronous mode is very similar to half duplex communication in asynchronous mode as detailed in [20.3.2.15 Asynchronous Half Duplex Communication](#). The main difference is that in this mode, the main interface must generate the bus clock even when it is not transmitting data, i.e. it must provide the secondary device with a clock to receive data. To generate the bus clock, the main device should transmit data with the transmitter tristated, i.e. TXTRI in USARTn\_STATUS set, when receiving data. If 2 bytes are expected from the secondary device, then transmit 2 bytes with the transmitter tristated, and the secondary uses the generated bus clock to transmit data to the main. TXTRI can be set by setting the TXTRIEN command bit in USARTn\_CMD.

**Note:** When operating as SPI secondary interface in half duplex mode, TX has to be tristated (not disabled) during data reception if the device is to transmit data in the current transfer.

### 20.3.3.8 I2S

I2S is a synchronous format for transmission of audio data. The frame format is 32-bit, but since data is always transmitted with MSB first, an I2S device operating with 16-bit audio may choose to only process the 16 msb of the frame, and only transmit data in the 16 msb of the frame.

In addition to the bit clock used for regular synchronous transfers, I2S mode uses a separate word clock. When operating in mono mode, with only one channel of data, the word clock pulses once at the start of each new word. In stereo mode, the word clock toggles at the start of new words, and also gives away whether the transmitted word is for the left or right audio channel; A word transmitted while the word clock is low is for the left channel, and a word transmitted while the word clock is high is for the right.

When operating in I2S mode, the CS pin is used as a the word clock. In main mode, this is automatically driven by the USART, and in secondary mode, the word clock is expected from an external main device.

### 20.3.3.9 Word Format

The general I2S word format is 32 bits wide, but the USART also supports 16-bit and 8-bit words. In addition to this, it can be specified how many bits of the word should actually be used by the USART. These parameters are given by FORMAT in USARTn\_I2SCTRL.

As an example, configuring FORMAT to using a 32-bit word with 16-bit data will make each word on the I2S bus 32-bits wide, but when receiving data through the USART, only the 16 most significant bits of each word can be read out of the USART. Similarly, only the 16 most significant bits have to be written to the USART when transmitting. The rest of the bits will be transmitted as zeroes.

### 20.3.3.10 Major Modes

The USART supports a set of different I2S formats as shown in [Table 20.9 USART I2S Modes on page 584](#), but it is not limited to these modes. MONO, JUSTIFY and DELAY in USARTn\_I2SCTRL can be mixed and matched to create an appropriate format. MONO enables mono mode, i.e. one data stream instead of two which is the default. JUSTIFY aligns data within a word on the I2S bus, either left or right which can be seen in figures [Figure 20.22 USART Left-Justified I2S Waveform on page 585](#) and [Figure 20.23 USART Right-Justified I2S Waveform on page 585](#). Finally, DELAY specifies whether a new I2S word should be started directly on the edge of the word-select signal, or one bit-period after the edge.

**Table 20.9. USART I2S Modes**

| Mode            | MONO | JUSTIFY | DELAY | CLKPOL |
|-----------------|------|---------|-------|--------|
| Regular I2S     | 0    | 0       | 1     | 0      |
| Left-Justified  | 0    | 0       | 0     | 1      |
| Right-Justified | 0    | 1       | 0     | 1      |
| Mono            | 1    | 0       | 0     | 0      |

The regular I2S waveform is shown in [Figure 20.20 USART Standard I2S Waveform on page 584](#) and [Figure 20.21 USART Standard I2S Waveform \(Reduced Accuracy\) on page 584](#). The first figure shows a waveform transmitted with full accuracy. The wordlength can be configured to 32-bit, 16-bit or 8-bit using FORMAT in USARTn\_I2SCTRL. In the second figure, I2S data is transmitted with reduced accuracy, i.e. the data transmitted has less bits than what is possible in the bus format.

Note that the msb of a word transmitted in regular I2S mode is delayed by one cycle with respect to word select



**Figure 20.20. USART Standard I2S Waveform**



**Figure 20.21. USART Standard I2S Waveform (Reduced Accuracy)**

A left-justified stream is shown in [Figure 20.22 USART Left-Justified I2S Waveform on page 585](#). Note that the MSB comes directly after the edge on the word-select signal in contradiction to the regular I2S waveform where it comes one bit-period after.



**Figure 20.22. USART Left-Justified I2S Waveform**

A right-justified stream is shown in [Figure 20.23 USART Right-Justified I2S Waveform on page 585](#). The left and right justified streams are equal when the data-size is equal to the word-width.



**Figure 20.23. USART Right-Justified I2S Waveform**

In mono-mode, the word-select signal pulses at the beginning of each word instead of toggling for each word. Mono I2S waveform is shown in [Figure 20.24 USART Mono I2S Waveform on page 585](#).



**Figure 20.24. USART Mono I2S Waveform**

### 20.3.3.11 Using I2S Mode

When using the USART in I2S mode, DATABITS in USARTn\_FRAME must be set to 8 or 16 data-bits. 8 databits can be used in all modes, and 16 can be used in the modes where the number of bytes in the I2S word is even. In addition to this, MSBF in USARTn\_CTRL should be set, and CLKPOL and CLKPHA in USARTn\_CTRL should be cleared.

The USART does not have separate TX and RX buffers for left and right data, so when using I2S in stereo mode, the application must keep track of whether the buffers contain left or right data. This can be done by observing TXBLRIGHT, RXDATAVRIGHT and RXFULLRIGHT in USARTn\_STATUS. TXBLRIGHT tells whether TX is expecting data for the left or right channel. It will be set with TXBL if right data is expected. The receiver will set RXDATAVRIGHT if there is at least one right element in the buffer, and RXFULLRIGHT if the buffer is full of right elements.

When using I2S with DMA, separate DMA requests can be used for left and right data by setting DMASPLIT in USARTn\_I2SCTRL.

In both main and secondary mode the USART always starts transmitting on the LEFT channel after being enabled. In main mode, the transmission will stop if TX becomes empty. In that case, TXC is set. Continuing the transmission in this case will make the data-stream continue where it left off. To make the USART start on the LEFT channel after going empty, disable and re-enable TX.

### 20.3.4 Hardware Flow Control

Hardware flow control can be used to hold off the link partner's transmission until RX buffer space is available. The RTS and CTS signals are enabled and configured using the GPIO\_USARTn\_ROUTEEN, GPIO\_USARTn\_RTSPROUTEEx and GPIO\_USARTn\_CTSROUTE registers. RTS is an out going signal which indicates that RX buffer space is available to receive a frame. The link partner is being requested to send its data when RTS is asserted. CTS is an incoming signal to stop the next TX data from going out. When CTS is negated, the frame currently being transmitted is completed before stopping. CTS indicates that the link partner has RX buffer space available, and the local transmitter is clear to send. Also use CTSEN in USARTn\_CTRLX to enable the CTS input into the TX sequencer. For debug use set DBGHALT in USARTn\_CTRLX which will force the RTS to request one frame from the link partner when the CPU core single steps.

### 20.3.5 Debug Halt

When DBGHALT in USART\_CTRLX is clear, RTS is only dependent on the RX buffer having space available to receive data. Incoming data is always received until both the RX buffer is full and the RX shift register is full regardless of the state of DBGHALT or chip halt. Additional incoming data is discarded. When DBGHALT is set, RTS deasserts on RX buffer full or when chip halt is high. However, a low pulse detected on chip halt will keep RTS asserted when no frame is being received. At the start of frame reception, RTS will deassert if chip halt is high and DBGHALT is set. This behavior allows single stepping to pulse the chip halt low for a cycle, and receive the next frame. The link partner must stop transmitting when RTS is deasserted, or the RX buffer could overflow. All data in the transmit buffer is sent out even when chip halt is asserted; therefore, the DMA will need to be set to stop sending the USART TX data during chip halt.

### 20.3.6 PRS-triggered Transmissions

If a transmission must be started on an event with very little delay, the PRS system can be used to trigger the transmission. The PRS channel to use as a trigger can be selected using PRSSEL in PRS\_USARTn\_TRIGGER. When a positive edge is detected on this signal, the receiver is enabled if RXTEN in USARTn\_TRIGCTRL is set, and the transmitter is enabled if TXTEN in USARTn\_TRIGCTRL is set. Only one signal input is supported by the USART.

The AUTOTX feature can also be enabled via PRS. If an external SPI device sets a pin high when there is data to be read from the device, this signal can be routed to the USART through the PRS system and be used to make the USART clock data out of the external device. If AUTOTXTEN in USARTn\_TRIGCTRL is set, the USART will transmit data whenever the PRS signal selected by PRS\_USARTn\_TRIGGER is high given that there is enough room in the RX buffer for the chosen frame size. Note that if there is no data in the TX buffer when using AUTOTX, the TX underflow interrupt will be set.

AUTOTXTEN can also be combined with TXTEN to make the USART transmit a command to the external device prior to clocking out data. To do this, disable TX using the TXDIS command, load the TX buffer with the command and enable AUTOTXTEN and TXTEN. When the selected PRS input goes high, the USART will now transmit the loaded command, and then continue clocking out while both the PRS input is high and there is room in the RX buffer.

### 20.3.7 PRS RX Input

The USART can be configured to receive data directly from a PRS channel by setting RXPRSEN in USARTn\_CTRLX. The PRS channel used is selected using PRSSEL in PRS\_USARTn\_RX.

### 20.3.8 PRS CLK Input

The USART can be configured to receive clock directly from a PRS channel by setting CLKPRSEN in USARTn\_CTRLX. The PRS channel used is selected using PRSSEL in PRS\_USARTn\_CLK. This is useful in synchronous secondary mode and can together with RX PRS input be used to input data from PRS.

### 20.3.9 DMA Support

The USART has full DMA support. The DMA controller can write to the transmit buffer using the registers USARTn\_TXDATA, USARTn\_TXDATAX, USARTn\_RXDOUBLE and USARTn\_RXDOUBLEX, and it can read from the receive buffer using the registers USARTn\_RXDATA, USARTn\_RXDATAX, USARTn\_RXDOUBLE and USARTn\_RXDOUBLEX. This enables single byte transfers, 9 bit data + control/status bits, double byte and double byte + control/status transfers both to and from the USART.

A request for the DMA controller to read from the USART receive buffer can come from the following source:

- Data available in the receive buffer
- Data available in the receive buffer and data is for the RIGHT I2S channel. Only used in I2S mode.

A write request can come from one of the following sources:

- Transmit buffer and shift register empty. No data to send.
- Transmit buffer has room for more data. This does not check the TXBIL for half full. For DMA use, it is either full or empty.
- Transmit buffer has room for RIGHT I2S data. Only used in I2S mode

Even though there are two sources for write requests to the DMA, only one should be used at a time, since the requests from both sources are cleared even though only one of the requests are used.

In some cases, it may be sensible to temporarily stop DMA access to the USART when an error such as a framing error has occurred. This is enabled by setting ERRSDMA in USARTn\_CTRL.

**Note:** For Synchronous mode full duplex operation, if both receive buffer and transmit buffer are served by DMA, to make sure receive buffer is not overflowed the settings below should be followed.

- The DMA channel that serves receive buffer should have higher priority than the DMA channel that serves transmit buffer.
- TXBL should be used as write request for transmit buffer DMA channel.
- IGNORESREQ should be set for both DMA channel.

### 20.3.10 Timer

In addition to the TX sequence timer, there is a versatile 8 bit timer that can generate up to three event pulses. These pulses can be used to create timing for a variety of uses such as RX timeout, break detection, response timeout, and RX enable delay. Transmission delay, CS setup, inter-character spacing, and CS hold use the TX sequence counter. The TX sequencer counter can use the three 8 bit compare values or preset values for delays. There is one general counter with three comparators. Each comparator has a start source, a stop source, a restart enable, and a timer compare value. The start source enables the comparator, resets the counter, and starts the counter. If the counter is already running, the start source will reset the counter and restart it.

Any comparator could start the counter using the same start source but have different timing events programmed into TCMPVALn in USARTn\_TIMECMPn. The TCMP0, TCMP1, or TCMP2 events can be preempted by using the comparator stop source to disable the comparator before the counter reaches TCMPVAL0, TCMPVAL1, or TCMPVAL2. If one comparator gets disabled while the other comparator is still enabled, the counter continues counting. By default the counter will count up to 256 and stop unless a RESTARTEN is set in one of the USARTn\_TIMECMPn registers. By using RESTARTEN and an interval programmed into TCMPVAL, an interval timer can be set up. The TSTART field needs to be changed to DISABLE to stop the interval timer. The timer stops running once all of the comparators are disabled. If a comparator's start and stop sources both trigger the same cycle, the TCMPn event triggers, the comparator stays enabled, and the counter begins counting from zero.

The TXDELAY, CSSETUP, ICS, and CSHOLD in USARTn\_TIMING are used to program start of transmission delay, chip select setup delay, inter-character space, and chip select hold delay. Either a preset value of 0, 1, 2, 3, or 7 can be used for any of these delays; or the value in TCMPVALn may be used to set the delay. Using the preset values leaves the TCMPVALn free for other uses. The same TCMPVALn may be used for multiple events that require the same timing. The transmit sequencer's counter can run in parallel with the timer's counter. The counters and controls are shown in [Figure 20.25 USART Timer Block Diagram on page 589](#).

**Figure 20.25. USART Timer Block Diagram**

The following sections will go into more details on programming the various usage cases.

**Table 20.10. USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn**

| Application            | TSTARTn                | TSTOPn         | TCMPVALn        | Other                                                                                |
|------------------------|------------------------|----------------|-----------------|--------------------------------------------------------------------------------------|
| Response Timeout       | TSTART0 = TXEOF        | TSTOP0 = RXACT | TCMPVAL0 = 0x08 | TCMP0 in USARTn_IEN                                                                  |
| Receiver Timeout       | TSTART1 = RXEOF        | TSTOP1 = RXACT | TCMPVAL1 = 0x08 | TCMP1 in USARTn_IEN                                                                  |
| Large Receiver Timeout | TSTART1 = RXEOF, TCMP1 | TSTOP1 = RXACT | TCMPVAL1 = 0xFF | TCMP1 in USARTn_IEN; TIME-RRESTARTED in USARTn_STATUS; RESTART1EN in USARTn_TIMECMP1 |

| Application                                      | TSTARTn                              | TSTOPn                          | TCMPVALn                         | Other                                                                               |
|--------------------------------------------------|--------------------------------------|---------------------------------|----------------------------------|-------------------------------------------------------------------------------------|
| Break Detect                                     | TSTART1 = RXACT                      | TSTOP1 = RXACTN                 | TCMPVAL1 = 0x0C                  | TCMP1 in USARTn_IEN                                                                 |
| TX delayed start of transmission and CS setup    | TSTART0 = DISABLE, TSTART1 = DISABLE | TSTOP0 = TCMP0, TSTOP1 = TCMP1  | TCMPVAL0 = 0x04, TCMPVAL1 = 0x02 | TXDELAY = TCMP0, CSSETUP = TCMP1 in USARTn_TIMING; AUTOCS in USARTn_CTRL            |
| TX inter-character spacing                       | TSTART2 = DISABLE                    | TSTOP2 = TCMP2                  | TCMPVAL2 = 0x03                  | ICS = TCMP2 in USARTn_TIMING; AUTOCS in USARTn_CTRL                                 |
| TX Chip Select End Delay                         | TSTART1 = DISABLE                    | TSTOP1 = TCMP1                  | TCMPVAL1 = 0x04                  | CSHOLD = TCMP1 in USARTn_TIMING; AUTOCS in USARTn_CTRL                              |
| Response Delay                                   | TSTART1 = RXEOF                      | TSTOP1 = TCMP1                  | TCMPVAL1 = 0x08                  | TXARX1EN in USARTn_TRIGCTRL                                                         |
| Combined TX and RX Example                       | TSTART1 = RXEOF, TSTART0 = TXEOF     | TSTOP1 = TCMP1, TSTOP0 = TCMP0  | TCMPVAL1 = 0x1C, TCMPVAL0 = 0x10 | TXARX1EN, RXATX0EN in USARTn_TRIGCTRL; CSSETUP = 0x7, CSHOLD = 0x3 in USARTn_TIMING |
| Combined Delayed TX and Receiver Timeout Example | TSTART0 = TCMPVAL0, TSTART1 = RXEOF  | TSTOP0 = RXACTN, TSTOP1 = RXACT | TCMPVAL0 = 0x20, TCMPVAL1 = 0x0C | TXARX0EN in USARTn_TRIGCTRL; TCMP0 in USARTn_IEN                                    |

Table 20.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 589 shows some examples of how the USART timer can be programmed for various applications. The following sections will describe more details for each applications shown in the table.

#### 20.3.10.1 Response Timeout

Response Timeout is when a UART transmitter sends a frame and expects another device to respond within a certain number of baud-times. Refer to Table 20.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 589 for specific register settings. Comparator 0 will be looking for TX end of frame to use as the timer start source. For this example, a receiver start of frame RXACT has not been detected for 8 baud-times, and the TCMP0 interrupt in USARTn\_IF is set. If an RX start bit is detected before the 8 baud-times, comparator 0 is disabled before the TCMP0 event can trigger.



Figure 20.26. USART Response Timeout

### 20.3.10.2 RX Timeout

A receiver timeout function can be implemented by using the RX end of frame to start comparator 1 and look for the RX start bit RXACT to disable the comparator. See [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) for details on setting up this example. As long as the next RX start bit occurs before the counter reaches the comparator 1 value TCMPVAL1, the interrupt will not get set. In this example the RX Timeout was set to 8 baud-times. To get an RX timeout larger than 256 baud-times, RESTART1EN in USARTn\_TIMER can be used to restart the counter when it reaches TCMPVAL1. By setting TCMPVAL1 in USARTn\_TIMING to 0xFF, an interrupt will be generated after 256 baud-times. An interrupt service routine can then increment a memory location until the desired timeout is reached. Once the RX start bit is detected, comparator 1 will be disabled. If TIMERRESTARTED in USARTn\_STATUS is clear, the TCMP1 interrupt is the first interrupt after RXEOF.



**Figure 20.27. USART RX Timeout**

### 20.3.10.3 Break Detect

LIN bus and half-duplex URTs can take advantage of the timer configured for break detection where RX is held low for a number of baud-times to indicate a break condition. [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) shows the settings for this mode. Each time RX is active (default of low) such as for a start bit, the timer begins counting. If the counter reaches 12 baud-times before RX goes to inactive RXACTN (default of high), an interrupt is asserted.



**Figure 20.28. USART Break Detection**

#### 20.3.10.4 TX Start Delay

Some applications may require a delay before the start of transmission. This example in [Figure 20.29 USART TXSEQ Timing on page 592](#) shows the TXSEQ timer used to delay the start of transmission by 4 baud times before the start of CS, and by 2 baud times with CS asserted. See [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) for details on how to configure this mode. The TX sequencer could be enabled on PRS and start the TXSEQ counter running for 4 baud times as programmed in TCMPVAL0. Then CS is asserted for 2 baud times before the transmitter begins sending TX data. TXDELAY in USARTn\_TIMING is the initial delay before any CS assertion, and CSSETUP is the delay during CS assertion. There are several small preset timing values such as 1, 2, 3, or 7 that can be used for some of the TX sequencer timing which leaves TCMPVAL0, TCMPVAL1, and TCMPVAL2 free for other uses.



**Figure 20.29. USART TXSEQ Timing**

#### 20.3.10.5 Inter-Character Space

In addition to delaying the start of frame transmission, it is sometimes necessary to also delay the time between each transmit character (inter-character space). After the first transmission, the inter-character space will delay the start of all subsequent transmissions until the transmit buffer is empty. See [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) for details on setting up this example. For this example in [Figure 20.29 USART TXSEQ Timing on page 592](#) ICS is set to TCMP2 in USARTn\_TIMING. To keep CS asserted during the inter-character space, set AUTOCS in USARTn\_CTRL. There are a few small preset timing values provided for TX sequence timing. Using these preset timing values can free up the TCMPVALn for other uses. For this example, the inter-character space is set to 0x03 and a preset value could be used.

#### 20.3.10.6 TX Chip Select End Delay

The assertion of CS can be extended after the final character of the frame by using CSHOLD in USARTn\_TIMING. See [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) for details on setting up this example. AUTOCS in USARTn\_CTRL needs to be set to extend the CS assertion after the last TX character is transmitted as shown in [Figure 20.29 USART TXSEQ Timing on page 592](#).

#### 20.3.10.7 Response Delay

A response delay can be used to hold off the transmitter until a certain number of baud-times after the RX frame. See [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) for details on setting up this example. TXARX1EN in USARTn\_TRIGCTRL tells the TX sequencer to trigger after RX EOF plus tcmp1val baud times.



**Figure 20.30. USART Response Delay**

### 20.3.10.8 Combined TX and RX Example

This example describes how to alternate between TX and RX frames. This has a 28 baud-time space after RX and a 16 baud-time space after TX. The TSTART1 in USARTn\_TIMECMP1 is set to RXEOF which uses the receiver end of frame to start the timer. The TSTOP1 is set to TCMP1 to generate an event after 28 baud times. Set TXARX1EN in USARTn\_TRIGCTRL, and the transmitter is held off until 28 baud times. TCMPVAL in USARTn\_TIMECMP1 is set to 0x1C for 28 baud times. By setting TSTART0 in USARTn\_TIMECMP0 to TXEOF, the timer will be started after the transmission has completed. RXATX0EN in USARTn\_TRIGCTRL is used to delay enabling of the receiver until 16 baud times after the transmitter has completed. Write 0x10 into TCMPVAL of USARTn\_TIMECMP0 for a 16 baud time delay. CS is also asserted 7 baud-times before start of transmission by setting CSSETUP to 0x7 in USARTn\_TIMING. To keep CS asserted for 3 baud-times after transmission completes, CSHOLD is set to 0x3 in USARTn\_TIMING. See [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) for details on setting up this example.

### 20.3.10.9 Combined TX Delay and RX Break Detect

This example describes how to delay TX transmission after an RX frame and how to have a break condition signal an interrupt. See [Table 20.10 USART Application Settings for USARTn\\_TIMING and USARTn\\_TIMECMPn on page 589](#) for details on setting up this example. The TX delay is set up by using transmit after RX, TXARX0EN in USARTn\_TRIGCTRL to start the timer. TSTART0 in USARTn\_TIMECMP0 is set to RXEOF which enables the transmitter of the timer delay. For this example TCMPVAL in USARTn\_TIMECMP0 is set to 0x20 to create a 32 baud-time delay between the end of the RX frame and the start of the TX frame. The break detect is configured by setting TSTART1 to RXACT to detect the start bit, and setting TSTOP1 to RXACTN to detect RX going high. In this case the interrupt asserts after RX stays low for 12 baud-times, so TCMPVAL1 is set to 0x0C.

### 20.3.10.10 Other Stop Conditions

There is also a timer stop on TX start using the TXST setting in TSTOP of USARTn\_TIMECMPn. This can be used to see that the DMA has not written to the TXBUFFER for a given time.

## 20.3.11 Interrupts

The interrupts generated by the USART are combined into two interrupt vectors. Interrupts related to reception are assigned to one interrupt vector, and interrupts related to transmission are assigned to the other. Separating the interrupts in this way allows different priorities to be set for transmission and reception interrupts.

The transmission interrupt vector groups the transmission-related interrupts generated by the following interrupt flags:

- TXC
- TXBL
- TXOF
- CCF
- TXIDLE

The reception interrupt on the other hand groups the reception-related interrupts, triggered by the following interrupt flags:

- RXDATAV
- RXFULL
- RXOF
- RXUF
- PERR
- FERR
- MPAF
- SSM
- TCMPn

If USART interrupts are enabled, an interrupt will be made if one or more of the interrupt flags in USART\_IF and their corresponding bits in USART\_IEN are set.

### 20.3.12 IrDA Modulator/ Demodulator

The IrDA modulator implements the physical layer of the IrDA specification, which is necessary for communication over IrDA. The modulator takes the signal output from the USART module, and modulates it before it leaves the USART. In the same way, the input signal is demodulated before it enters the actual USART module. The modulator implements the original Rev. 1.0 physical layer and one high speed extension which supports speeds from 2.4 kbps to 1.152 Mbps.

The data from and to the USART is represented in a NRZ (Non Return to Zero) format, where the signal value is at the same level through the entire bit period. For IrDA, the required format is RZI (Return to Zero Inverted), a format where a “1” is signalled by holding the line low, and a “0” is signalled by a short high pulse. An example is given in [Figure 20.31 USART Example RZI Signal for a given Asynchronous USART Frame on page 594](#).



**Figure 20.31. USART Example RZI Signal for a given Asynchronous USART Frame**

The IrDA module is enabled by setting IREN. The USART transmitter output and receiver input is then routed through the IrDA modulator.

The width of the pulses generated by the IrDA modulator is set by configuring IRPW in USARTn\_IRCTRL. Four pulse widths are available, each defined relative to the configured bit period as listed in [Table 20.11 USART IrDA Pulse Widths on page 594](#).

**Table 20.11. USART IrDA Pulse Widths**

| IRPW | Pulse width OVS=0 | Pulse width OVS=1 | Pulse width OVS=2 | Pulse width OVS=3 |
|------|-------------------|-------------------|-------------------|-------------------|
| 00   | 1/16              | 1/8               | 1/6               | 1/4               |
| 01   | 2/16              | 2/8               | 2/6               | N/A               |
| 10   | 3/16              | 3/8               | N/A               | N/A               |
| 11   | 4/16              | N/A               | N/A               | N/A               |

By default, no filter is enabled in the IrDA demodulator. A filter can be enabled by setting IRFILT in USARTn\_IRCTRL. When the filter is enabled, an incoming pulse has to last for 4 consecutive clock cycles to be detected by the IrDA demodulator.

Note that by default, the idle value of the USART data signal is high. This means that the IrDA modulator generates negative pulses, and the IrDA demodulator expects negative pulses. To make the IrDA module use RZI signalling, both TXINV and RXINV in USARTn\_CTRL must be set.

## 20.4 USART Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description                              |
|--------|---------------------|-------------|------------------------------------------|
| 0x000  | USART_IPVERSION     | R           | IPVERSION                                |
| 0x004  | USART_EN            | RW          | USART Enable                             |
| 0x008  | USART_CTRL          | RW          | Control Register                         |
| 0x00C  | USART_FRAME         | RW          | USART Frame Format Register              |
| 0x010  | USART_TRIGCTRL      | RW          | USART Trigger Control Register           |
| 0x014  | USART_CMD           | W           | Command Register                         |
| 0x018  | USART_STATUS        | RH          | USART Status Register                    |
| 0x01C  | USART_CLKDIV        | RWH         | Clock Control Register                   |
| 0x020  | USART_RXDATAL       | RH          | RX Buffer Data Extended Register         |
| 0x024  | USART_RXDATA        | RH          | RX Buffer Data Register                  |
| 0x028  | USART_RXDOUBLEX     | RH          | RX Buffer Double Data Extended Register  |
| 0x02C  | USART_RXDOUBLE      | RH          | RX FIFO Double Data Register             |
| 0x030  | USART_RXDATALP      | RH          | RX Buffer Data Extended Peek Register    |
| 0x034  | USART_RXDOUBLEXP    | RH          | RX Buffer Double Data Extended Peek R... |
| 0x038  | USART_TXDATAL       | W           | TX Buffer Data Extended Register         |
| 0x03C  | USART_TXDATA        | W           | TX Buffer Data Register                  |
| 0x040  | USART_TXDOUBLEX     | W           | TX Buffer Double Data Extended Register  |
| 0x044  | USART_TXDOUBLE      | W           | TX Buffer Double Data Register           |
| 0x048  | USART_IF            | RWH INTFLAG | Interrupt Flag Register                  |
| 0x04C  | USART_IEN           | RW          | Interrupt Enable Register                |
| 0x050  | USART_IRCTRL        | RW          | IrDA Control Register                    |
| 0x054  | USART_I2SCTRL       | RW          | I2S Control Register                     |
| 0x058  | USART_TIMING        | RW          | Timing Register                          |
| 0x05C  | USART_CTRLX         | RW          | Control Register Extended                |
| 0x060  | USART_TIMECMP0      | RW          | Timer Compare 0                          |
| 0x064  | USART_TIMECMP1      | RW          | Timer Compare 1                          |
| 0x068  | USART_TIMECMP2      | RW          | Timer Compare 2                          |
| 0x1000 | USART_IPVERSION_SET | R           | IPVERSION                                |
| 0x1004 | USART_EN_SET        | RW          | USART Enable                             |
| 0x1008 | USART_CTRL_SET      | RW          | Control Register                         |
| 0x100C | USART_FRAME_SET     | RW          | USART Frame Format Register              |
| 0x1010 | USART_TRIGCTRL_SET  | RW          | USART Trigger Control Register           |
| 0x1014 | USART_CMD_SET       | W           | Command Register                         |
| 0x1018 | USART_STATUS_SET    | RH          | USART Status Register                    |
| 0x101C | USART_CLKDIV_SET    | RWH         | Clock Control Register                   |

| Offset | Name                 | Type        | Description                              |
|--------|----------------------|-------------|------------------------------------------|
| 0x1020 | USART_RXDATA_X_SET   | RH          | RX Buffer Data Extended Register         |
| 0x1024 | USART_RXDATA_SET     | RH          | RX Buffer Data Register                  |
| 0x1028 | USART_RXDOUBLEX_SET  | RH          | RX Buffer Double Data Extended Register  |
| 0x102C | USART_RXDOUBLE_SET   | RH          | RX FIFO Double Data Register             |
| 0x1030 | USART_RXDATAXP_SET   | RH          | RX Buffer Data Extended Peek Register    |
| 0x1034 | USART_RXDOUBLEXP_SET | RH          | RX Buffer Double Data Extended Peek R... |
| 0x1038 | USART_TXDATA_X_SET   | W           | TX Buffer Data Extended Register         |
| 0x103C | USART_TXDATA_SET     | W           | TX Buffer Data Register                  |
| 0x1040 | USART_TXDOUBLEX_SET  | W           | TX Buffer Double Data Extended Register  |
| 0x1044 | USART_TXDOUBLE_SET   | W           | TX Buffer Double Data Register           |
| 0x1048 | USART_IF_SET         | RWH INTFLAG | Interrupt Flag Register                  |
| 0x104C | USART_IEN_SET        | RW          | Interrupt Enable Register                |
| 0x1050 | USART_IRCTRL_SET     | RW          | IrDA Control Register                    |
| 0x1054 | USART_I2SCTRL_SET    | RW          | I2S Control Register                     |
| 0x1058 | USART_TIMING_SET     | RW          | Timing Register                          |
| 0x105C | USART_CTRLX_SET      | RW          | Control Register Extended                |
| 0x1060 | USART_TIMECMP0_SET   | RW          | Timer Compare 0                          |
| 0x1064 | USART_TIMECMP1_SET   | RW          | Timer Compare 1                          |
| 0x1068 | USART_TIMECMP2_SET   | RW          | Timer Compare 2                          |
| 0x2000 | USART_IPVERSION_CLR  | R           | IPVERSION                                |
| 0x2004 | USART_EN_CLR         | RW          | USART Enable                             |
| 0x2008 | USART_CTRL_CLR       | RW          | Control Register                         |
| 0x200C | USART_FRAME_CLR      | RW          | USART Frame Format Register              |
| 0x2010 | USART_TRIGCTRL_CLR   | RW          | USART Trigger Control Register           |
| 0x2014 | USART_CMD_CLR        | W           | Command Register                         |
| 0x2018 | USART_STATUS_CLR     | RH          | USART Status Register                    |
| 0x201C | USART_CLKDIV_CLR     | RWH         | Clock Control Register                   |
| 0x2020 | USART_RXDATA_X_CLR   | RH          | RX Buffer Data Extended Register         |
| 0x2024 | USART_RXDATA_CLR     | RH          | RX Buffer Data Register                  |
| 0x2028 | USART_RXDOUBLEX_CLR  | RH          | RX Buffer Double Data Extended Register  |
| 0x202C | USART_RXDOUBLE_CLR   | RH          | RX FIFO Double Data Register             |
| 0x2030 | USART_RXDATAXP_CLR   | RH          | RX Buffer Data Extended Peek Register    |
| 0x2034 | USART_RXDOUBLEXP_CLR | RH          | RX Buffer Double Data Extended Peek R... |
| 0x2038 | USART_TXDATA_X_CLR   | W           | TX Buffer Data Extended Register         |
| 0x203C | USART_TXDATA_CLR     | W           | TX Buffer Data Register                  |
| 0x2040 | USART_TXDOUBLEX_CLR  | W           | TX Buffer Double Data Extended Register  |
| 0x2044 | USART_TXDOUBLE_CLR   | W           | TX Buffer Double Data Register           |

| Offset | Name                  | Type        | Description                              |
|--------|-----------------------|-------------|------------------------------------------|
| 0x2048 | USART_IF_CLR          | RWH INTFLAG | Interrupt Flag Register                  |
| 0x204C | USART_IEN_CLR         | RW          | Interrupt Enable Register                |
| 0x2050 | USART_IRCTRL_CLR      | RW          | IrDA Control Register                    |
| 0x2054 | USART_I2SCTRL_CLR     | RW          | I2S Control Register                     |
| 0x2058 | USART_TIMING_CLR      | RW          | Timing Register                          |
| 0x205C | USART_CTRLX_CLR       | RW          | Control Register Extended                |
| 0x2060 | USART_TIMECMP0_CLR    | RW          | Timer Compare 0                          |
| 0x2064 | USART_TIMECMP1_CLR    | RW          | Timer Compare 1                          |
| 0x2068 | USART_TIMECMP2_CLR    | RW          | Timer Compare 2                          |
| 0x3000 | USART_IPVERSION_TGL   | R           | IPVERSION                                |
| 0x3004 | USART_EN_TGL          | RW          | USART Enable                             |
| 0x3008 | USART_CTRL_TGL        | RW          | Control Register                         |
| 0x300C | USART_FRAME_TGL       | RW          | USART Frame Format Register              |
| 0x3010 | USART_TRIGCTRL_TGL    | RW          | USART Trigger Control Register           |
| 0x3014 | USART_CMD_TGL         | W           | Command Register                         |
| 0x3018 | USART_STATUS_TGL      | RH          | USART Status Register                    |
| 0x301C | USART_CLKDIV_TGL      | RWH         | Clock Control Register                   |
| 0x3020 | USART_RXDATA_X_TGL    | RH          | RX Buffer Data Extended Register         |
| 0x3024 | USART_RXDATA_TGL      | RH          | RX Buffer Data Register                  |
| 0x3028 | USART_RXDOUBLE_X_TGL  | RH          | RX Buffer Double Data Extended Register  |
| 0x302C | USART_RXDOUBLE_TGL    | RH          | RX FIFO Double Data Register             |
| 0x3030 | USART_RXDATA_XP_TGL   | RH          | RX Buffer Data Extended Peek Register    |
| 0x3034 | USART_RXDOUBLE_XP_TGL | RH          | RX Buffer Double Data Extended Peek R... |
| 0x3038 | USART_TXDATA_X_TGL    | W           | TX Buffer Data Extended Register         |
| 0x303C | USART_TXDATA_TGL      | W           | TX Buffer Data Register                  |
| 0x3040 | USART_TXDOUBLE_X_TGL  | W           | TX Buffer Double Data Extended Register  |
| 0x3044 | USART_TXDOUBLE_TGL    | W           | TX Buffer Double Data Register           |
| 0x3048 | USART_IF_TGL          | RWH INTFLAG | Interrupt Flag Register                  |
| 0x304C | USART_IEN_TGL         | RW          | Interrupt Enable Register                |
| 0x3050 | USART_IRCTRL_TGL      | RW          | IrDA Control Register                    |
| 0x3054 | USART_I2SCTRL_TGL     | RW          | I2S Control Register                     |
| 0x3058 | USART_TIMING_TGL      | RW          | Timing Register                          |
| 0x305C | USART_CTRLX_TGL       | RW          | Control Register Extended                |
| 0x3060 | USART_TIMECMP0_TGL    | RW          | Timer Compare 0                          |
| 0x3064 | USART_TIMECMP1_TGL    | RW          | Timer Compare 1                          |
| 0x3068 | USART_TIMECMP2_TGL    | RW          | Timer Compare 2                          |

## 20.5 USART Register Description

### 20.5.1 USART\_IPVERSION - IPVERSION

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x0   | R      | <b>IPVERSION</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                  |

### 20.5.2 USART\_EN - USART Enable

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x004  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                | Name     | Reset                                                                                                                                                             | Access | Description         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:1                               | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                  | EN       | 0x0                                                                                                                                                               | RW     | <b>USART Enable</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| The ENABLE bit enables the module. |          |                                                                                                                                                                   |        |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### 20.5.3 USART\_CTRL - Control Register

| Offset | Bit Position |          |        |        |         |          |          |           |        |         |        |       |       |       |       |      |      |        |        |     |      |     |      |        |      |
|--------|--------------|----------|--------|--------|---------|----------|----------|-----------|--------|---------|--------|-------|-------|-------|-------|------|------|--------|--------|-----|------|-----|------|--------|------|
| Reset  | 0x0          | 31       | 0x0    | 30     | 0x0     | 29       | 0x0      | 28        | 0x0    | 27      | 0x0    | 26    | 0x0   | 25    | 0x0   | 24   |      |        |        |     |      |     |      |        |      |
| Access | RW           | MVDIS    | RW     | AUTOTX | RW      | BYTESWAP | RW       |           |        |         |        |       |       |       |       |      |      |        |        |     |      |     |      |        |      |
| Name   | SMSDELAY     | SSSEARLY | ERRSTX | ERRSRX | ERRSDMA | BIT8DV   | SKIPPERF | SCRETRANS | SCMODE | AUTOTRI | AUTOCS | CSINV | TXINV | RXINV | TXBIL | CSMA | MSBF | CLKPHA | CLKPOL | OVS | MPAB | MPM | CCEN | LOOPBK | SYNC |

| Bit   | Name     | Reset   | Access | Description                                                                                                                                                                       |
|-------|----------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | SMSDELAY | 0x0     | RW     | <b>Synchronous Main Sample Delay</b><br>Delay Synchronous Main interface sample point to the next setup edge to improve timing and allow communication at higher speeds           |
| 30    | MVDIS    | 0x0     | RW     | <b>Majority Vote Disable</b><br>Disable majority vote for 16x, 8x and 6x oversampling modes.                                                                                      |
| 29    | AUTOTX   | 0x0     | RW     | <b>Always Transmit When RX Not Full</b><br>Transmits as long as RX is not full. If TX is empty, underflows are generated.                                                         |
| 28    | BYTESWAP | 0x0     | RW     | <b>Byteswap In Double Accesses</b><br>Set to switch the order of the bytes in double accesses.                                                                                    |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | DISABLE |        | Normal byte order                                                                                                                                                                 |
|       | 1        | ENABLE  |        | Byte order swapped                                                                                                                                                                |
| 27:26 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 25    | SSSEARLY | 0x0     | RW     | <b>Synchronous Secondary Setup Early</b><br>Setup data on sample edge in synchronous secondary interface mode to improve MOSI setup time                                          |
| 24    | ERRSTX   | 0x0     | RW     | <b>Disable TX On Error</b><br>When set, the transmitter is disabled on framing and parity errors (asynchronous mode only) in the receiver.                                        |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | DISABLE |        | Received framing and parity errors have no effect on transmitter                                                                                                                  |
|       | 1        | ENABLE  |        | Received framing and parity errors disable the transmitter                                                                                                                        |
| 23    | ERRSRX   | 0x0     | RW     | <b>Disable RX On Error</b><br>When set, the receiver is disabled on framing and parity errors (asynchronous mode only).                                                           |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | DISABLE |        | Framing and parity errors have no effect on receiver                                                                                                                              |
|       | 1        | ENABLE  |        | Framing and parity errors disable the receiver                                                                                                                                    |

| Bit                                                                                                                                                                           | Name      | Reset   | Access | Description                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|--------|----------------------------------------------------------------------------------------|
| 22                                                                                                                                                                            | ERRSDMA   | 0x0     | RW     | <b>Halt DMA On Error</b>                                                               |
| When set, DMA requests will be cleared on framing and parity errors (asynchronous mode only).                                                                                 |           |         |        |                                                                                        |
|                                                                                                                                                                               | Value     | Mode    |        | Description                                                                            |
|                                                                                                                                                                               | 0         | DISABLE |        | Framing and parity errors have no effect on DMA requests from the USART                |
|                                                                                                                                                                               | 1         | ENABLE  |        | DMA requests from the USART are blocked while the PERR or FERR interrupt flags are set |
| 21                                                                                                                                                                            | BIT8DV    | 0x0     | RW     | <b>Bit 8 Default Value</b>                                                             |
| The default value of the 9th bit. If 9-bit frames are used, and an 8-bit write operation is done, leaving the 9th bit unspecified, the 9th bit is set to the value of BIT8DV. |           |         |        |                                                                                        |
| 20                                                                                                                                                                            | SKIPPERRF | 0x0     | RW     | <b>Skip Parity Error Frames</b>                                                        |
| When set, the receiver discards frames with parity errors (asynchronous mode only). The PERR interrupt flag is still set.                                                     |           |         |        |                                                                                        |
| 19                                                                                                                                                                            | SCRETRANS | 0x0     | RW     | <b>SmartCard Retransmit</b>                                                            |
| When in SmartCard mode, a NACK'ed frame will be kept in the shift register and retransmitted if the transmitter is still enabled.                                             |           |         |        |                                                                                        |
| 18                                                                                                                                                                            | SCMODE    | 0x0     | RW     | <b>SmartCard Mode</b>                                                                  |
| Use this bit to enable or disable SmartCard mode.                                                                                                                             |           |         |        |                                                                                        |
| 17                                                                                                                                                                            | AUTOTRI   | 0x0     | RW     | <b>Automatic TX Tristate</b>                                                           |
| When enabled, TXTRI is set by hardware whenever the transmitter is idle, and TXTRI is cleared by hardware when transmission starts.                                           |           |         |        |                                                                                        |
|                                                                                                                                                                               | Value     | Mode    |        | Description                                                                            |
|                                                                                                                                                                               | 0         | DISABLE |        | The output on U(S)n_TX when the transmitter is idle is defined by TXINV                |
|                                                                                                                                                                               | 1         | ENABLE  |        | U(S)n_TX is tristated whenever the transmitter is idle                                 |
| 16                                                                                                                                                                            | AUTOCS    | 0x0     | RW     | <b>Automatic Chip Select</b>                                                           |
| When enabled, the output on USn_CS will be activated one baud-period before transmission starts, and deactivated when transmission ends.                                      |           |         |        |                                                                                        |
| 15                                                                                                                                                                            | CSINV     | 0x0     | RW     | <b>Chip Select Invert</b>                                                              |
| Default value is active low. This affects both the selection of external secondaries, as well as the selection of the microcontroller as a secondary interface.               |           |         |        |                                                                                        |
|                                                                                                                                                                               | Value     | Mode    |        | Description                                                                            |
|                                                                                                                                                                               | 0         | DISABLE |        | Chip select is active low                                                              |
|                                                                                                                                                                               | 1         | ENABLE  |        | Chip select is active high                                                             |
| 14                                                                                                                                                                            | TXINV     | 0x0     | RW     | <b>Transmitter output Invert</b>                                                       |
| The output from the USART transmitter can optionally be inverted by setting this bit.                                                                                         |           |         |        |                                                                                        |
|                                                                                                                                                                               | Value     | Mode    |        | Description                                                                            |
|                                                                                                                                                                               | 0         | DISABLE |        | Output from the transmitter is passed unchanged to U(S)n_TX                            |
|                                                                                                                                                                               | 1         | ENABLE  |        | Output from the transmitter is inverted before it is passed to U(S)n_TX                |

| Bit | Name   | Reset                                                                                                                                       | Access         | Description                                                                                                                          |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 13  | RXINV  | 0x0                                                                                                                                         | RW             | <b>Receiver Input Invert</b>                                                                                                         |
|     |        | Setting this bit will invert the input to the USART receiver.                                                                               |                |                                                                                                                                      |
|     |        | Value                                                                                                                                       | Mode           | Description                                                                                                                          |
|     |        | 0                                                                                                                                           | DISABLE        | Input is passed directly to the receiver                                                                                             |
|     |        | 1                                                                                                                                           | ENABLE         | Input is inverted before it is passed to the receiver                                                                                |
| 12  | TXBIL  | 0x0                                                                                                                                         | RW             | <b>TX Buffer Interrupt Level</b>                                                                                                     |
|     |        | Determines the interrupt and status level of the transmit buffer.                                                                           |                |                                                                                                                                      |
|     |        | Value                                                                                                                                       | Mode           | Description                                                                                                                          |
|     |        | 0                                                                                                                                           | EMPTY          | TXBL and the TXBL interrupt flag are set when the transmit buffer becomes empty. TXBL is cleared when the buffer becomes nonempty.   |
|     |        | 1                                                                                                                                           | HALFFULL       | TXBL and TXBLIF are set when the transmit buffer goes from full to half-full or empty. TXBL is cleared when the buffer becomes full. |
| 11  | CSMA   | 0x0                                                                                                                                         | RW             | <b>Action On Chip Select In Main Mode</b>                                                                                            |
|     |        | This register determines the action to be performed when chip select is configured as an input and driven low while in main interface mode. |                |                                                                                                                                      |
|     |        | Value                                                                                                                                       | Mode           | Description                                                                                                                          |
|     |        | 0                                                                                                                                           | NOACTION       | No action taken                                                                                                                      |
|     |        | 1                                                                                                                                           | GOTOSLAVEMODE  | Go to secondary mode                                                                                                                 |
| 10  | MSBF   | 0x0                                                                                                                                         | RW             | <b>Most Significant Bit First</b>                                                                                                    |
|     |        | Decides whether data is sent with the least significant bit first, or the most significant bit first.                                       |                |                                                                                                                                      |
|     |        | Value                                                                                                                                       | Mode           | Description                                                                                                                          |
|     |        | 0                                                                                                                                           | DISABLE        | Data is sent with the least significant bit first                                                                                    |
|     |        | 1                                                                                                                                           | ENABLE         | Data is sent with the most significant bit first                                                                                     |
| 9   | CLKPHA | 0x0                                                                                                                                         | RW             | <b>Clock Edge For Setup/Sample</b>                                                                                                   |
|     |        | Determines where data is set-up and sampled according to the bus clock when in synchronous mode.                                            |                |                                                                                                                                      |
|     |        | Value                                                                                                                                       | Mode           | Description                                                                                                                          |
|     |        | 0                                                                                                                                           | SAMPLELEADING  | Data is sampled on the leading edge and set-up on the trailing edge of the bus clock in synchronous mode                             |
|     |        | 1                                                                                                                                           | SAMPLETRAILING | Data is set-up on the leading edge and sampled on the trailing edge of the bus clock in synchronous mode                             |
| 8   | CLKPOL | 0x0                                                                                                                                         | RW             | <b>Clock Polarity</b>                                                                                                                |
|     |        | Determines the clock polarity of the bus clock used in synchronous mode.                                                                    |                |                                                                                                                                      |
|     |        | Value                                                                                                                                       | Mode           | Description                                                                                                                          |
|     |        | 0                                                                                                                                           | IDLELOW        | The bus clock used in synchronous mode has a low base value                                                                          |

| Bit | Name     | Reset   | Access | Description                                                                                                                                                                 |
|-----|----------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | IDLEHIGH |         |        | The bus clock used in synchronous mode has a high base value                                                                                                                |
| 7   | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>           |
| 6:5 | OVS      | 0x0     | RW     | <b>Oversampling</b>                                                                                                                                                         |
|     |          |         |        | Sets the number of clock periods in a USART bit-period. More clock cycles gives better robustness, while less clock cycles gives better performance.                        |
|     | Value    | Mode    |        | Description                                                                                                                                                                 |
|     | 0        | X16     |        | Regular UART mode with 16X oversampling in asynchronous mode                                                                                                                |
|     | 1        | X8      |        | Double speed with 8X oversampling in asynchronous mode                                                                                                                      |
|     | 2        | X6      |        | 6X oversampling in asynchronous mode                                                                                                                                        |
|     | 3        | X4      |        | Quadruple speed with 4X oversampling in asynchronous mode                                                                                                                   |
| 4   | MPAB     | 0x0     | RW     | <b>Multi-Processor Address-Bit</b>                                                                                                                                          |
|     |          |         |        | Defines the value of the multi-processor address bit. An incoming frame with its 9th bit equal to the value of this bit marks the frame as a multi-processor address frame. |
| 3   | MPM      | 0x0     | RW     | <b>Multi-Processor Mode</b>                                                                                                                                                 |
|     |          |         |        | Multi-processor mode uses the 9th bit of the USART frames to tell whether the frame is an address frame or a data frame.                                                    |
|     | Value    | Mode    |        | Description                                                                                                                                                                 |
|     | 0        | DISABLE |        | The 9th bit of incoming frames has no special function                                                                                                                      |
|     | 1        | ENABLE  |        | An incoming frame with the 9th bit equal to MPAB will be loaded into the receive buffer regardless of RXBLOCK and will result in the MPAB interrupt flag being set          |
| 2   | CCEN     | 0x0     | RW     | <b>Collision Check Enable</b>                                                                                                                                               |
|     |          |         |        | Enables collision checking on data when operating in half duplex modus.                                                                                                     |
|     | Value    | Mode    |        | Description                                                                                                                                                                 |
|     | 0        | DISABLE |        | Collision check is disabled                                                                                                                                                 |
|     | 1        | ENABLE  |        | Collision check is enabled. The receiver must be enabled for the check to be performed                                                                                      |
| 1   | LOOPBK   | 0x0     | RW     | <b>Loopback Enable</b>                                                                                                                                                      |
|     |          |         |        | Allows the receiver to be connected directly to the USART transmitter for loopback and half duplex communication.                                                           |
|     | Value    | Mode    |        | Description                                                                                                                                                                 |
|     | 0        | DISABLE |        | The receiver is connected to and receives data from U(S)n_RX                                                                                                                |
|     | 1        | ENABLE  |        | The receiver is connected to and receives data from U(S)n_TX                                                                                                                |
| 0   | SYNC     | 0x0     | RW     | <b>USART Synchronous Mode</b>                                                                                                                                               |
|     |          |         |        | Determines whether the USART is operating in asynchronous or synchronous mode.                                                                                              |
|     | Value    | Mode    |        | Description                                                                                                                                                                 |

| Bit | Name | Reset   | Access | Description                             |
|-----|------|---------|--------|-----------------------------------------|
| 0   |      | DISABLE |        | The USART operates in asynchronous mode |
| 1   |      | ENABLE  |        | The USART operates in synchronous mode  |

#### 20.5.4 USART FRAME - USART Frame Format Register

| Bit   | Name        | Reset                                                                                       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
|-------|-------------|---------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|------|-----------------------------------------------------------------------------------|---|------|----------------------------------------------------------------------------------------|---|-------------|---------------------------------------------------------------------------------------------|---|-----|--------------------------------------------------------------------------------------|
| 31:14 | Reserved    |                                                                                             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 13:12 | STOPBITS    | 0x1                                                                                         | RW     | <b>Stop-Bit Mode</b><br><br>Determines the number of stop-bits used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
|       |             |                                                                                             |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>HALF</td><td>The transmitter generates a half stop bit. Stop-bits are not verified by receiver</td></tr> <tr> <td>1</td><td>ONE</td><td>One stop bit is generated and verified</td></tr> <tr> <td>2</td><td>ONEANDAHALF</td><td>The transmitter generates one and a half stop bit. The receiver verifies the first stop bit</td></tr> <tr> <td>3</td><td>TWO</td><td>The transmitter generates two stop bits. The receiver checks the first stop-bit only</td></tr> </tbody> </table> | Value | Mode | Description | 0 | HALF | The transmitter generates a half stop bit. Stop-bits are not verified by receiver | 1 | ONE  | One stop bit is generated and verified                                                 | 2 | ONEANDAHALF | The transmitter generates one and a half stop bit. The receiver verifies the first stop bit | 3 | TWO | The transmitter generates two stop bits. The receiver checks the first stop-bit only |
| Value | Mode        | Description                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 0     | HALF        | The transmitter generates a half stop bit. Stop-bits are not verified by receiver           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 1     | ONE         | One stop bit is generated and verified                                                      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 2     | ONEANDAHALF | The transmitter generates one and a half stop bit. The receiver verifies the first stop bit |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 3     | TWO         | The transmitter generates two stop bits. The receiver checks the first stop-bit only        |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 11:10 | Reserved    |                                                                                             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 9:8   | PARITY      | 0x0                                                                                         | RW     | <b>Parity-Bit Mode</b><br><br>Determines whether parity bits are enabled, and whether even or odd parity should be used. Only available in asynchronous mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
|       |             |                                                                                             |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>NONE</td><td>Parity bits are not used</td></tr> <tr> <td>2</td><td>EVEN</td><td>Even parity are used. Parity bits are automatically generated and checked by hardware.</td></tr> <tr> <td>3</td><td>ODD</td><td>Odd parity is used. Parity bits are automatically generated and checked by hardware.</td></tr> </tbody> </table>                                                                                                                                                      | Value | Mode | Description | 0 | NONE | Parity bits are not used                                                          | 2 | EVEN | Even parity are used. Parity bits are automatically generated and checked by hardware. | 3 | ODD         | Odd parity is used. Parity bits are automatically generated and checked by hardware.        |   |     |                                                                                      |
| Value | Mode        | Description                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 0     | NONE        | Parity bits are not used                                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 2     | EVEN        | Even parity are used. Parity bits are automatically generated and checked by hardware.      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 3     | ODD         | Odd parity is used. Parity bits are automatically generated and checked by hardware.        |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 7:4   | Reserved    |                                                                                             |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 3:0   | DATABITS    | 0x5                                                                                         | RW     | <b>Data-Bit Mode</b><br><br>This register sets the number of data bits in a USART frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
|       |             |                                                                                             |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>1</td><td>FOUR</td><td>Each frame contains 4 data bits</td></tr> <tr> <td>2</td><td>FIVE</td><td>Each frame contains 5 data bits</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                    | Value | Mode | Description | 1 | FOUR | Each frame contains 4 data bits                                                   | 2 | FIVE | Each frame contains 5 data bits                                                        |   |             |                                                                                             |   |     |                                                                                      |
| Value | Mode        | Description                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 1     | FOUR        | Each frame contains 4 data bits                                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |
| 2     | FIVE        | Each frame contains 5 data bits                                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |      |                                                                                   |   |      |                                                                                        |   |             |                                                                                             |   |     |                                                                                      |

| Bit | Name     | Reset | Access | Description                      |
|-----|----------|-------|--------|----------------------------------|
| 3   | SIX      |       |        | Each frame contains 6 data bits  |
| 4   | SEVEN    |       |        | Each frame contains 7 data bits  |
| 5   | EIGHT    |       |        | Each frame contains 8 data bits  |
| 6   | NINE     |       |        | Each frame contains 9 data bits  |
| 7   | TEN      |       |        | Each frame contains 10 data bits |
| 8   | ELEVEN   |       |        | Each frame contains 11 data bits |
| 9   | TWELVE   |       |        | Each frame contains 12 data bits |
| 10  | THIRTEEN |       |        | Each frame contains 13 data bits |
| 11  | FOURTEEN |       |        | Each frame contains 14 data bits |
| 12  | FIFTEEN  |       |        | Each frame contains 15 data bits |
| 13  | SIXTEEN  |       |        | Each frame contains 16 data bits |

### 20.5.5 USART\_TRIGCTRL - USART Trigger Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |          |          |          |          |          |           |       |       |    |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|----------|----------|----------|----------|-----------|-------|-------|----|---|---|---|
| 0x010  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0       | 0x0   |       |    |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW        | RW    | RW    | RW |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXATX2EN | RXATX1EN | RXATX0EN | TXARX2EN | TXARX1EN | TXARX0EN | AUTOTXTEN | TXTEN | RXTEN |    |   |   |   |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | RXATX2EN  | 0x0   | RW     | <b>Enable Receive Trigger after TX end of f</b><br>When set, a TX end of frame will trigger the receiver after a TCMPVAL2 baud-time delay                                         |
| 11    | RXATX1EN  | 0x0   | RW     | <b>Enable Receive Trigger after TX end of f</b><br>When set, a TX end of frame will trigger the receiver after a TCMPVAL1 baud-time delay                                         |
| 10    | RXATX0EN  | 0x0   | RW     | <b>Enable Receive Trigger after TX end of f</b><br>When set, a TX end of frame will trigger the receiver after a TCMPVAL0 baud-time delay                                         |
| 9     | TXARX2EN  | 0x0   | RW     | <b>Enable Transmit Trigger after RX End of</b><br>When set, an RX end of frame will trigger the transmitter after TCMP2VAL bit times to force a minimum response delay            |
| 8     | TXARX1EN  | 0x0   | RW     | <b>Enable Transmit Trigger after RX End of</b><br>When set, an RX end of frame will trigger the transmitter after TCMP1VAL bit times to force a minimum response delay            |
| 7     | TXARX0EN  | 0x0   | RW     | <b>Enable Transmit Trigger after RX End of</b><br>When set, an RX end of frame will trigger the transmitter after TCMP0VAL bit times to force a minimum response delay            |
| 6     | AUTOTXTEN | 0x0   | RW     | <b>AUTOTX Trigger Enable</b><br>When set, AUTOTX is enabled as long as the PRS channel selected by TSEL has a high value                                                          |
| 5     | TXTEN     | 0x0   | RW     | <b>Transmit Trigger Enable</b><br>When set, the PRS channel selected by TSEL sets TXEN, enabling the transmitter on positive trigger edges.                                       |
| 4     | RXTEN     | 0x0   | RW     | <b>Receive Trigger Enable</b><br>When set, the PRS channel selected by TSEL sets RXEN, enabling the receiver on positive trigger edges.                                           |
| 3:0   | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 20.5.6 USART\_CMD - Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |       |     |    |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|-------|-----|----|----|
| 0x014  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         | 15    | 14  | 13 | 12 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | W(nB)      | 0x0   | 11  |    |    |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | W(nB)      | 0x0   | 10  |    |    |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CLEARRX    | W(nB) | 0x0 | 9  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CLEARTX    | W(nB) | 0x0 | 8  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TXTRIDIS   | W(nB) | 0x0 | 7  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TXTRIEN    | W(nB) | 0x0 | 6  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXBLOCKDIS | W(nB) | 0x0 | 5  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXBLOCKEN  | W(nB) | 0x0 | 4  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MASTERDIS  | W(nB) | 0x0 | 3  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MASTERREN  | W(nB) | 0x0 | 2  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TXDIS      | W(nB) | 0x0 | 1  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TXEN       | W(nB) | 0x0 | 0  |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXDIS      | W(nB) | 0x0 |    |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXEN       | W(nB) | 0x0 |    |    |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                                                                                                                                    |
|-------|------------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                              |
| 11    | CLEARRX    | 0x0   | W(nB)  | <b>Clear RX</b><br>Set to clear receive buffer and the RX shift register.                                                                                                                                                                                                      |
| 10    | CLEARTX    | 0x0   | W(nB)  | <b>Clear TX</b><br>Set to clear transmit buffer and the TX shift register.                                                                                                                                                                                                     |
| 9     | TXTRIDIS   | 0x0   | W(nB)  | <b>Transmitter Tristate Disable</b><br>Disables tristating of the transmitter output.                                                                                                                                                                                          |
| 8     | TXTRIEN    | 0x0   | W(nB)  | <b>Transmitter Tristate Enable</b><br>Tristates the transmitter output.                                                                                                                                                                                                        |
| 7     | RXBLOCKDIS | 0x0   | W(nB)  | <b>Receiver Block Disable</b><br>Set to clear RXBLOCK, resulting in all incoming frames being loaded into the receive buffer.                                                                                                                                                  |
| 6     | RXBLOCKEN  | 0x0   | W(nB)  | <b>Receiver Block Enable</b><br>Set to set RXBLOCK, resulting in all incoming frames being discarded.                                                                                                                                                                          |
| 5     | MASTERDIS  | 0x0   | W(nB)  | <b>Main Mode Disable</b><br>Set to disable main interface mode, clearing the MASTER status bit and putting the USART in secondary interface mode.                                                                                                                              |
| 4     | MASTERREN  | 0x0   | W(nB)  | <b>Main Mode Enable</b><br>Set to enable main interface mode, setting the MASTER status bit. Main mode should not be enabled while TXENS is set to 1. To enable both main interface and TX mode, write MASTERREN before TXEN, or enable them both in the same write operation. |
| 3     | TXDIS      | 0x0   | W(nB)  | <b>Transmitter Disable</b><br>Set to disable transmission.                                                                                                                                                                                                                     |
| 2     | TXEN       | 0x0   | W(nB)  | <b>Transmitter Enable</b><br>Set to enable data transmission.                                                                                                                                                                                                                  |
| 1     | RXDIS      | 0x0   | W(nB)  | <b>Receiver Disable</b><br>Set to disable data reception. If a frame is under reception when the receiver is disabled, the incoming frame is discarded.                                                                                                                        |
| 0     | RXEN       | 0x0   | W(nB)  | <b>Receiver Enable</b>                                                                                                                                                                                                                                                         |

| Bit | Name | Reset | Access | Description                                 |
|-----|------|-------|--------|---------------------------------------------|
|     |      |       |        | Set to activate data reception on U(S)n_RX. |

### 20.5.7 USART\_STATUS - USART Status Register

| Offset | Bit Position |    |     |    |                |    |     |    |
|--------|--------------|----|-----|----|----------------|----|-----|----|
| Reset  | 31           | 30 | 29  | 28 | 27             | 26 | 25  | 24 |
| Access | 23           | 22 | 21  | 20 | 19             | 18 | 17  | 16 |
| Name   | TXBUFCNT     | R  | 0x0 | 15 | TIMERRESTARTED | R  | 0x0 | 14 |
|        |              |    |     |    | TXIDLE         | R  | 0x1 | 13 |
|        |              |    |     |    | RXFULLRIGHT    | R  | 0x0 | 12 |
|        |              |    |     |    | RXDATARIGHT    | R  | 0x0 | 11 |
|        |              |    |     |    | TXBRSRIGHT     | R  | 0x0 | 10 |
|        |              |    |     |    | TXBDRIGHT      | R  | 0x0 | 9  |
|        |              |    |     |    | RXFULL         | R  | 0x0 | 8  |
|        |              |    |     |    | RXDATAV        | R  | 0x0 | 7  |
|        |              |    |     |    | TXBL           | R  | 0x1 | 6  |
|        |              |    |     |    | TXC            | R  | 0x0 | 5  |
|        |              |    |     |    | TXTRI          | R  | 0x0 | 4  |
|        |              |    |     |    | RXBLOCK        | R  | 0x0 | 3  |
|        |              |    |     |    | MASTER         | R  | 0x0 | 2  |
|        |              |    |     |    | TXENS          | R  | 0x0 | 1  |
|        |              |    |     |    | RXENS          | R  | 0x0 | 0  |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                                                                                           |
| 17:16 | TXBUFCNT       | 0x0   | R      | <b>TX Buffer Count</b><br><br>Count of TX buffer entry 0, entry 1, and TX shift register. For large frames, the count is only of TX buffer entry 0 and the TX shifter register.                                                                                                                                                                                                                                                                                             |
| 15    | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                                                                                           |
| 14    | TIMERRESTARTED | 0x0   | R      | <b>The USART Timer restarted itself</b><br><br>When the timer is restarting itself on each TCMP event, a TIMERRESTARTED value of 0x0 indicates the first TCMP event in the sequence of multiple TCMP events. Any non TCMP timer start events will clear TIMERRESTARTED. When there is a TCMP interrupt and TIMERRESTARTED is 0x0, an interrupt service routine can set a TCMP event counter variable in memory to 0x1 to indicate the first TCMP interrupt of the sequence. |
| 13    | TXIDLE         | 0x1   | R      | <b>TX Idle</b><br><br>Set when TX idle                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12    | RXFULLRIGHT    | 0x0   | R      | <b>RX Full of Right Data</b><br><br>When set, the entire RX buffer contains right data. Only used in I2S mode                                                                                                                                                                                                                                                                                                                                                               |
| 11    | RXDATAVRIGHT   | 0x0   | R      | <b>RX Data Right</b><br><br>When set, reading RXDATA or RXDATAX gives right data. Else left data is read. Only used in I2S mode                                                                                                                                                                                                                                                                                                                                             |
| 10    | TXBSRIGHT      | 0x0   | R      | <b>TX Buffer Expects Single Right Data</b><br><br>When set, the TX buffer expects at least a single right data. Else it expects left data. Only used in I2S mode                                                                                                                                                                                                                                                                                                            |
| 9     | TXBDRIGHT      | 0x0   | R      | <b>TX Buffer Expects Double Right Data</b><br><br>When set, the TX buffer expects double right data. Else it may expect a single right data or left data. Only used in I2S mode                                                                                                                                                                                                                                                                                             |
| 8     | RXFULL         | 0x0   | R      | <b>RX FIFO Full</b><br><br>Set when the RXFIFO is full. Cleared when the receive buffer is no longer full. When this bit is set, there is still room for one more frame in the receive shift register.                                                                                                                                                                                                                                                                      |
| 7     | RXDATAV        | 0x0   | R      | <b>RX Data Valid</b><br><br>Set when data is available in the receive buffer. Cleared when the receive buffer is empty.                                                                                                                                                                                                                                                                                                                                                     |
| 6     | TXBL           | 0x1   | R      | <b>TX Buffer Level</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit | Name    | Reset | Access | Description                                                                                                                                                                                |
|-----|---------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         |       |        | Indicates the level of the transmit buffer. If TXBIL is 0x0, TXBL is set whenever the transmit buffer is completely empty. Otherwise TXBL is set whenever the TX Buffer becomes half full. |
| 5   | TXC     | 0x0   | R      | <b>TX Complete</b>                                                                                                                                                                         |
|     |         |       |        | Set when a transmission has completed and no more data is available in the transmit buffer and shift register. Cleared when data is written to the transmit buffer.                        |
| 4   | TXTRI   | 0x0   | R      | <b>Transmitter Tristated</b>                                                                                                                                                               |
|     |         |       |        | Set when the transmitter is tristated, and cleared when transmitter output is enabled. If AUTOTRI in USARTn_CTRL is set this bit is always read as 0.                                      |
| 3   | RXBLOCK | 0x0   | R      | <b>Block Incoming Data</b>                                                                                                                                                                 |
|     |         |       |        | When set, the receiver discards incoming frames. An incoming frame will not be loaded into the receive buffer if this bit is set at the instant the frame has been completely received.    |
| 2   | MASTER  | 0x0   | R      | <b>SPI Main Mode</b>                                                                                                                                                                       |
|     |         |       |        | Set when the USART operates as a main interface. Set using the MASTEREN command and clear using the MASTERS command.                                                                       |
| 1   | TXENS   | 0x0   | R      | <b>Transmitter Enable Status</b>                                                                                                                                                           |
|     |         |       |        | Set when the transmitter is enabled.                                                                                                                                                       |
| 0   | RXENS   | 0x0   | R      | <b>Receiver Enable Status</b>                                                                                                                                                              |
|     |         |       |        | Set when the receiver is enabled.                                                                                                                                                          |

#### 20.5.8 USART\_CLKDIV - Clock Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x01C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW  |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | AUTOBAUDEN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DIV |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                       |
|-------|------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | AUTOBAUDEN | 0x0   | RW     | <b>AUTOBAUD detection enable</b>                                                                                                                                  |
|       |            |       |        | Detects the baud rate based on receiving a 0x55 frame (0x00 for IrDA). This is used in Asynchronous mode.                                                         |
| 30:23 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 22:3  | DIV        | 0x0   | RW     | <b>Fractional Clock Divider</b>                                                                                                                                   |
|       |            |       |        | Specifies the fractional clock divider for the USART. Setting AUTOBAUDEN in USARTn_CLKDIV will overwrite the DIV field.                                           |
| 2:0   | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |

**20.5.9 USART\_RXDATAx - RX Buffer Data Extended Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |        |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|--------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x020  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0  | 0x0  | 0x0    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R    | R    | R      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FERR | PERR | RXDATA |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset                                                                                                                                                                      | Access | Description                                                                                                         |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                     |
| 15    | FERR     | 0x0                                                                                                                                                                        | R      | <b>Data Framing Error</b><br><br>Set if data in buffer has a framing error. Can be the result of a break condition. |
| 14    | PERR     | 0x0                                                                                                                                                                        | R      | <b>Data Parity Error</b><br><br>Set if data in buffer has a parity error (asynchronous mode only).                  |
| 13:9  | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                     |
| 8:0   | RXDATA   | 0x0                                                                                                                                                                        | R      | <b>RX Data</b><br><br>Use this register to access data read from the USART. Buffer is cleared on read access.       |

**20.5.10 USART\_RXDATA - RX Buffer Data Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x024  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R      | RXDATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXDATA |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name     | Reset                                                                                                                                                                      | Access | Description                                                                                                                                               |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                                                           |
| 7:0  | RXDATA   | 0x0                                                                                                                                                                        | R      | <b>RX Data</b><br><br>Use this register to access data read from USART. Buffer is cleared on read access. Only the 8 LSB can be read using this register. |

**20.5.11 USART\_RXDOUBLEX - RX Buffer Double Data Extended Register**

| Offset | Bit Position |       |     |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|--------|--------------|-------|-----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 0x028  | 31           | 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 |  |  |  |
| Reset  | 0x0          | R     | 0x0 | R  |    |    |    |    |    |    | 0x0     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Access | R            | R     |     |    |    |    |    |    |    |    | R       |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name   | FERR1        | PERR1 |     |    |    |    |    |    |    |    | RXDATA1 |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |       |     |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | FERR1    | 0x0   | R      | <b>Data Framing Error 1</b>                                                                                                                                                       |
|       |          |       |        | Set if data in buffer has a framing error. Can be the result of a break condition.                                                                                                |
| 30    | PERR1    | 0x0   | R      | <b>Data Parity Error 1</b>                                                                                                                                                        |
|       |          |       |        | Set if data in buffer has a parity error (asynchronous mode only).                                                                                                                |
| 29:25 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 24:16 | RXDATA1  | 0x0   | R      | <b>RX Data 1</b>                                                                                                                                                                  |
|       |          |       |        | Second frame read from buffer.                                                                                                                                                    |
| 15    | FERR0    | 0x0   | R      | <b>Data Framing Error 0</b>                                                                                                                                                       |
|       |          |       |        | Set if data in buffer has a framing error. Can be the result of a break condition.                                                                                                |
| 14    | PERR0    | 0x0   | R      | <b>Data Parity Error 0</b>                                                                                                                                                        |
|       |          |       |        | Set if data in buffer has a parity error (asynchronous mode only).                                                                                                                |
| 13:9  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8:0   | RXDATA0  | 0x0   | R      | <b>RX Data 0</b>                                                                                                                                                                  |
|       |          |       |        | First frame read from buffer.                                                                                                                                                     |

### 20.5.12 USART\_RXDOUBLE - RX FIFO Double Data Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |     |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|-----|---------|---|---|---|---|---|---|
| 0x02C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |   |   | 0x0 |         |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R       |    |    |    |    |    |   |   |     | R       |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXDATA1 |    |    |    |    |    |   |   |     | RXDATA0 |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:8  | RXDATA1  | 0x0   | R      | <b>RX Data 1</b><br>Second frame read from buffer.                                                                                                                                |
| 7:0   | RXDATA0  | 0x0   | R      | <b>RX Data 0</b><br>First frame read from buffer.                                                                                                                                 |

### 20.5.13 USART\_RXDATAP - RX Buffer Data Extended Peek Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |     |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|-----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 0x030  | 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 |   |   |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0   |    |     |    |    |    |    |    | 0x0 |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |     |    |    |    |    |    | R   |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FERRP | R  | 0x0 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PERRP | R  | 0x0 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15    | FERRP    | 0x0   | R      | <b>Data Framing Error Peek</b><br>Set if data in buffer has a framing error. Can be the result of a break condition.                                                              |
| 14    | PERRP    | 0x0   | R      | <b>Data Parity Error Peek</b><br>Set if data in buffer has a parity error (asynchronous mode only).                                                                               |
| 13:9  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8:0   | RXDATAP  | 0x0   | R      | <b>RX Data Peek</b><br>Use this register to access data read from the USART.                                                                                                      |

## 20.5.14 USART\_RXDOUBLEXP - RX Buffer Double Data Extended Peek R...

| Offset        | Bit Position |        |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |          |   |     |
|---------------|--------------|--------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|-----|
|               | 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   |
| <b>Reset</b>  | 0x0          | R      | 0x0 | 30 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |          |   | 0x0 |
| <b>Access</b> | R            | R      |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | R        |   |     |
| <b>Name</b>   | FERRP1       | PERRP1 |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RXDATAP0 |   |     |

| Bit   | Name     | Reset                                                                                                                                                                             | Access | Description                                                                                                                |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------|
| 31    | FERRP1   | 0x0                                                                                                                                                                               | R      | <b>Data Framing Error 1 Peek</b><br><br>Set if data in buffer has a framing error. Can be the result of a break condition. |
| 30    | PERRP1   | 0x0                                                                                                                                                                               | R      | <b>Data Parity Error 1 Peek</b><br><br>Set if data in buffer has a parity error (asynchronous mode only).                  |
| 29:25 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                            |
| 24:16 | RXDATAP1 | 0x0                                                                                                                                                                               | R      | <b>RX Data 1 Peek</b><br><br>Second frame read from FIFO.                                                                  |
| 15    | FERRP0   | 0x0                                                                                                                                                                               | R      | <b>Data Framing Error 0 Peek</b><br><br>Set if data in buffer has a framing error. Can be the result of a break condition. |
| 14    | PERRP0   | 0x0                                                                                                                                                                               | R      | <b>Data Parity Error 0 Peek</b><br><br>Set if data in buffer has a parity error (asynchronous mode only).                  |
| 13:9  | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                            |
| 8:0   | RXDATAP0 | 0x0                                                                                                                                                                               | R      | <b>RX Data 0 Peek</b><br><br>First frame read from FIFO.                                                                   |

#### 20.5.15 USART\_TXDATAx - TX Buffer Data Extended Register

| Offset | Bit Position |       |     |    |         |       |     |    |         |       |     |    |         |       |     |    |         |       |     |    |
|--------|--------------|-------|-----|----|---------|-------|-----|----|---------|-------|-----|----|---------|-------|-----|----|---------|-------|-----|----|
| Reset  | 31           | 30    | 29  | 28 | 27      | 26    | 25  | 24 | 23      | 22    | 21  | 20 | 19      | 18    | 17  | 16 |         |       |     |    |
| Access | RXENAT       | W(nB) | 0x0 | 15 | TXDISAT | W(nB) | 0x0 | 14 | TXBREAK | W(nB) | 0x0 | 13 | TXTRIAT | W(nB) | 0x0 | 12 | UBRXAT  | W(nB) | 0x0 | 11 |
| Name   |              |       |     |    |         |       |     |    |         |       |     |    |         |       |     |    | TXDATAL | W(nB) | 0x0 | 4  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15    | RXENAT   | 0x0   | W(nB)  | <b>Enable RX After Transmission</b><br><br>Set to enable reception after transmission.                                                                                            |
| 14    | TXDISAT  | 0x0   | W(nB)  | <b>Clear TXEN After Transmission</b><br><br>Set to disable transmitter and release data bus directly after transmission.                                                          |
| 13    | TXBREAK  | 0x0   | W(nB)  | <b>Transmit Data As Break</b><br><br>Set to send data as a break. Recipient will see a framing error or a break condition depending on its configuration and the value of TXDATA. |
| 12    | TXTRIAT  | 0x0   | W(nB)  | <b>Set TXTRI After Transmission</b><br><br>Set to tristate transmitter by setting TXTRI after transmission.                                                                       |
| 11    | UBRXAT   | 0x0   | W(nB)  | <b>Unblock RX After Transmission</b><br><br>Set to clear RXBLOCK after transmission, unblocking the receiver.                                                                     |
| 10:9  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8:0   | TXDATAB  | 0x0   | W(nB)  | <b>TX Data</b><br><br>Use this register to write data to the USART. If TXEN is set, a transfer will be initiated at the first opportunity.                                        |

**20.5.16 USART\_TXDATA - TX Buffer Data Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |       |        |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-------|--------|---|
| 0x03C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0   |        |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | W(nB) |        |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |       | TXDATA |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | TXDATA   | 0x0   | W(nB)  | <b>TX Data</b><br><br>This frame will be added to TX buffer. Only 8 LSB can be written using this register. 9th bit and control bits will be cleared.                             |

## 20.5.17 USART\_TXDOUBLEX - TX Buffer Double Data Extended Register

| Offset | Bit Position |          |          |          |         |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |     |         |   |
|--------|--------------|----------|----------|----------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----|---------|---|
| 0x040  | 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 |
| Reset  | 0x0          | 0x0      | 0x0      | 0x0      | 0x0     | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0   | 0x0 |         |   |
| Access | W(nB)        | W(nB)    | W(nB)    | W(nB)    | W(nB)   | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) | W(nB) |     |         |   |
| Name   | RXENAT1      | TXDISAT1 | TXBREAK1 | TXTRIAT1 | UBRXAT1 |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |     | TXDATA0 |   |

| Bit   | Name     | Reset                                                                                                                                                             | Access | Description                                                                                                                                                                              |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RXENAT1  | 0x0                                                                                                                                                               | W(nB)  | <b>Enable RX After Transmission</b><br><br>Set to enable reception after transmission.                                                                                                   |
| 30    | TXDISAT1 | 0x0                                                                                                                                                               | W(nB)  | <b>Clear TXEN After Transmission</b><br><br>Set to disable transmitter and release data bus directly after transmission.                                                                 |
| 29    | TXBREAK1 | 0x0                                                                                                                                                               | W(nB)  | <b>Transmit Data As Break</b><br><br>Set to send data as a break. Recipient will see a framing error or a break condition depending on its configuration and the value of USARTn_TXDATA. |
| 28    | TXTRIAT1 | 0x0                                                                                                                                                               | W(nB)  | <b>Set TXTRI After Transmission</b><br><br>Set to tristate transmitter by setting TXTRI after transmission.                                                                              |
| 27    | UBRXAT1  | 0x0                                                                                                                                                               | W(nB)  | <b>Unblock RX After Transmission</b><br><br>Set clear RXBLOCK after transmission, unblocking the receiver.                                                                               |
| 26:25 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                                                                                                                          |
| 24:16 | TXDATA1  | 0x0                                                                                                                                                               | W(nB)  | <b>TX Data</b><br><br>Second frame to write to FIFO.                                                                                                                                     |
| 15    | RXENAT0  | 0x0                                                                                                                                                               | W(nB)  | <b>Enable RX After Transmission</b><br><br>Set to enable reception after transmission.                                                                                                   |
| 14    | TXDISAT0 | 0x0                                                                                                                                                               | W(nB)  | <b>Clear TXEN After Transmission</b><br><br>Set to disable transmitter and release data bus directly after transmission.                                                                 |
| 13    | TXBREAK0 | 0x0                                                                                                                                                               | W(nB)  | <b>Transmit Data As Break</b><br><br>Set to send data as a break. Recipient will see a framing error or a break condition depending on its configuration and the value of TXDATA.        |
| 12    | TXTRIAT0 | 0x0                                                                                                                                                               | W(nB)  | <b>Set TXTRI After Transmission</b><br><br>Set to tristate transmitter by setting TXTRI after transmission.                                                                              |
| 11    | UBRXATO  | 0x0                                                                                                                                                               | W(nB)  | <b>Unblock RX After Transmission</b><br><br>Set clear RXBLOCK after transmission, unblocking the receiver.                                                                               |
| 10:9  | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                                                                                                                          |
| 8:0   | TXDATA0  | 0x0                                                                                                                                                               | W(nB)  | <b>TX Data</b>                                                                                                                                                                           |

| Bit                             | Name | Reset | Access | Description |
|---------------------------------|------|-------|--------|-------------|
| First frame to write to buffer. |      |       |        |             |

### 20.5.18 USART\_TXDOUBLE - TX Buffer Double Data Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| 0x044  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |    |    |    |    |   |   | 0x0     |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    | W       |    |    |    |    |    |    |    |    |    |   |   | W       |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | TXDATA1 |    |    |    |    |    |    |    |    |    |   |   | TXDATA0 |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                       |
|-------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:8  | TXDATA1  | 0x0   | W      | <b>TX Data</b><br>Second frame to write to buffer.                                                                                                                |
| 7:0   | TXDATA0  | 0x0   | W      | <b>TX Data</b><br>First frame to write to buffer.                                                                                                                 |

**20.5.19 USART\_IF - Interrupt Flag Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       | 16    | 15  | 14  | 13    | 12    | 11  | 10  | 9     | 8     | 7   | 6   | 5      | 4      | 3   | 2   | 1   | 0   |     |     |     |     |     |     |      |      |     |     |      |      |     |     |      |      |     |     |      |      |     |     |      |      |     |     |        |        |     |     |       |       |     |     |      |      |     |     |     |     |     |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|-----|-----|-------|-------|-----|-----|-------|-------|-----|-----|--------|--------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|------|-----|-----|------|------|-----|-----|------|------|-----|-----|------|------|-----|-----|------|------|-----|-----|--------|--------|-----|-----|-------|-------|-----|-----|------|------|-----|-----|-----|-----|-----|-----|---|
| 0x048  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | TCMP2 | RW    | 0x0 | 16  | TCMP1 | RW    | 0x0 | 15  | TCMP0 | RW    | 0x0 | 14  | TXIDLE | RW     | 0x0 | 13  | CCF | RW  | 0x0 | 12  | SSM | RW  | 0x0 | 11  | MPAF | RW   | 0x0 | 10  | FERR | RW   | 0x0 | 9   | PERR | RW   | 0x0 | 8   | TXUF | RW   | 0x0 | 7   | TXOF | RW   | 0x0 | 6   | RXFULL | RW     | 0x0 | 5   | RXDAV | RW    | 0x0 | 3   | TXBL | RW   | 0x1 | 1   | TXC | RW  | 0x0 | 0   |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       | TCMP2 | RW  | 0x0 | 16    | TCMP1 | RW  | 0x0 | 15    | TCMP0 | RW  | 0x0 | 14     | TXIDLE | RW  | 0x0 | 13  | CCF | RW  | 0x0 | 12  | SSM | RW  | 0x0 | 11   | MPAF | RW  | 0x0 | 10   | FERR | RW  | 0x0 | 9    | PERR | RW  | 0x0 | 8    | TXUF | RW  | 0x0 | 7    | TXOF | RW  | 0x0 | 6      | RXFULL | RW  | 0x0 | 5     | RXDAV | RW  | 0x0 | 3    | TXBL | RW  | 0x1 | 1   | TXC | RW  | 0x0 | 0 |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       | TCMP2 | RW  | 0x0 | 16    | TCMP1 | RW  | 0x0 | 15    | TCMP0 | RW  | 0x0 | 14     | TXIDLE | RW  | 0x0 | 13  | CCF | RW  | 0x0 | 12  | SSM | RW  | 0x0 | 11   | MPAF | RW  | 0x0 | 10   | FERR | RW  | 0x0 | 9    | PERR | RW  | 0x0 | 8    | TXUF | RW  | 0x0 | 7    | TXOF | RW  | 0x0 | 6      | RXFULL | RW  | 0x0 | 5     | RXDAV | RW  | 0x0 | 3    | TXBL | RW  | 0x1 | 1   | TXC | RW  | 0x0 | 0 |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       | TCMP2 | RW  | 0x0 | 16    | TCMP1 | RW  | 0x0 | 15    | TCMP0 | RW  | 0x0 | 14     | TXIDLE | RW  | 0x0 | 13  | CCF | RW  | 0x0 | 12  | SSM | RW  | 0x0 | 11   | MPAF | RW  | 0x0 | 10   | FERR | RW  | 0x0 | 9    | PERR | RW  | 0x0 | 8    | TXUF | RW  | 0x0 | 7    | TXOF | RW  | 0x0 | 6      | RXFULL | RW  | 0x0 | 5     | RXDAV | RW  | 0x0 | 3    | TXBL | RW  | 0x1 | 1   | TXC | RW  | 0x0 | 0 |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                  |
|-------|----------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>            |
| 16    | TCMP2    | 0x0   | RW     | <b>Timer comparator 2 Interrupt Flag</b><br>Set when the timer reaches the comparator 2 value, TCMP2.                                                                                        |
| 15    | TCMP1    | 0x0   | RW     | <b>Timer comparator 1 Interrupt Flag</b><br>Set when the timer reaches the comparator 1 value, TCMP1.                                                                                        |
| 14    | TCMP0    | 0x0   | RW     | <b>Timer comparator 0 Interrupt Flag</b><br>Set when the Timer reaches the comparator 0 value, TCMP0.                                                                                        |
| 13    | TXIDLE   | 0x0   | RW     | <b>TX Idle Interrupt Flag</b><br>Set when TX goes idle. At this point, transmission has ended                                                                                                |
| 12    | CCF      | 0x0   | RW     | <b>Collision Check Fail Interrupt Flag</b><br>Set when a collision check notices an error in the transmitted data.                                                                           |
| 11    | SSM      | 0x0   | RW     | <b>Chip-Select In Main Mode Interrupt Flag</b><br>Set when the chip select is pulled active when in main interface mode.                                                                     |
| 10    | MPAF     | 0x0   | RW     | <b>Multi-Processor Address Frame Interrupt</b><br>Set when a multi-processor address frame is detected.                                                                                      |
| 9     | FERR     | 0x0   | RW     | <b>Framing Error Interrupt Flag</b><br>Set when a frame with a framing error is received while RXBLOCK is cleared.                                                                           |
| 8     | PERR     | 0x0   | RW     | <b>Parity Error Interrupt Flag</b><br>Set when a frame with a parity error (asynchronous mode only) is received while RXBLOCK is cleared.                                                    |
| 7     | TXUF     | 0x0   | RW     | <b>TX Underflow Interrupt Flag</b><br>Set when operating as a synchronous secondary, no data is available in the transmit buffer when the main interface starts transmission of a new frame. |
| 6     | TXOF     | 0x0   | RW     | <b>TX Overflow Interrupt Flag</b><br>Set when a write is done to the transmit buffer while it is full. The data already in the transmit buffer is preserved.                                 |
| 5     | RXUF     | 0x0   | RW     | <b>RX Underflow Interrupt Flag</b><br>Set when trying to read from the receive buffer when it is empty.                                                                                      |
| 4     | RXOF     | 0x0   | RW     | <b>RX Overflow Interrupt Flag</b><br>Set when data is incoming while the receive shift register is full. The data previously in the shift register is lost.                                  |

| Bit | Name    | Reset | Access | Description                                                                                                                                                                         |
|-----|---------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RXFULL  | 0x0   | RW     | <b>RX Buffer Full Interrupt Flag</b><br>Set when the receive buffer becomes full.                                                                                                   |
| 2   | RXDATAV | 0x0   | RW     | <b>RX Data Valid Interrupt Flag</b><br>Set when data becomes available in the receive buffer.                                                                                       |
| 1   | TXBL    | 0x1   | RW     | <b>TX Buffer Level Interrupt Flag</b><br>Set when buffer becomes empty if buffer level is set to 0x0, or when the number of empty TX buffer elements equals specified buffer level. |
| 0   | TXC     | 0x0   | RW     | <b>TX Complete Interrupt Flag</b><br>This interrupt is set after a transmission when both the TX buffer and shift register are empty.                                               |

### 20.5.20 USART\_IEN - Interrupt Enable Register

| Offset  | Bit Position |     |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
|---------|--------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| 0x04C   | 31           | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 |  |
| Reset   |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| Access  |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| Name    |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TCMP2   | RW           | 0x0 | 16 |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TCMP1   | RW           | 0x0 | 15 |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TCMP0   | RW           | 0x0 | 14 |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TXIDLE  | RW           | 0x0 | 13 |    |    |    |    |    |    |    |    |    |    |    |    |  |
| CCF     | RW           | 0x0 | 12 |    |    |    |    |    |    |    |    |    |    |    |    |  |
| SSM     | RW           | 0x0 | 11 |    |    |    |    |    |    |    |    |    |    |    |    |  |
| MPAF    | RW           | 0x0 | 10 |    |    |    |    |    |    |    |    |    |    |    |    |  |
| FERR    | RW           | 0x0 | 9  |    |    |    |    |    |    |    |    |    |    |    |    |  |
| PERR    | RW           | 0x0 | 8  |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TXUF    | RW           | 0x0 | 7  |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TXOF    | RW           | 0x0 | 6  |    |    |    |    |    |    |    |    |    |    |    |    |  |
| RXFULL  | RW           | 0x0 | 5  |    |    |    |    |    |    |    |    |    |    |    |    |  |
| RXDATAV | RW           | 0x0 | 4  |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TXBL    | RW           | 0x0 | 3  |    |    |    |    |    |    |    |    |    |    |    |    |  |
| TXC     | RW           | 0x0 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                    |
|-------|----------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>              |
| 16    | TCMP2    | 0x0   | RW     | <b>Timer comparator 2 Interrupt Enable</b><br>Set when the timer reaches the comparator 2 value, TCMP2.                                                                                        |
| 15    | TCMP1    | 0x0   | RW     | <b>Timer comparator 1 Interrupt Enable</b><br>Set when the timer reaches the comparator 1 value, TCMP1.                                                                                        |
| 14    | TCMP0    | 0x0   | RW     | <b>Timer comparator 0 Interrupt Enable</b><br>Set when the Timer reaches the comparator 0 value, TCMP0.                                                                                        |
| 13    | TXIDLE   | 0x0   | RW     | <b>TX Idle Interrupt Enable</b><br>Set when TX goes idle. At this point, transmission has ended                                                                                                |
| 12    | CCF      | 0x0   | RW     | <b>Collision Check Fail Interrupt Enable</b><br>Set when a collision check notices an error in the transmitted data.                                                                           |
| 11    | SSM      | 0x0   | RW     | <b>Chip-Select In Main Mode Interrupt Flag</b><br>Set when the chip select is pulled active when in main interface mode.                                                                       |
| 10    | MPAF     | 0x0   | RW     | <b>Multi-Processor Address Frame Interrupt</b><br>Set when a multi-processor address frame is detected.                                                                                        |
| 9     | FERR     | 0x0   | RW     | <b>Framing Error Interrupt Enable</b><br>Set when a frame with a framing error is received while RXBLOCK is cleared.                                                                           |
| 8     | PERR     | 0x0   | RW     | <b>Parity Error Interrupt Enable</b><br>Set when a frame with a parity error (asynchronous mode only) is received while RXBLOCK is cleared.                                                    |
| 7     | TXUF     | 0x0   | RW     | <b>TX Underflow Interrupt Enable</b><br>Set when operating as a synchronous secondary, no data is available in the transmit buffer when the main interface starts transmission of a new frame. |
| 6     | TXOF     | 0x0   | RW     | <b>TX Overflow Interrupt Enable</b><br>Set when a write is done to the transmit buffer while it is full. The data already in the transmit buffer is preserved.                                 |
| 5     | RXUF     | 0x0   | RW     | <b>RX Underflow Interrupt Enable</b><br>Set when trying to read from the receive buffer when it is empty.                                                                                      |
| 4     | RXOF     | 0x0   | RW     | <b>RX Overflow Interrupt Enable</b><br>Set when data is incoming while the receive shift register is full. The data previously in the shift register is lost.                                  |

| Bit | Name    | Reset | Access | Description                                                                                                                                                                           |
|-----|---------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RXFULL  | 0x0   | RW     | <b>RX Buffer Full Interrupt Enable</b><br>Set when the receive buffer becomes full.                                                                                                   |
| 2   | RXDATAV | 0x0   | RW     | <b>RX Data Valid Interrupt Enable</b><br>Set when data becomes available in the receive buffer.                                                                                       |
| 1   | TXBL    | 0x0   | RW     | <b>TX Buffer Level Interrupt Enable</b><br>Set when buffer becomes empty if buffer level is set to 0x0, or when the number of empty TX buffer elements equals specified buffer level. |
| 0   | TXC     | 0x0   | RW     | <b>TX Complete Interrupt Enable</b><br>This interrupt is set after a transmission when both the TX buffer and shift register are empty.                                               |

#### 20.5.21 USART\_IRCTRL - IrDA Control Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |        |      |      |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|------|------|
| 0x050         | 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    |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0    | 3    |      |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW     | 0x0  |      |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | IRFILT | IRPW | IREN |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                                                                                               |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                           |
| 3    | IRFILT   | 0x0                                                                                                                                                                               | RW     | <b>IrDA RX Filter</b><br>Set to enable filter on IrDA demodulator.                                                                        |
|      | Value    | Mode                                                                                                                                                                              |        | Description                                                                                                                               |
|      | 0        | DISABLE                                                                                                                                                                           |        | No filter enabled                                                                                                                         |
|      | 1        | ENABLE                                                                                                                                                                            |        | Filter enabled. IrDA pulse must be high for at least 5 consecutive clock cycles to be detected                                            |
| 2:1  | IRPW     | 0x0                                                                                                                                                                               | RW     | <b>IrDA TX Pulse Width</b><br>Configure the pulse width generated by the IrDA modulator as a fraction of the configured USART bit period. |
|      | Value    | Mode                                                                                                                                                                              |        | Description                                                                                                                               |
|      | 0        | ONE                                                                                                                                                                               |        | IrDA pulse width is 1/16 for OVS=0 and 1/8 for OVS=1                                                                                      |
|      | 1        | TWO                                                                                                                                                                               |        | IrDA pulse width is 2/16 for OVS=0 and 2/8 for OVS=1                                                                                      |
|      | 2        | THREE                                                                                                                                                                             |        | IrDA pulse width is 3/16 for OVS=0 and 3/8 for OVS=1                                                                                      |
|      | 3        | FOUR                                                                                                                                                                              |        | IrDA pulse width is 4/16 for OVS=0 and 4/8 for OVS=1                                                                                      |
| 0    | IREN     | 0x0                                                                                                                                                                               | RW     | <b>Enable IrDA Module</b><br>Enable IrDA module and route USART signals through it.                                                       |

**20.5.22 USART\_I2SCTRL - I2S Control Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |         |    |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---------|----|-----|---|
| 0x054         | 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  |     |   |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0      | 4       |    |     |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW       | 0x0     | 3  |     |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | FORMAT   | DELAY   | RW | 0x0 | 2 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DMASPLIT | JUSTIFY | RW | 0x0 | 1 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | MONO     | EN      | RW | 0x0 | 0 |

| Bit   | Name                                                                                                                                     | Reset                                                                                                                                                                             | Access                                     | Description                                     |
|-------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------|
| 31:11 | <i>Reserved</i>                                                                                                                          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |                                            |                                                 |
| 10:8  | FORMAT                                                                                                                                   | 0x0                                                                                                                                                                               | RW                                         | <b>I2S Word Format</b>                          |
|       | Configure the data-width used internally for I2S data                                                                                    |                                                                                                                                                                                   |                                            |                                                 |
|       | Value                                                                                                                                    | Mode                                                                                                                                                                              | Description                                |                                                 |
|       | 0                                                                                                                                        | W32D32                                                                                                                                                                            | 32-bit word, 32-bit data                   |                                                 |
|       | 1                                                                                                                                        | W32D24M                                                                                                                                                                           | 32-bit word, 32-bit data with 8 lsb masked |                                                 |
|       | 2                                                                                                                                        | W32D24                                                                                                                                                                            | 32-bit word, 24-bit data                   |                                                 |
|       | 3                                                                                                                                        | W32D16                                                                                                                                                                            | 32-bit word, 16-bit data                   |                                                 |
|       | 4                                                                                                                                        | W32D8                                                                                                                                                                             | 32-bit word, 8-bit data                    |                                                 |
|       | 5                                                                                                                                        | W16D16                                                                                                                                                                            | 16-bit word, 16-bit data                   |                                                 |
|       | 6                                                                                                                                        | W16D8                                                                                                                                                                             | 16-bit word, 8-bit data                    |                                                 |
|       | 7                                                                                                                                        | W8D8                                                                                                                                                                              | 8-bit word, 8-bit data                     |                                                 |
| 7:5   | <i>Reserved</i>                                                                                                                          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |                                            |                                                 |
| 4     | DELAY                                                                                                                                    | 0x0                                                                                                                                                                               | RW                                         | <b>Delay on I2S data</b>                        |
|       | Set to add a one-cycle delay between a transition on the word-clock and the start of the I2S word. Should be set for standard I2S format |                                                                                                                                                                                   |                                            |                                                 |
| 3     | DMASPLIT                                                                                                                                 | 0x0                                                                                                                                                                               | RW                                         | <b>Separate DMA Request For Left/Right Data</b> |
|       | When set DMA requests for right-channel data are put on the TXBLRIGHT and RXDATAVRIGHT DMA requests.                                     |                                                                                                                                                                                   |                                            |                                                 |
| 2     | JUSTIFY                                                                                                                                  | 0x0                                                                                                                                                                               | RW                                         | <b>Justification of I2S Data</b>                |
|       | Determines whether the I2S data is left or right justified                                                                               |                                                                                                                                                                                   |                                            |                                                 |
|       | Value                                                                                                                                    | Mode                                                                                                                                                                              | Description                                |                                                 |
|       | 0                                                                                                                                        | LEFT                                                                                                                                                                              | Data is left-justified                     |                                                 |
|       | 1                                                                                                                                        | RIGHT                                                                                                                                                                             | Data is right-justified                    |                                                 |
| 1     | MONO                                                                                                                                     | 0x0                                                                                                                                                                               | RW                                         | <b>Stereo or Mono</b>                           |
|       | Switch between stereo and mono mode. Set for mono                                                                                        |                                                                                                                                                                                   |                                            |                                                 |
| 0     | EN                                                                                                                                       | 0x0                                                                                                                                                                               | RW                                         | <b>Enable I2S Mode</b>                          |

| Bit | Name | Reset | Access | Description                  |
|-----|------|-------|--------|------------------------------|
|     |      |       |        | Set the U(S)ART in I2S mode. |

### 20.5.23 USART\_TIMING - Timing Register

| Offset        | Bit Position |        |     |    |     |     |    |         |    |     |    |    |     |         |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|--------------|--------|-----|----|-----|-----|----|---------|----|-----|----|----|-----|---------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x058         | 31           | 30     | 29  | 28 | 27  | 26  | 25 | 24      | 23 | 22  | 20 | 19 | 18  | 17      | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>Reset</b>  |              |        | 0x0 |    |     | 0x0 |    |         |    | 0x0 |    |    | 0x0 |         |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Access</b> |              | RW     |     |    | RW  |     |    | RW      |    | RW  |    |    | RW  |         |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Name</b>   |              | CSHOLD |     |    | ICS |     |    | CSSETUP |    |     |    |    |     | TXDELAY |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name                                                                                                                                                                                              | Reset                                                                                                                                                                                 | Access | Description                                                                                                                                                                       |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved                                                                                                                                                                                          |                                                                                                                                                                                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 30:28 | CSHOLD                                                                                                                                                                                            | 0x0                                                                                                                                                                                   | RW     | <b>Chip Select Hold</b>                                                                                                                                                           |
|       |                                                                                                                                                                                                   | Chip Select will be asserted after the end of frame transmission. When using TCMPn, normally set TIMECMPn_TSTART to DISABLE to stop general timer and to prevent unwanted interrupts. |        |                                                                                                                                                                                   |
|       | Value                                                                                                                                                                                             | Mode                                                                                                                                                                                  |        | Description                                                                                                                                                                       |
|       | 0                                                                                                                                                                                                 | ZERO                                                                                                                                                                                  |        | Disable CS being asserted after the end of transmission                                                                                                                           |
|       | 1                                                                                                                                                                                                 | ONE                                                                                                                                                                                   |        | CS is asserted for 1 baud-times after the end of transmission                                                                                                                     |
|       | 2                                                                                                                                                                                                 | TWO                                                                                                                                                                                   |        | CS is asserted for 2 baud-times after the end of transmission                                                                                                                     |
|       | 3                                                                                                                                                                                                 | THREE                                                                                                                                                                                 |        | CS is asserted for 3 baud-times after the end of transmission                                                                                                                     |
|       | 4                                                                                                                                                                                                 | SEVEN                                                                                                                                                                                 |        | CS is asserted for 7 baud-times after the end of transmission                                                                                                                     |
|       | 5                                                                                                                                                                                                 | TCMP0                                                                                                                                                                                 |        | CS is asserted after the end of transmission for TCMPVAL0 baud-times                                                                                                              |
|       | 6                                                                                                                                                                                                 | TCMP1                                                                                                                                                                                 |        | CS is asserted after the end of transmission for TCMPVAL1 baud-times                                                                                                              |
|       | 7                                                                                                                                                                                                 | TCMP2                                                                                                                                                                                 |        | CS is asserted after the end of transmission for TCMPVAL2 baud-times                                                                                                              |
| 27    | Reserved                                                                                                                                                                                          |                                                                                                                                                                                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 26:24 | ICS                                                                                                                                                                                               | 0x0                                                                                                                                                                                   | RW     | <b>Inter-character spacing</b>                                                                                                                                                    |
|       | Inter-character spacing after each TX frame while the TX buffer is not empty. When using USART_TIMECMPn, normally set TSTART to DISABLE to stop general timer and to prevent unwanted interrupts. |                                                                                                                                                                                       |        |                                                                                                                                                                                   |
|       | Value                                                                                                                                                                                             | Mode                                                                                                                                                                                  |        | Description                                                                                                                                                                       |
|       | 0                                                                                                                                                                                                 | ZERO                                                                                                                                                                                  |        | There is no space between characters                                                                                                                                              |
|       | 1                                                                                                                                                                                                 | ONE                                                                                                                                                                                   |        | Create a space of 1 baud-times before start of transmission                                                                                                                       |
|       | 2                                                                                                                                                                                                 | TWO                                                                                                                                                                                   |        | Create a space of 2 baud-times before start of transmission                                                                                                                       |
|       | 3                                                                                                                                                                                                 | THREE                                                                                                                                                                                 |        | Create a space of 3 baud-times before start of transmission                                                                                                                       |
|       | 4                                                                                                                                                                                                 | SEVEN                                                                                                                                                                                 |        | Create a space of 7 baud-times before start of transmission                                                                                                                       |
|       | 5                                                                                                                                                                                                 | TCMP0                                                                                                                                                                                 |        | Create a space of before the start of transmission for TCMPVAL0 baud-times                                                                                                        |

| Bit   | Name     | Reset                                                                   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
|-------|----------|-------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|---------|---------------------------------------------------------|---|-----|--------------------------------------------------------------|---|-----|--------------------------------------------------------------|---|-------|--------------------------------------------------------------|---|-------|--------------------------------------------------------------|---|-------|-------------------------------------------------------------------------|---|-------|-------------------------------------------------------------------------|---|-------|-------------------------------------------------------------------------|
| 6     |          | TCMP1                                                                   |        | Create a space of before the start of transmission for TCMPVAL1 baud-times                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 7     |          | TCMP2                                                                   |        | Create a space of before the start of transmission for TCMPVAL2 baud-times                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 23    | Reserved |                                                                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 22:20 | CSSETUP  | 0x0                                                                     | RW     | <b>Chip Select Setup</b><br><br>Chip Select will be asserted before the start of frame transmission. When using USART_TIMECMPn, normally set TSTART to DISABLE to stop general timer and to prevent unwanted interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
|       |          |                                                                         |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>ZERO</td><td>CS is not asserted before start of transmission</td></tr> <tr> <td>1</td><td>ONE</td><td>CS is asserted for 1 baud-times before start of transmission</td></tr> <tr> <td>2</td><td>TWO</td><td>CS is asserted for 2 baud-times before start of transmission</td></tr> <tr> <td>3</td><td>THREE</td><td>CS is asserted for 3 baud-times before start of transmission</td></tr> <tr> <td>4</td><td>SEVEN</td><td>CS is asserted for 7 baud-times before start of transmission</td></tr> <tr> <td>5</td><td>TCMP0</td><td>CS is asserted before the start of transmission for TCMPVAL0 baud-times</td></tr> <tr> <td>6</td><td>TCMP1</td><td>CS is asserted before the start of transmission for TCMPVAL1 baud-times</td></tr> <tr> <td>7</td><td>TCMP2</td><td>CS is asserted before the start of transmission for TCMPVAL2 baud-times</td></tr> </tbody> </table> | Value | Mode | Description | 0 | ZERO    | CS is not asserted before start of transmission         | 1 | ONE | CS is asserted for 1 baud-times before start of transmission | 2 | TWO | CS is asserted for 2 baud-times before start of transmission | 3 | THREE | CS is asserted for 3 baud-times before start of transmission | 4 | SEVEN | CS is asserted for 7 baud-times before start of transmission | 5 | TCMP0 | CS is asserted before the start of transmission for TCMPVAL0 baud-times | 6 | TCMP1 | CS is asserted before the start of transmission for TCMPVAL1 baud-times | 7 | TCMP2 | CS is asserted before the start of transmission for TCMPVAL2 baud-times |
| Value | Mode     | Description                                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 0     | ZERO     | CS is not asserted before start of transmission                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 1     | ONE      | CS is asserted for 1 baud-times before start of transmission            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 2     | TWO      | CS is asserted for 2 baud-times before start of transmission            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 3     | THREE    | CS is asserted for 3 baud-times before start of transmission            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 4     | SEVEN    | CS is asserted for 7 baud-times before start of transmission            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 5     | TCMP0    | CS is asserted before the start of transmission for TCMPVAL0 baud-times |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 6     | TCMP1    | CS is asserted before the start of transmission for TCMPVAL1 baud-times |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 7     | TCMP2    | CS is asserted before the start of transmission for TCMPVAL2 baud-times |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 19    | Reserved |                                                                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 18:16 | TXDELAY  | 0x0                                                                     | RW     | <b>TX frame start delay</b><br><br>Number of baud-times to delay the start of frame transmission. When using USART_TIMECMPn, normally set TSTART to DISABLE to stop general timer and to prevent unwanted interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
|       |          |                                                                         |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>Disable - TXDELAY in USARTn_CTRL can be used for legacy</td></tr> <tr> <td>1</td><td>ONE</td><td>Start of transmission is delayed for 1 baud-times</td></tr> <tr> <td>2</td><td>TWO</td><td>Start of transmission is delayed for 2 baud-times</td></tr> <tr> <td>3</td><td>THREE</td><td>Start of transmission is delayed for 3 baud-times</td></tr> <tr> <td>4</td><td>SEVEN</td><td>Start of transmission is delayed for 7 baud-times</td></tr> <tr> <td>5</td><td>TCMP0</td><td>Start of transmission is delayed for TCMPVAL0 baud-times</td></tr> <tr> <td>6</td><td>TCMP1</td><td>Start of transmission is delayed for TCMPVAL1 baud-times</td></tr> <tr> <td>7</td><td>TCMP2</td><td>Start of transmission is delayed for TCMPVAL2 baud-times</td></tr> </tbody> </table>                                                                               | Value | Mode | Description | 0 | DISABLE | Disable - TXDELAY in USARTn_CTRL can be used for legacy | 1 | ONE | Start of transmission is delayed for 1 baud-times            | 2 | TWO | Start of transmission is delayed for 2 baud-times            | 3 | THREE | Start of transmission is delayed for 3 baud-times            | 4 | SEVEN | Start of transmission is delayed for 7 baud-times            | 5 | TCMP0 | Start of transmission is delayed for TCMPVAL0 baud-times                | 6 | TCMP1 | Start of transmission is delayed for TCMPVAL1 baud-times                | 7 | TCMP2 | Start of transmission is delayed for TCMPVAL2 baud-times                |
| Value | Mode     | Description                                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 0     | DISABLE  | Disable - TXDELAY in USARTn_CTRL can be used for legacy                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 1     | ONE      | Start of transmission is delayed for 1 baud-times                       |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 2     | TWO      | Start of transmission is delayed for 2 baud-times                       |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 3     | THREE    | Start of transmission is delayed for 3 baud-times                       |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 4     | SEVEN    | Start of transmission is delayed for 7 baud-times                       |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 5     | TCMP0    | Start of transmission is delayed for TCMPVAL0 baud-times                |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 6     | TCMP1    | Start of transmission is delayed for TCMPVAL1 baud-times                |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 7     | TCMP2    | Start of transmission is delayed for TCMPVAL2 baud-times                |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |
| 15:0  | Reserved |                                                                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      |             |   |         |                                                         |   |     |                                                              |   |     |                                                              |   |       |                                                              |   |       |                                                              |   |       |                                                                         |   |       |                                                                         |   |       |                                                                         |

## 20.5.24 USART\_CTRLX - Control Register Extended

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |   |   |         |    |     |    |     |        |       |        |         |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|---|---|---------|----|-----|----|-----|--------|-------|--------|---------|
| 0x05C  | 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  |     |        |       |        |         |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0      |    |    |    |    |    |    |   |   | 0x0     | 3  | 0x0 | 2  | 0x0 | 1      | 0x0   | 0      |         |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW       |    |    |    |    |    |    |   |   | RW      | RW | RW  | RW | RW  | RW     | RW    | RW     |         |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CLKPRSEN |    |    |    |    |    |    |   |   | RXPRSEN |    |     |    |     | RTSINV | CTSEN | CTSINV | DBGHALT |

| Bit   | Name     | Reset   | Access | Description                                                                                                                                                                                                                                    |
|-------|----------|---------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                              |
| 15    | CLKPRSEN | 0x0     | RW     | <b>PRS CLK Enable</b><br><br>When set, the PRS channel selected as input to CLK.                                                                                                                                                               |
| 14:8  | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                              |
| 7     | RXPRSEN  | 0x0     | RW     | <b>PRS RX Enable</b><br><br>When set, the PRS channel selected as input to RX.                                                                                                                                                                 |
| 6:4   | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                              |
| 3     | RTSINV   | 0x0     | RW     | <b>RTS Pin Inversion</b><br><br>When set, the RTS pin polarity is inverted.                                                                                                                                                                    |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                                                    |
|       | 0        | DISABLE |        | The USn_RTS pin is low true                                                                                                                                                                                                                    |
|       | 1        | ENABLE  |        | The USn_RTS pin is high true                                                                                                                                                                                                                   |
| 2     | CTSEN    | 0x0     | RW     | <b>CTS Function enabled</b><br><br>When set, frames in the TXBUFn will not be sent until link partner asserts CTS. Any data in the TX shift register will continue transmitting, the next TXBUFn data will not load into the TX shift register |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                                                    |
|       | 0        | DISABLE |        | Ignore CTS                                                                                                                                                                                                                                     |
|       | 1        | ENABLE  |        | Stop transmitting when CTS is negated                                                                                                                                                                                                          |
| 1     | CTSINV   | 0x0     | RW     | <b>CTS Pin Inversion</b><br><br>When set, the CTS pin polarity is inverted.                                                                                                                                                                    |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                                                    |
|       | 0        | DISABLE |        | The USn_CTS pin is low true                                                                                                                                                                                                                    |
|       | 1        | ENABLE  |        | The USn_CTS pin is high true                                                                                                                                                                                                                   |
| 0     | DBGHALT  | 0x0     | RW     | <b>Debug halt</b>                                                                                                                                                                                                                              |

| Bit   | Name    | Reset | Access | Description                                                                                                                                                                                                                                        |
|-------|---------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Value | Mode    |       |        | Description                                                                                                                                                                                                                                        |
| 0     | DISABLE |       |        | Continue to transmit until TX buffer is empty                                                                                                                                                                                                      |
| 1     | ENABLE  |       |        | Negate RTS to stop link partner's transmission during debug HALT. NOTE** The core clock should be equal to or faster than the peripheral clock; otherwise, each single step could transmit multiple frames instead of just transmitting one frame. |

## 20.5.25 USART\_TIMECMP0 - Timer Compare 0

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x060  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TCMPVAL |   |   |   |   |   |   |

| Bit   | Name                                              | Reset   | Access | Description                                                                                                                                                       |
|-------|---------------------------------------------------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 24    | RESTARTEN                                         | 0x0     | RW     | <b>Restart Timer on TCMP0</b>                                                                                                                                     |
|       | Each TCMP0 event will reset and restart the timer |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | DISABLE |        | Disable the timer restarting on TCMP0                                                                                                                             |
|       | 1                                                 | ENABLE  |        | Enable the timer restarting on TCMP0                                                                                                                              |
| 23    | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 22:20 | TSTOP                                             | 0x0     | RW     | <b>Source used to disable comparator 0</b>                                                                                                                        |
|       | Select the source which disables comparator 0     |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | TCMP0   |        | Comparator 0 is disabled when the counter equals TCMPVAL and triggers a TCMP0 event                                                                               |
|       | 1                                                 | TXST    |        | Comparator 0 is disabled at TX start TX Engine                                                                                                                    |
|       | 2                                                 | RXACT   |        | Comparator 0 is disabled on RX going Active (default: low)                                                                                                        |
|       | 3                                                 | RXACTN  |        | Comparator 0 is disabled on RX going Inactive                                                                                                                     |
| 19    | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 18:16 | TSTART                                            | 0x0     | RW     | <b>Timer start source</b>                                                                                                                                         |
|       | Source used to start comparator 0 and timer       |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | DISABLE |        | Comparator 0 is disabled                                                                                                                                          |
|       | 1                                                 | TXEOF   |        | Comparator 0 and timer are started at TX end of frame                                                                                                             |
|       | 2                                                 | TXC     |        | Comparator 0 and timer are started at TX Complete                                                                                                                 |
|       | 3                                                 | RXACT   |        | Comparator 0 and timer are started at RX going Active (default: low)                                                                                              |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                                    |
|------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 4        | RXEOF |        | Comparator 0 and timer are started at RX end of frame                                                                                                                                                                          |
| 15:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                              |
| 7:0  | TCMPVAL  | 0x0   | RW     | <b>Timer comparator 0.</b><br>When the timer equals TCMPVAL, this signals a TCMP0 event and sets the TCMP0 flag. This event can also be used to enable various USART functionality. A value of 0x00 represents 256 baud times. |

## 20.5.26 USART\_TIMECMP1 - Timer Compare 1

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x064  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TCMPVAL |   |   |   |   |   |   |

| Bit   | Name                                              | Reset   | Access | Description                                                                                                                                                       |
|-------|---------------------------------------------------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 24    | RESTARTEN                                         | 0x0     | RW     | <b>Restart Timer on TCMP1</b>                                                                                                                                     |
|       | Each TCMP1 event will reset and restart the timer |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | DISABLE |        | Disable the timer restarting on TCMP1                                                                                                                             |
|       | 1                                                 | ENABLE  |        | Enable the timer restarting on TCMP1                                                                                                                              |
| 23    | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 22:20 | TSTOP                                             | 0x0     | RW     | <b>Source used to disable comparator 1</b>                                                                                                                        |
|       | Select the source which disables comparator 1     |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | TCMP1   |        | Comparator 1 is disabled when the counter equals TCMPVAL and triggers a TCMP1 event                                                                               |
|       | 1                                                 | TXST    |        | Comparator 1 is disabled at TX start TX Engine                                                                                                                    |
|       | 2                                                 | RXACT   |        | Comparator 1 is disabled on RX going Active (default: low)                                                                                                        |
|       | 3                                                 | RXACTN  |        | Comparator 1 is disabled on RX going Inactive                                                                                                                     |
| 19    | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 18:16 | TSTART                                            | 0x0     | RW     | <b>Timer start source</b>                                                                                                                                         |
|       | Source used to start comparator 1 and timer       |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | DISABLE |        | Comparator 1 is disabled                                                                                                                                          |
|       | 1                                                 | TXEOF   |        | Comparator 1 and timer are started at TX end of frame                                                                                                             |
|       | 2                                                 | TXC     |        | Comparator 1 and timer are started at TX Complete                                                                                                                 |
|       | 3                                                 | RXACT   |        | Comparator 1 and timer are started at RX going Active (default: low)                                                                                              |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                                    |
|------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 4        | RXEOF |        | Comparator 1 and timer are started at RX end of frame                                                                                                                                                                          |
| 15:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                              |
| 7:0  | TCMPVAL  | 0x0   | RW     | <b>Timer comparator 1.</b><br>When the timer equals TCMPVAL, this signals a TCMP1 event and sets the TCMP1 flag. This event can also be used to enable various USART functionality. A value of 0x00 represents 256 baud times. |

## 20.5.27 USART\_TIMECMP2 - Timer Compare 2

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x068  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0     |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW      |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TCMPVAL |   |   |   |   |   |   |

| Bit   | Name                                              | Reset   | Access | Description                                                                                                                                                       |
|-------|---------------------------------------------------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 24    | RESTARTEN                                         | 0x0     | RW     | <b>Restart Timer on TCMP2</b>                                                                                                                                     |
|       | Each TCMP2 event will reset and restart the timer |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | DISABLE |        | Disable the timer restarting on TCMP2                                                                                                                             |
|       | 1                                                 | ENABLE  |        | Enable the timer restarting on TCMP2                                                                                                                              |
| 23    | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 22:20 | TSTOP                                             | 0x0     | RW     | <b>Source used to disable comparator 2</b>                                                                                                                        |
|       | Select the source which disables comparator 2     |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | TCMP2   |        | Comparator 2 is disabled when the counter equals TCMPVAL and triggers a TCMP2 event                                                                               |
|       | 1                                                 | TXST    |        | Comparator 2 is disabled at TX start TX Engine                                                                                                                    |
|       | 2                                                 | RXACT   |        | Comparator 2 is disabled on RX going Active (default: low)                                                                                                        |
|       | 3                                                 | RXACTN  |        | Comparator 2 is disabled on RX going Inactive                                                                                                                     |
| 19    | Reserved                                          |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 18:16 | TSTART                                            | 0x0     | RW     | <b>Timer start source</b>                                                                                                                                         |
|       | Source used to start comparator 2 and timer       |         |        |                                                                                                                                                                   |
|       | Value                                             | Mode    |        | Description                                                                                                                                                       |
|       | 0                                                 | DISABLE |        | Comparator 2 is disabled                                                                                                                                          |
|       | 1                                                 | TXEOF   |        | Comparator 2 and timer are started at TX end of frame                                                                                                             |
|       | 2                                                 | TXC     |        | Comparator 2 and timer are started at TX Complete                                                                                                                 |
|       | 3                                                 | RXACT   |        | Comparator 2 and timer are started at RX going Active (default: low)                                                                                              |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                                    |
|------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    |          | RXEOF |        | Comparator 2 and timer are started at RX end of frame                                                                                                                                                                          |
| 15:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                              |
| 7:0  | TCMPVAL  | 0x0   | RW     | <b>Timer comparator 2.</b><br>When the timer equals TCMPVAL, this signals a TCMP2 event and sets the TCMP2 flag. This event can also be used to enable various USART functionality. A value of 0x00 represents 256 baud times. |

## 21. EUSART - Universal Synchronous Asynchronous Receiver/Transmitter



### Quick Facts

#### What?

The EUSART handles high-speed UART, SPI-bus, and IrDA communication.

#### Why?

Serial communication is frequently used in embedded systems and the EUSART allows efficient communication with a wide range of external devices.

#### How?

The EUSART has a wide selection of operating modes, frame formats and baud rates. The multi-processor mode allows the EUSART to remain idle when not addressed. 16-deep FIFOs and DMA support makes high data-rates possible with minimal CPU intervention and it is possible to transmit and receive large frames while the MCU remains in EM1 Sleep.

### 21.1 Introduction

The Enhanced Universal Synchronous Asynchronous serial Receiver and Transmitter (EUSART) is a very flexible serial I/O module. It supports full duplex asynchronous UART communication as well as SPI, MicroWire. It can also interface with IrDA devices.

## 21.2 Features

- Asynchronous (UART) and synchronous (SPI) communication
- Full duplex and half duplex
- Separate TX/RX enable
- Separate receive / transmit 16 deep FIFOs, with additional separate shift registers
- Can operate using HF clock or LF clock (UART only)
- Programmable baud rate, generated as an fractional division from the peripheral clock ( $HFPERCLK_{EUSARTn}$ )
- Max bit-rate
  - Main SPI mode: 20 MHz
  - Secondary SPI mode: 10 MHz
  - UART mode, HF peripheral clock rate/16, 8, 6, or 4
  - UART mode, 32 KHz LF peripheral clock: 9600 (oversampling not supported with LF operation)
- Supports transmission and reception in EM0 (also EM1 and EM2 in certain modes) with
  - Full DMA support
  - UART mode, specified start-frame can start reception automatically
- UART mode, capable of sleep-mode wake-up on received frame (EM2 Capable instance only)
  - Either wake-up on any received byte or
  - Wake up only on specified start and signal frames
- SPI mode, capable of sleep-mode wake-up on received frame (EM2/3 Capable instance only)
  - Either wake-up on CS active or
  - Wake up on Receive FIFO level matching Watermark Level Setting
- Asynchronous mode supports
  - Configurable number of data bits 7-9 (plus the parity bit, if enabled)
  - HW parity bit generation and check
  - Majority vote baud-reception
  - False start-bit detection
  - Break generation/detection
  - Multi-processor mode
  - Configurable number of stop bits in asynchronous mode:
    - HF clock EM0/1 operation: 0.5, 1, 1.5, 2
    - LF clock operation: 1, 2
  - HW collision detection
  - IrDA support
    - HF clock EM0/1 operation: IrDA modulator
    - LF clock operation: Pulse extender, RX-only
  - Hardware Flow Control
  - Automatic Baud Rate Detection
- Synchronous mode supports
  - Configurable number of data bits 8-16
  - All 4 SPI clock polarity/phase configurations
  - Main and Secondary interface modes
- Data can be transmitted LSB first or MSB first
- Separate interrupt vectors for receive and transmit interrupts
- Loopback mode
  - Half duplex communication
  - Communication debugging
- PRS RX input
- DMA Support
- EM2 operation with LF clock (EM2/3 Capable instance only), wakeup to EM1 for DMA interaction
- Async mode Automatic Baud Rate Detection operating with HF clock in EM0/1

### 21.3 Functional Description

An overview of the EUSART module is shown in [Figure 21.1 EUSART Overview on page 637](#).

This section describes all possible EUSART features. Please refer to the Device Datasheet to see what features a specific EUSART instance supports.



**Figure 21.1. EUSART Overview**

### 21.3.1 Modes of Operation

The EUSART operates in either asynchronous or synchronous mode.

In synchronous mode, a separate clock signal is transmitted with the data. This clock signal is generated by the main interface on the bus, and both the main and secondary devices sample and transmit data according to this clock. Both main and secondary interface modes are supported by the EUSART. The synchronous communication mode is compatible with the Serial Peripheral Interface Bus (SPI) standard.

In asynchronous mode, no separate clock signal is transmitted with the data on the bus. The EUSART receiver thus has to determine where to sample the data on the bus from the actual data. To make this possible, additional synchronization bits are added to the data when operating in asynchronous mode, resulting in a slight overhead.

Asynchronous or synchronous mode can be selected by configuring SYNC in EUSARTn\_CFG0. The options are listed with supported protocols in [Table 21.1 EUSART Asynchronous vs. Synchronous Mode on page 638](#). Full duplex and half duplex communication is supported in both asynchronous and synchronous mode.

**Table 21.1. EUSART Asynchronous vs. Synchronous Mode**

| SYNC | Communication Mode | Supported Protocols |
|------|--------------------|---------------------|
| 0    | Asynchronous       | RS-232, IrDA        |
| 1    | Synchronous        | SPI, MicroWire      |

[Table 21.2 EUSART Pin Usage on page 638](#) explains the functionality of the different EUSART pins when the EUSART operates in different modes. Pin functionality enclosed in square brackets is optional, and depends on additional configuration parameters. LOOPBK and MASTER are discussed in [21.3.2.7 Local Loopback](#) and [21.3.3.3 Main SPI Interface Mode \(Clock Driver\)](#) respectively.

**Table 21.2. EUSART Pin Usage**

| SYNC | LOOPBK | MASTER | Pin Functionality |           |           |                         |
|------|--------|--------|-------------------|-----------|-----------|-------------------------|
|      |        |        | TX (MOSI)         | RX (MISO) | CLK       | CS                      |
| 0    | 0      | x      | Data out          | Data in   | -         | -                       |
| 0    | 1      | x      | Data out/in       | -         | -         | -                       |
| 1    | 0      | 0      | Data in           | Data out  | Clock in  | Secondary select        |
| 1    | 0      | 1      | Data out          | Data in   | Clock out | [Auto secondary select] |
| 1    | 1      | 0      | Data out/in       | -         | Clock in  | Secondary select        |
| 1    | 1      | 1      | Data out/in       | -         | Clock out | [Auto secondary select] |

### 21.3.2 Asynchronous Operation

EUSART can operate in asynchronous mode when EUSARTn\_CFG0.SYNC is set to 0.

EUSART0 may operate as either a high-speed peripheral running from a high-frequency clock source (HF mode, available in EM0 or EM1), or as a low-energy peripheral operating from a low-frequency clock source (LF mode, available in EM0, EM1, or EM2). EUSART0 operates in HF mode when the EUSART0CLK clock selected in CMU\_EUSART0CLKCTRL\_CLKSEL is EM01GRPACLK or HFRCOEM23. EUSART0 operates in LF mode when the selected clock is LFXO or LFRCO. Baud rate generation differs between these two modes, and there are certain operational restrictions in LF mode discussed in this chapter. It is not generally useful to switch between modes on-the-fly in a single application.

Other EUSART instances operate only as a high-speed peripheral running from the EM01RPCCLK selected using CMU\_EM01RPCCLKCTRL\_CLKSEL.

### 21.3.2.1 Frame Format

The frame format used in asynchronous mode consists of a set of data bits in addition to bits for synchronization and optionally a parity bit for error checking. A frame starts with one start-bit (S), where the line is driven low for one bit-period. This signals the start of a frame, and is used for synchronization. Following the start bit are 7 to 9 data bits and an optional parity bit. Finally, a number of stop-bits, where the line is driven high that indicates the end of the frame. An example frame is shown in [Figure 21.2 Frame Format on page 639](#).



**Figure 21.2. Frame Format**

The number of data bits in a frame is set by DATABITS in EUSARTn\_FRAMECFG, see [Table 21.3 Data Bits on page 639](#), and the number of stop-bits is set by STOPBITS in EUSARTn\_FRAMECFG, see [Table 21.4 Stop Bits on page 639](#). Whether or not a parity bit should be included, and whether it should be even or odd is defined by PARITY, also in EUSARTn\_FRAMECFG. For proper and reliable communication, all parties of a transfer must agree on the frame format prior to the start of the transfer.

**Table 21.3. Data Bits**

| EUSARTn_FRAMECFG_DATABITS[3:0] | Number of Data bits |
|--------------------------------|---------------------|
| 0001                           | 7                   |
| 0010                           | 8 (Default)         |
| 0011                           | 9                   |

**Table 21.4. Stop Bits**

| EUSARTn_FRAMECFG_STOPBITS[1:0] | Number of Stop bits           |
|--------------------------------|-------------------------------|
| 00                             | 0.5 (HF clock operation only) |
| 01                             | 1 (Default)                   |
| 10                             | 1.5 (HF clock operation only) |
| 11                             | 2                             |

The order in which the data bits are transmitted and received is defined by MSBF in EUSARTn\_CFG0. When MSBF is cleared, data in a frame is sent and received with the least significant bit first. When it is set, the most significant bit comes first.

The frame format used by the transmitter can be inverted by setting TXINV in EUSARTn\_CFG0, and the format expected by the receiver can be inverted by setting RXINV in EUSARTn\_CFG0. These bits affect the entire frame, not only the data bits. An inverted frame has a low idle state, a high start-bit, inverted data and parity bits, and low stop-bits.

### 21.3.2.2 Parity Bit Calculation and Handling

When parity bit is enabled, hardware automatically calculates and inserts a parity bit into outgoing frames, and verifies the received parity bit in incoming frames. The possible parity modes are defined in [Table 21.5 Parity Bits on page 640](#). When even parity is chosen, a parity bit is inserted to make the number of high bits (data + parity) even. If odd parity is chosen, the parity bit makes the total number of high bits odd. When parity bit is disabled, which is the default configuration, the parity bit is omitted.

**Table 21.5. Parity Bits**

| EUSARTn_FRAMECFG_PARITY[1:0] | Description             |
|------------------------------|-------------------------|
| 00                           | No parity bit (Default) |
| 01                           | Reserved                |
| 10                           | Even parity             |
| 11                           | Odd parity              |

### 21.3.2.3 Clock Generation

The EUSART clock defines the transmission and reception data rate. The baud rate is given by [Figure 21.3 EUSART Baud Rate on page 641](#).

$$br = f_{EUSARTn}/(\text{oversample} \times (1 + \text{EUSARTn\_CLKDIV}/256))$$

**Figure 21.3. EUSART Baud Rate**

where  $f_{EUSARTn}$  is the peripheral clock frequency and oversample is the oversampling rate as defined by OVS in EUSARTn\_CFG0, see [Table 21.6 Oversampling \(EUSARTn\\_CFG0\\_OVS\) on page 641](#). Note that different instances of the EUSART inside a device may use different peripheral clocks. The peripheral clock may be generically referred to in this chapter as clk\_per.

**Note:** Please note that high frequency clocks should not be selected as UART clock source when nominal voltage is 0.9V.

**Note:**

Please note that when EUSARTn\_CFG0\_OVS is set to OVS\_DISABLE (0x4), the peripheral clock frequency must be at least three times higher than the chosen baud rate. This condition is given in [Figure 21.4 Requirement for EUSARTn\\_CFG0\\_OVS = OVS\\_DISABLE on page 641](#).

$$f_{EUSARTn} / br \geq 3.0$$

**Figure 21.4. Requirement for EUSARTn\_CFG0\_OVS = OVS\_DISABLE**

**Table 21.6. Oversampling (EUSARTn\_CFG0\_OVS)**

| OVS[2:0] | Oversample                                 |
|----------|--------------------------------------------|
| 000      | 16 (HF clock operation only)               |
| 001      | 8 (HF clock operation only)                |
| 010      | 6 (HF clock operation only)                |
| 011      | 4 (HF clock operation only)                |
| 100      | 1 (OVS disabled - LF clock operation only) |

**Note:** Please note that EUSARTn\_CFG0\_OVS must not be set to OVS\_DISABLE (0x4) when one of the high frequency clocks is selected as EUSARTn peripheral clock source. When one of the low frequency clocks (LFXO/LFRCO) is selected as EUSARTn peripheral clock source, EUSARTn\_CFG0\_OVS must be set to OVS\_DISABLE (0x4).

The EUSART has a fractional clock divider to allow the EUSART clock to be controlled more accurately than what is possible with a standard integral divider. The clock divider used in the EUSART is a 20-bit value, with a 15-bit integral part and an 5-bit fractional part. The fractional part is configured in the lower 5 bits of DIV in EUSARTn\_CLKDIV. Fractional clock division is implemented by distributing the selected fraction over thirty two baud periods. The fractional part of the divider tells how many of these periods should be extended by one peripheral clock cycle.

Given a desired baud rate  $br_{desired}$ , the clock divider EUSARTn\_CLKDIV can be calculated by using [Figure 21.5 EUSART Desired Baud Rate on page 641](#):

$$\text{EUSARTn\_CLKDIV} = 256 \times (f_{EUSARTn}/(\text{oversample} \times br_{desired})) - 1$$

**Figure 21.5. EUSART Desired Baud Rate**

[Table 21.7 EUSART Baud Rates @ 4 MHz Peripheral Clock with 20 Bit CLKDIV on page 642](#) shows a set of desired baud rates and how accurately the EUSART is able to generate these baud rates when running at a 4 MHz peripheral clock, using 16x or 8x oversampling.

**Table 21.7. EUSART Baud Rates @ 4 MHz Peripheral Clock with 20 Bit CLKDIV**

| Desired baud rate [baud/s] | EUSARTn_CFG0_OVS =00                  |                           |         | EUSARTn_CFG0_OVS =01                  |                           |                        |
|----------------------------|---------------------------------------|---------------------------|---------|---------------------------------------|---------------------------|------------------------|
|                            | EUSARTn_CLKDIV/256 (to 32nd position) | Actual baud rate [baud/s] | Error % | EUSARTn_CLKDIV/256 (to 32nd position) | Actual baud rate [baud/s] | Error <sup>1</sup> [%] |
| 600                        | 415,6563                              | 600,015                   | 0,003   | 832,3438                              | 599,9925                  | -0,001                 |
| 1200                       | 207,3438                              | 1199,94                   | -0,005  | 415,6563                              | 1200,03                   | 0,003                  |
| 2400                       | 103,1563                              | 2400,24                   | 0,010   | 207,3438                              | 2399,88                   | -0,005                 |
| 4800                       | 51,09375                              | 4799,04                   | -0,020  | 103,1563                              | 4800,48                   | 0,010                  |
| 9600                       | 25,03125                              | 9603,842                  | 0,040   | 51,09375                              | 9598,08                   | -0,020                 |
| 14400                      | 16,375                                | 14388,49                  | -0,080  | 33,71875                              | 14401,44                  | 0,010                  |
| 19200                      | 12,03125                              | 19184,65                  | -0,080  | 25,03125                              | 19207,68                  | 0,040                  |
| 28800                      | 7,6875                                | 28776,98                  | -0,080  | 16,375                                | 28776,98                  | -0,080                 |
| 38400                      | 5,5                                   | 38461,54                  | 0,160   | 12,03125                              | 38369,3                   | -0,080                 |
| 57600                      | 3,34375                               | 57553,96                  | -0,080  | 7,6875                                | 57553,96                  | -0,080                 |
| 76800                      | 2,25                                  | 76923,08                  | 0,160   | 5,5                                   | 76923,08                  | 0,160                  |
| 115200                     | 1,15625                               | 115942                    | 0,644   | 3,34375                               | 115107,9                  | -0,080                 |
| 230400                     | 0,09375                               | 228571,4                  | -0,794  | 1,15625                               | 231884,1                  | 0,644                  |

1 In addition to error introduced by oscillator frequency variation

**Table 21.8 EUSART0 Baud Rates in LF mode @ 32.768 kHz Peripheral Clock with 20 bit CLKDIV** on page 642 shows a set of desired baud rates and how accurately the EUSART0 is able to generate these baud rates when running from a 32.768 kHz peripheral clock in LF mode.

**Table 21.8. EUSART0 Baud Rates in LF mode @ 32.768 kHz Peripheral Clock with 20 bit CLKDIV**

| Desired baud rate [baud/s] | EUSART0_CLKDIV/256 | Actual baud rate [baud/s] | Error <sup>1</sup> [%] |
|----------------------------|--------------------|---------------------------|------------------------|
| 300                        | 108,21875          | 300,0217                  | 0,01                   |
| 600                        | 53,625             | 599,8719                  | -0,02                  |
| 1200                       | 26,3125            | 1199,744                  | -0,02                  |
| 2400                       | 12,65625           | 2399,487                  | -0,02                  |
| 4800                       | 5,8125             | 4809,982                  | 0,21                   |
| 9600                       | 2,40625            | 9619,963                  | 0,21                   |

1 In addition to error introduced by oscillator frequency variation

#### 21.3.2.4 Auto Baud Detection (HF clock only)

Setting AUTOBAUDEN in EUSARTn\_CFG0 uses the first frame received to automatically set the baud rate provided that it contains 0x55 (IrDA uses 0x00) and is sent out as LSB first and there is no break in the frame. The receiver will measure the number of local clock cycles between the beginning of the START bit and the beginning of the 8th data bit. The DIV field in EUSARTn\_CLKDIV will be overwritten with the new value. The OVS in EUSARTn\_CFG0 and the +1 count of the Baud Rate equation are already factored into the result that gets written into the DIV field. To restart autobaud detection, clear AUTOBAUDEN and set it high again. Since the auto baud rate detection is done over 8 baud times, only the upper 3 bits of the fractional part of the clock divider are populated.

Auto baud detection has associated status bit EUSARTn\_STATUS\_AUTOBAUDDONE and interrupt flag EUSARTn\_IF\_AUTOBAUDDONE. Both the status and the interrupt flag get set after auto baud detection is complete and DIV field in EUSARTn\_CLKDIV is overwritten with the new value.

**Note:**

- If autobaud detection is enabled, software must wait for autobaud detection to complete before transmitting any data.
- Autobaud should be used only during times when it is known that the transmitter will be sending the required data word.
- Autobaud detection is not available when operating with LF clock source.
- For autobaud to work with IrDA, there should be odd parity or no parity in the received data frame.

#### 21.3.2.5 Data Transmission

Asynchronous data transmission is initiated by writing data to the transmit FIFO using one of the methods described in [21.3.2.5.1 Transmit FIFO Operation](#). When the transmission shift register is empty and if the transmitter is enabled, a frame from the transmit FIFO is loaded into the shift register and transmission begins. Note that the frame loading in to the shift register can also be blocked if CTSEN is set in EUSARTn\_CFG0 but the CTS input is inactive. When the frame has been transmitted, a new frame is loaded into the shift register if available, and transmission continues. If the transmit FIFO is empty, the transmitter goes to an idle state, waiting for a new frame to become available.

Transmission is enabled through the command register EUSARTn\_CMD by setting TXEN, and disabled by setting TXDIS in the same command register. When the transmitter is disabled using TXDIS, any ongoing transmission is aborted, and any frame currently being transmitted is discarded. When disabled, the TX output goes to an idle state, which by default is a high value. Whether or not the transmitter is enabled at a given time can be read from TXENS in EUSARTn\_STATUS.

When the EUSART transmitter is enabled and there is no data in the transmit shift register or transmit FIFO, the TXC status flag in EUSARTn\_STATUS and the TXC interrupt flag in EUSARTn\_IF are set, signaling that the transmission is complete. The TXC status flag is cleared when a new frame becomes available for transmission, but the TXC interrupt flag must be cleared by software.

**Note:** (1) Condition for TX to send data out: TX is enabled and there is data available in the TX FIFO and CTS is either not enabled, or if it is enabled, then it is active. (2) If TX output is tri-stated using TXDIS command or TXDISAT setting, then the TX module will still send out data (emptying the FIFO) if condition in point 1 is satisfied, even though the pad is tristated. Restriction: User should not set TXEN when the output is tristated.

### 21.3.2.5.1 Transmit FIFO Operation

The transmit FIFO is a 16 deep FIFO. A frame can be loaded into the FIFO by writing to EUSARTn\_TXDATA. Using EUSARTn\_TXDATA allows 9 bits to be written to the FIFO, as well as a set of control bits regarding the transmission of the written frame. Every frame in the FIFO is stored with 9 data bits and additional transmission control bits. A frame is loaded from the FIFO in to the shift register if the transmitter is enabled.

Figure 21.6 Transmit FIFO Operation on page 644 shows the basics of the transmit FIFO.



**Figure 21.6. Transmit FIFO Operation**

In addition to the interrupt flag TXC in EUSARTn\_IF and status flag TXC in EUSARTn\_STATUS which are set when the transmission is complete, TXFL in EUSARTn\_STATUS and the TXFL interrupt flag in EUSARTn\_IF are used to indicate the level of the transmit FIFO. TXFIW in EUSARTn\_CFG1 controls the level at which these bits are set. The user can choose a transmit FIFO watermark level in TXFIW field of EUSARTn\_CFG1 register in order to program when the TXFL interrupt should be triggered.

There is a TXIDLE status bit in EUSARTn\_STATUS to provide an indication of when the transmitter is idle. The count of TX valid FIFO entries is called TXFCNT in EUSARTn\_STATUS.

The transmit FIFO can be cleared by setting CLEARTX in EUSARTn\_CMD. Since this is an Async FIFO, the user needs to first issue the CLEARTX command and then wait on the CLEARTXBUSY status flag until it goes low. EUSART must be enabled (EUSARTn\_EN should be set) for the flush to work. EUSART should not be transmitting when CLEARTX command gets issued (can be achieved by disabling the transmitter). Any frame present in the transmit shift register currently being transmitted will not be aborted due to the flush. Transmission of this frame will be completed. Note that the transmit shift register is never used to store a transmit frame, i.e., if the transmitter is not enabled then the data stays in the transmit FIFO until the transmitter gets enabled. Whenever a frame is loaded in to the transmit shift register, the transmission starts immediately.

#### Transmit FIFO Status Flags

TX FIFO has two associated status flags: TXFL (set when there is space for data in the TX FIFO, depends on the setting in the TXFIW register) and TXFCNT (count of number of TX frames in the FIFO). These status flags remain set as long as the underlying condition is true, even if the EUSART is disabled (i.e., EUSARTn\_EN is 0). It is possible to write to the TX FIFO while EUSART is disabled, this will impact the two flags mentioned above.

#### Transmit FIFO Interrupt Flags

TX FIFO has two associated interrupt flags: TXFL and TXOF. TXFL is set when space becomes available in the FIFO, depends on TXFIW in CFG1 register. Reset value for TXFIW is such that TXFL gets set as soon the chip comes out of reset (so the interrupt should

be cleared once TXFIW is updated). TXFL remains set as long as the underlying condition is true even if the EUSART is disabled. This means that if a software clear is done for TXFL, then the interrupt will get set again after the clear if the underlying condition is still true (this will happen even if the EUSART is disabled). Writing more data to the FIFO or disabling the TXFL will make the TXFL go away (even if the EUSART is disabled). When writing more frames to the transmit FIFO than there is free space for, the TXOF interrupt flag in EUSARTn\_IF will be set, indicating the overflow. The data already in the transmit FIFO is preserved in this case, and no data is written. Note that TXOF can also trigger if DMA tries to write to the FIFO while a TX Flush operation is going on (Flush is activated by setting CMD.CLEARTX). No data will be written to the FIFO in this case. TXOF triggers only once every time an overflow occurs.

**Note:** (EUSART0 only) In LF clock mode, the TXFL interrupt flag and the TXFL wakeup flag differ slightly in their behavior. IF.TXFL is always set out of reset since there is space available in the FIFO. However, the TXFL wakeup flag is only set after a FIFO read happens and the space that becomes available in the FIFO is the same as programmed in TXFIW in EUSART0\_CFG1.

### 21.3.2.5.2 Frame Transmission Control

The transmission control bits, which can be written using EUSARTn\_TXDATA, affect the transmission of the written frame. The following options are available:

- Generate break: By setting TXBREAK, the output will be held low during the stop-bit period to generate a framing error. A receiver that supports break detection detects this state, allowing it to be used e.g. for framing of larger data packets. The line is driven high before the next frame is transmitted so the next start condition can be identified correctly by the recipient. Continuous breaks lasting longer than a EUSART frame are thus not supported. GPIO can be used for this.
- Disable transmitter after transmission: If TXDISAT is set, the transmitter is disabled after the frame has been fully transmitted.
- Enable receiver after transmission: If RXENAT is set, the receiver is enabled after the frame has been fully transmitted. It is enabled in time to detect a start-bit directly after the last stop-bit has been transmitted.
- Unblock receiver after transmission: If UBRXAT is set, the receiver is unblocked and RXBLOCK is cleared after the frame has been fully transmitted.
- Tristate transmitter after transmission: If TXTRIAT is set, TXTRI is set after the frame has been fully transmitted, tristating the transmitter output. Note that if there are more frames in the TX FIFO after the tristating has happened and the transmitter is enabled, then the transmitter will try to send them out but since the output is tristated, nothing will show up at the transmitter output. The FIFO however will get emptied because of the transmitter attempting to send these frames out. If the target is to automatically tristate the TX line whenever the transmitter is idle, then that can be done by setting AUTOTRI in EUSARTn\_CFG0. If AUTOTRI is set TXTRI status flag is always read as 0.

### 21.3.2.5.3 TX Status Flags

The following status flags should be used with care keeping in mind the external sources that can impact these flags as well as the synchronization delay when the status signal crosses over from the EUSART Core clock domain to the APB clock domain. FIFO related status flags were already discussed in [21.3.2.5.1 Transmit FIFO Operation](#), the remaining flags are mentioned below:

- TXENS: Enable sources: (1) TXEN command from software, (2) PRS trigger (when TXTEN=1). Disable Sources: (1) TXDIS command from software, (2) PERR/FERR (when ERRSTX=1), (3) Software when TXDISAT is set to 1 for a frame.
- TXTRI: Enable sources: (1) TXTRIEN command from software, (2) Software when TXTRIAT is set to 1 for a frame. Disable sources: (1) TXTRIDIS command from software.
- TXIDLE: Set whenever the TX module is idle.
- TXC: Set whenever the TX module goes to idle and both the TX FIFO and the TX shift register are empty. Cleared when either TX FIFO or the TX shift register has data.

### 21.3.2.5.4 Transmission Delay

By configuring TXDELAY in EUSARTn\_CFG1, the transmitter can be forced to wait a number of bit-periods from when it is ready to transmit data, to when it actually transmits the data. This delay is only applied to the first frame transmitted after the transmitter has been idle. When transmitting frames back-to-back the delay is not introduced between the transmitted frames.

This is useful on half duplex buses, because the receiver always returns received frames to software during the first stop-bit. The bus may still be driven for up to 3 bit periods, depending on the current frame format. Using the transmission delay, a transmission can be started when a frame is received, and it is possible to make sure that the transmitter does not begin driving the output before the frame on the bus is completely transmitted.

### 21.3.2.6 Data Reception

Data reception is enabled by setting RXEN in EUSARTn\_CMD. When the receiver is enabled, it actively samples the input looking for a transition from high to low indicating the start baud of a new frame. When a start baud is found, reception of the new frame begins. When the frame has been received, it is pushed into the receive FIFO, making the shift register ready for another frame of data, and the receiver starts looking for another start baud. If a frame is received while the receive FIFO is full, the received frame is discarded and the RXOF interrupt flag in EUSARTn\_IF is set to indicate the FIFO overflow.

The receiver can be disabled by setting the command bit RXDIS in EUSARTn\_CMD. Any frame currently being received, when the receiver is disabled, is discarded. Whether or not the receiver is enabled at a given time can be read out from RXENS in EUSARTn\_STATUS.

### 21.3.2.6.1 Receive FIFO Operation

The receive-FIFO is a 16 deep FIFO. Data can be read from the receive FIFO via EUSARTn\_RXDATA. EUSARTn\_RXDATA gives access to the received frame. This register also contains parity error and framing error information of the received frame. When a frame is read from the receive FIFO using EUSARTn\_RXDATA, the frame is pulled out of the FIFO, making room for a new frame. If an attempt is done to read more frames from the FIFO than what is available, the RXUF interrupt flag in EUSARTn\_IF is set to signal the underflow, and the data read from the FIFO is undefined.

Frames can be read from the receive FIFO without removing the data by using EUSARTn\_RXDATAP. EUSARTn\_RXDATAP gives access to the first frame in the FIFO with status bits. The data read from this register when the receive FIFO is empty is undefined. No underflow interrupt is generated by a read using this register, i.e. RXUF in EUSARTn\_IF is never set as a result of reading from EUSARTn\_RXDATAP.

The basic operation of the receive FIFO is shown in [Figure 21.7 EUSART Receive FIFO Operation on page 647](#).



**Figure 21.7. EUSART Receive FIFO Operation**

#### Receive FIFO Status Flags

Receive FIFO has two associated status flags: RXFL (set when number of available frames in the receive FIFO is at least number of frames set by RXFIW in CFG1 register) and RXFULL (set when receive FIFO is full). These status flags remain set as long as the underlying condition is true, even if the EUSART is disabled (i.e., EUSARTn\_EN is 0). It is possible to read from the receive FIFO while EUSART is disabled, this will impact the two status flags mentioned above. The status flags RXFL and RXFULL are automatically cleared by hardware when their condition is no longer true.

#### Receive FIFO Interrupt Flags

Receive FIFO has four associated interrupt flags: RXFL, RXFULL, RXOF and RXUF. RXFL is set when number of available frames in the receive FIFO is at least number of frames set by RXFIW in CFG1 register. RXFULL is set when receive FIFO is full. Both RXFL and RXFULL remains set as long as the underlying condition is true even if EUSART is disabled. This means that if a software clear is done for RXFL / RXFULL while the undelying condition of respective interrupt is still true, the corresponding interrupt will get set again after the clear (this will happen even if EUSART is disabled). Reading data from the FIFO or disabling the RXFL / RXFULL will block the respective interrupt to get set after a software clear (even if EUSART is disabled). RXOF is set when a new frame is received while the receive FIFO is full, indicating overflow. The new frame is discarded. RXOF triggers only once every time an overflow occurs. RXUF is set when an attempt (via RXDATA or DMA) is done to read more frames from the receive FIFO than what is available, indicating underflow. The data read from the FIFO is undefined. RXUF triggers every time an underflow occurs even if EUSART is disabled.

### 21.3.2.6.2 Blocking Incoming Data

When using hardware frame recognition, as detailed in [21.3.2.6.9 Multi-Processor Mode](#) and [21.3.2.8 Collision Detection](#), it is necessary to be able to let the receiver sample incoming frames without loading them into the receive FIFO. This is accomplished by blocking incoming data.

Incoming data is blocked as long as RXBLOCK in EUSARTn\_STATUS is set. When blocked, frames received by the receiver will not be loaded into the receive FIFO, and software is not notified by the RXFL flag in EUSARTn\_STATUS or the RXFL interrupt flag in EUSARTn\_IF at their arrival. For data to be loaded into the receive FIFO, RXBLOCK must be cleared in the instant a frame is fully received by the receiver. RXBLOCK is set by setting RXBLOCKEN in EUSARTn\_CMD and disabled by setting RXBLOCKDIS also in EUSARTn\_CMD. There is one exception where data is loaded into the receive FIFO even when RXBLOCK is set. This is when an address frame is received while operating in multi-processor mode. See [21.3.2.6.9 Multi-Processor Mode](#) for more information.

Frames received containing framing or parity errors will not result in the FERR and PERR interrupt flags in EUSARTn\_IF being set while RXBLOCK in EUSARTn\_STATUS is set. Hardware recognition is not applied to these erroneous frames, and they are silently discarded.

The overflow interrupt flag RXOF in EUSARTn\_IF will also not be set while RXBLOCK in EUSARTn\_STATUS is set.

### 21.3.2.6.3 Data Sampling and Filtering

The receiver can sample incoming signal at a rate 16, 8, 6 or 4 times higher than the given baud rate, depending on the oversampling mode given by OVS in EUSARTn\_CFG0. Lower oversampling rates make higher baud rates possible, but give less room for errors.

When a high-to-low transition is registered on the input while the receiver is idle, this is recognized as a start-bit, and the baud rate generator is synchronized with the incoming frame.

For oversampling modes 16, 8 and 6, every bit in the incoming frame is sampled three times to gain a level of noise immunity. These samples are aimed at the middle of the bit-periods, as visualized in [Figure 21.8 EUSART Sampling of Start and Data Bits on page 649](#). With OVS=0 in EUSARTn\_CFG0, the start and data bits are thus sampled at locations 8, 9 and 10 in the figure, locations 4, 5 and 6 for OVS=1 and locations 3, 4, and 5 for OVS=2. The value of a sampled bit is determined by majority vote. If two or more of the three bit-samples are high, the resulting bit value is high. If the majority is low, the resulting bit value is low.

Majority vote is used for all oversampling modes except 4X oversampling and when oversampling is disabled. In 4X oversampling mode, a single sample is taken at position 3 as shown in [Figure 21.8 EUSART Sampling of Start and Data Bits on page 649](#).

When oversampling is disabled i.e. OVS = DISABLE, there is only one available location for sampling the start and data bits and so majority vote is not used.

**Note:** When operating in HF clock mode, oversampling must be set to 4, 6, 8, or 16x. When operating in LF clock mode, oversampling must be disabled.

Software can disable majority vote by setting MVDIS in EUSARTn\_CFG0. When majority vote is disabled by software, a single sample is taken at location 9 in the figure for OVS=0, location 5 for OVS=1 and location 4 for OVS=2.

If the value of the start bit is found to be high, the reception of the frame is aborted, filtering out false start bits possibly generated by noise on the input.



**Figure 21.8. EUSART Sampling of Start and Data Bits**

If the baud rate of the transmitter and receiver differ, the location each bit is sampled will be shifted towards the previous or next bit in the frame. This is acceptable for small errors in the baud rate, but for larger errors, it will result in transmission errors.

When the number of stop bits is 1 or more, stop bits are sampled like the start and data bits as seen in [Figure 21.9 EUSART Sampling of Stop Bits when Number of Stop Bits are 1 or More on page 650](#). When a stop bit has been detected, EUSARTn is ready for a new start bit.



**Figure 21.9. EUSART Sampling of Stop Bits when Number of Stop Bits are 1 or More**

When working with stop bit lengths of half a baud period, the above sampling scheme no longer suffices. In this case, the stop-bit is not sampled, and no framing error is generated in the receiver if the stop-bit is not generated. However, the line must still be driven high before the next start bit for the EUSART to successfully identify the start bit.

#### 21.3.2.6.4 RX Status Flags

The following status flags should be used with care keeping in mind the external sources that can impact these flags as well as the synchronization delay when the status signal crosses over from the EUSART Core clock domain to the APB clock domain. FIFO related status flags were already discussed in [21.3.2.6.1 Receive FIFO Operation](#), the remaining flags are mentioned below:

- RXENS: set when RX is enabled. Enable sources: (1) RXEN command from software, (2) PRS trigger (when RXTEN=1), (3) TX (when RXENAT=1). Disable Sources: (1) RXDIS command from software, (2) Parity / framing error (when ERRSRX=1).
- RXBLOCK: set when RX is blocked which means RX keeps receiving frames but does not push received frame to receive FIFO. Enable sources: (1) RXBLOCKEN command from software. Disable Sources: (1) RXBLOCKDIS command from software, (2) STARTFRAME match (when SFUBRX=1), (3) TX (when UBRXAT=1).
- RXIDLE: Set when RX module completes pushing the last received frame to receive FIFO (if receive FIFO has space) and is not receiving any new frame or when RX gets disabled.
- AUTOBAUDDONE: Set when auto baud detection is complete and DIV field in EUSARTn\_CLKDIV is overwritten with the detected value.

#### 21.3.2.6.5 Parity Error

When parity bits are enabled, a parity check is automatically performed on incoming frames. When a parity error is detected in an incoming frame, the data parity error bit PERR in the frame is set, as well as the interrupt flag PERR in EUSARTn\_IF. Frames with parity errors are loaded into the receive FIFO like regular frames.

PERR can be accessed by reading the frame from the receive FIFO using the EUSARTn\_RXDATA, or EUSARTn\_RXDATAP registers.

If ERRSTX in EUSARTn\_CFG0 is set, the transmitter is disabled on received parity errors. If ERRSRX in EUSARTn\_CFG0 is set, the receiver is disabled on parity errors.

### 21.3.2.6.6 Framing Error and Break Detection

A framing error is the result of an asynchronous frame where the stop bit was sampled to a value of 0. This can be the result of noise and baud rate errors, but can also be the result of a break generated by the transmitter on purpose.

When a framing error is detected in an incoming frame, the framing error bit FERR in the frame is set. The interrupt flag FERR in EUSARTn\_IF is also set. Frames with framing errors are loaded into the receive FIFO like regular frames.

If ERRSTX in EUSARTn\_CFG0 is set, the transmitter is disabled on received framing errors. If ERRSRX in EUSARTn\_CFG0 is set, the receiver is disabled on framing errors.

### 21.3.2.6.7 Programmable Start Frame

The EUSART can be configured to start receiving data when a special start frame is detected on the input. This can be useful when operating in low energy modes, allowing other devices to gain the attention of the EUSART by transmitting a given frame.

When SFUBRX in EUSARTn\_CFG1 is set, an incoming frame matching the frame defined in EUSARTn\_STARTFRAME will result in RXBLOCK in EUSARTn\_STATUS being cleared. This can be used to enable reception when a specified start frame is detected. If the receiver is enabled and blocked, i.e. RXENS and RXBLOCK in EUSARTn\_STATUS are set, the receiver will receive all incoming frames, but unless an incoming frame is a start frame it will be discarded and not loaded into the receive FIFO. When a start frame is detected, the block is cleared, and frames received from that point, including the start frame, are loaded into the receive FIFO.

An incoming start frame results in the STARTFIF interrupt flag in EUSARTn\_IF being set, regardless of the value of SFUBRX in EUSARTn\_CFG1. This allows an interrupt to be made when the start frame is detected. The interrupt will be set even if the receiver is blocked i.e. EUSARTn\_STATUS\_RXBLOCK = 1.

**Note:** The receiver must be enabled for start frames to be detected. Please note that, if another UART device sends a start frame but a parity and/or framing error occurs during the reception, the received frame is not detected as a start frame.

### 21.3.2.6.8 Programmable Signal Frame

As well as the configurable start frame, a special signal frame can be specified. When a frame matching the frame defined in EUSARTn\_SIGFRAME is detected by the receiver, the SIGF interrupt flag in EUSARTn\_IF is set. As like start frame detection, the interrupt will be set even if the receiver is blocked i.e. EUSARTn\_STATUS\_RXBLOCK = 1.

One use of the programmable signal frame is to signal the end of a multi-frame message transmitted to the EUSART. An interrupt will then be triggered when the packet has been completely received, allowing software to process it. Used in conjunction with the programmable start frame and DMA, this makes it possible for the EUSART to automatically begin the reception of a packet on a specified start frame, load the entire packet into memory, and give an interrupt when reception of a packet has completed. When one of the low frequency oscillators (LFXO,LFRCO) is used as EUSART0 peripheral clock source, the device can thus wait for data packets in EM2, and only be woken up when a packet has been completely received.

**Note:** The receiver must be enabled for a signal frame to be detected. If a parity and/or framing error occurs during the reception of a signal frame, the received frame is not detected as a signal frame.

### 21.3.2.6.9 Multi-Processor Mode

To simplify communication between multiple processors, the EUSART supports a special multi-processor mode. In this mode the 9th data bit in each frame is used to indicate whether the content of the remaining 8 bits is data or an address.

When multi-processor mode is enabled, an incoming 9-bit frame with the 9th bit equal to the value of MPAB in EUSARTn\_CFG0 is identified as an address frame. When an address frame is detected, the MPAF interrupt flag in EUSARTn\_IF is set, and the address frame is loaded into the receive register. This happens regardless of the value of RXBLOCK in EUSARTn\_STATUS.

Multi-processor mode is enabled by setting MPM in EUSARTn\_CFG0, and the value of the 9th bit in address frames can be configured in EUSARTn\_CFG0\_MPAB. Note that the receiver must be enabled for address frames to be detected. The receiver can be blocked however, preventing data from being loaded into the receive FIFO while looking for address frames.

The following section explains basic usage of the multi-processor mode:

### EUSART Multi-processor Mode Example

1. All devices on the bus enable multi-processor mode and enable and block the receiver. They will now not receive data unless it is an address frame. MPAB in EUSARTn\_CFG0 is set to desired value to identify frames with the 9th bit value equal to MPAB as address frames.
2. A transmitting device sends a frame containing the address of a different device and with the 9th bit set to value of MPAB.
3. All devices receive the address frame and get an interrupt. They can read the address from the receive FIFO. The selected device unblocks the receiver to start receiving data from the transmitter.
4. The transmitter sends data with the 9th bit set to opposite value of MPAB.
5. Only the addressed device with RX enabled and unblocked receives the data. When transmission is complete, the device blocks the receiver and waits for a new address frame.

When a device has received an address frame and wants to receive the following data, it must make sure the receiver is unblocked before the next frame has been completely received in order to prevent data loss. One option is to set SFUBRX in EUSARTn\_CFG1 and set the address frame as start frame in EUSARTn\_STARTFRAME. This will handle automatic unblocking of RX when address frame is received.

#### 21.3.2.6.10 RX Timeout

A RX timeout function can be enabled by setting EUSART\_CFG1\_RXTIMEOUT to desired value. When enabled, a timer gets started after every successful frame reception. If timeout occurs before the next RX start bit is received, EUSART\_IF\_RXTO gets set which can be used to wake-up the system to handle received data. This is shown in [Figure 21.10 RX Timeout on page 652](#). If the next RX start bit is received before timeout occurs, no interrupt gets generated, the timer is reset and will only be started again after the on-going frame reception is complete.



**Figure 21.10. RX Timeout**

Please note that the timer does not get started in following scenarios:

- If auto baud rate detection is enabled and auto baud rate has not been found, the timer does not get started after the first frame which is used to detect the baud rate automatically.
- If a frame is received while RX is blocked, the timer does not get started.
- If EUSART\_CFG0\_SKIPERRF is set to '1' and a frame is received with a parity error, the timer does not get started.

Please also note that the UART RX input line must be in idle state after frame reception for the timer to start.

**Note:** When EUSARTn\_FRAMECFG\_STOPBITS is set to a fractional value i.e. 'HALF' or 'ONEANDHALF', the fractional value is rounded to nearest value and so RX timeout is extended by 0.5 baud width per frame.

### 21.3.2.7 Local Loopback

The EUSARTn receiver samples RX by default, and the transmitter drives TX by default. This is not the only option however. When LOOPBK in EUSARTn\_CFG0 is set, the RX pin is connected to the TX pin as shown in [Figure 21.11 EUSART Local Loopback on page 653](#). This is useful for debugging, as the EUSARTn can receive the data it transmits, but it is also used to allow the EUSARTn to read and write to the same pin, which is required for some half duplex communication modes. In this mode, the TX pin must be enabled as an output in the GPIO.



**Figure 21.11. EUSART Local Loopback**

### 21.3.2.8 Collision Detection

EUSARTn supports a basic form of collision detection. When the receiver is connected to the output of the transmitter, either by using the LOOPBK bit in EUSARTn\_CFG0 or through an external connection, this feature can be used to detect whether data transmitted on the bus by the EUSARTn did get corrupted by a simultaneous transmission by another device on the bus.

For collision detection to be enabled, CCEN in EUSARTn\_CFG0 must be set, and the receiver enabled. The data sampled by the receiver is then continuously compared with the data output by the transmitter. If they differ, the CCF interrupt flag in EUSARTn\_IF is set. The collision check includes all bits of the transmitted frames. The CCF interrupt flag is set once for each bit sampled by the receiver that differs from the bit output by the transmitter. When the transmitter output is disabled, i.e. the transmitter is tristated, collisions are not registered.

**Note:** Please note that collision detection supports only baudrates up to 1mbps.

### 21.3.2.9 Half Duplex Communication

When doing full duplex communication, two data links are provided, making it possible for data to be sent and received at the same time. In half duplex mode, data is only sent in one direction at a time. There are several possible half duplex setups, as described in the following sections.

#### 21.3.2.9.1 Single Data-link

In this setup, the EUSART both receives and transmits data on the same pin. This is enabled by setting LOOPBK in EUSARTn\_CFG0, which connects the receiver to the transmitter output. Because they are both connected to the same line, it is important that the EUSART transmitter does not drive the line when receiving data, as this would corrupt the data on the line.

When communicating over a single data-link, the transmitter must thus be tristated whenever not transmitting data. This is done by setting the command bit TXTRIEN in EUSARTn\_CMD, which tristates the transmitter. Before transmitting data, the command bit TXTRIDIS, also in EUSARTn\_CMD, must be set to enable transmitter output again. Whether or not the output is tristated at a given time can be read from TXTRI in EUSARTn\_STATUS. If TXTRI is set when transmitting data, the data is shifted out of the shift register, but is not put out on TX line.

When operating a half duplex data bus, it is common to have a main bus controller, which first transmits a request to one of the secondary devices on the bus, then receives a reply. In this case, the frame transmission control bits, which can be set by writing to EUSARTn\_TXDATA, can be used to make the EUSART automatically disable transmission, tristate the transmitter and enable reception when the request has been transmitted, making it ready to receive a response from the secondary device.

Tristating the transmitter can also be performed automatically by the EUSART by using AUTOTRI in EUSARTn\_CFG0. When AUTOTRI is set, the EUSART automatically tristates TX line whenever the transmitter is idle, and enables transmitter output when the transmitter goes active. If AUTOTRI is set TXTRI is always read as 0.

**Note:** Another way to tristate the transmitter is to enable wired-and or wired-or mode in GPIO. For wired-and mode, outputting a 1 will be the same as tristating the output, and for wired-or mode, outputting a 0 will be the same as tristating the output. This can only be done on buses with a pull-up or pull-down resistor respectively.

### 21.3.2.9.2 Single Data-link with External Driver

Some communication schemes, such as RS-485 rely on an external driver. Here, the driver has an extra input which enables it, and instead of tristating the transmitter when receiving data, the external driver must be disabled.

This can be done manually by assigning a GPIO to turn the driver on or off.

[Figure 21.12 EUSART Half Duplex Communication with External Driver on page 654](#) shows an example configuration using an external driver.



Figure 21.12. EUSART Half Duplex Communication with External Driver

### 21.3.2.9.3 Two Data-links

Some limited devices only support half duplex communication even though two data links are available. In this case software is responsible for making sure data is not transmitted when incoming data is expected.

### 21.3.2.10 Hardware Flow Control

Hardware flow control can be used to hold off the link partner's transmission until receive FIFO space is available. Use RTSPEN in GPIO\_DBUSEUSARTn\_ROUTEEN to enable RTS pin (CTS is an input so its pin is enabled by default). Port and Pin selection for RTS and CTS can be done in GPIO\_DBUSEUSARTn\_RTSPROUTE/CTSROUTE. RTS is an out going signal which indicates that receive FIFO space is available to receive a frame. The link partner is being requested to send its data when RTS is active. RTS activation can be made dependent on how much space is available in the receive FIFO using RTSRXFW in EUSARTn\_CFG1. For debug use set DBGHALT in EUSARTn\_CFG1 which will force the RTS to request one frame from the link partner when the CPU core single steps. RTS is deactivated when RX is disabled.

CTS is an incoming signal to stop the next TX data from going out. CTS indicates that the link partner has receive FIFO space available, and the local transmitter is clear to send. When CTS deactivates in the middle of a frame, the frame currently being transmitted is completed before stopping. CTS operation needs to be enabled using CFG1.CTSEN.

The RTS and CTS are active low by default, but their polarity can be changed with RTSINV and CTSINV in EUSARTn\_CFG1 respectively.

### 21.3.2.11 Debug Halt

During single stepping, debug halt feature allows halting EUSART frame reception by deactivating RTS when the core is halted and continuing frame reception by activating RTS when the core is unhalted. EUSART debug halt can be enabled by setting DBGHALT in EUSART\_CFG1 to '1'. EUSART receiver must be enabled for debug halting.

When EUSART\_CFG1\_DBGHALT is not set or EUSART\_CFG1\_DBGHALT is set but chip halt is low, RTS is only dependent on the receive FIFO having space available to receive at least number of frames given by EUSART\_CFG1\_RTSRXFW settings.

When EUSART\_CFG1\_DBGHALT is set, RTS will remain deactivated as long as chip halt is high. When a low pulse is detected on chip halt while DBGHALT is set, RTS will be activated if receive FIFO has space available to receive at least number of frames given by EUSART\_CFG1\_RTSRXFW settings and no frame is being received. RTS will be deactivated again if chip halt goes back to high and receiver starts receiving a new frame or if receive FIFO does not have space available to receive at least number of frames given by EUSART\_CFG1\_RTSRXFW settings. This behavior allows single stepping to pulse the chip halt low for a cycle, and receive the next frame.

Please note that, if chip halt remains low for a short duration after RX is enabled while DBGHALT is set, initial low value of chip halt will be treated the same as a low pulse on chip halt.

As incoming frame is always received until receive FIFO is full regardless of the state of DBGHALT or chip halt, the link partner must stop transmitting when RTS is deactivated, or the receive FIFO could overflow.

All data in the transmit FIFO is sent out even when chip halt is asserted; therefore, DMA will need to be set to stop sending EUSART TX data during chip halt.

### 21.3.2.12 PRS-triggered Transmissions

If a transmission must be started on an event with very little delay, the PRS system can be used to trigger the transmission. The PRS channel to use as a trigger can be selected using EUSARTn\_TRIGGER.PRSSEL in PRS. When a positive edge is detected on PRS signal, the receiver is enabled if RXTEN in EUSARTn\_TRIGCTRL is set, and the transmitter is enabled if TXTEN in EUSARTn\_TRIGCTRL is set. Only one signal input is supported by the EUSART.

### 21.3.2.13 PRS RX Input

The EUSART can be configured to receive data directly from a PRS channel by setting RXPRSEN in EUSARTn\_CFG1. The PRS channel used is selected using EUSARTn\_RX.PRSSEL in PRS.

### 21.3.2.14 DMA Support

The EUSART has full DMA support. The DMA controller can write to the transmit FIFO using the register EUSARTn\_TXDATA, and it can read from the receive FIFO using the register EUSARTn\_RXDATA. This enables 9 bit data + control/status bits transfers both to and from the EUSART.

A request for the DMA controller to read from the EUSART receive buffer can come from the following source:

- Receive FIFO is loaded with at least number of frames set by RXFIW.

A write request can come from the following source:

- Transmit FIFO has space for at least number of frames set by TXFIW

In some cases, it may be sensible to temporarily stop DMA read access to the EUSART when an error such as parity or framing error has occurred. This is enabled by setting ERRSDMA in EUSARTn\_CFG0.

EUSART0 (EM2 Capable instance only) can also work with the DMA in low power mode so that the system does not have to wake up to EM0 to consume data. This can happen if TXDMAWU or RXDMAWU in the EUSARTn\_CFG1 is set. The DMA will be triggered when TXFIW/RXFIW samples are in the corresponding FIFO. The chip will enter EM1, DMA will then pop/ push all the elements of the corresponding FIFO and then the system will be put back to EM2.

### 21.3.2.15 Interrupts

The interrupts generated by the EUSART are combined into two interrupt vectors. Interrupts related to reception are assigned to one interrupt vector, and interrupts related to transmission are assigned to the other. Separating the interrupts in this way allows different priorities to be set for transmission and reception interrupts.

The transmission interrupt vector groups the transmission-related interrupts generated by the following interrupt flags:

- TXC
- TXFL
- TXOF
- CCF
- TXIDLE

The reception interrupt on the other hand groups the reception-related interrupts, triggered by the following interrupt flags:

- RXFL
- RXFULL
- RXOF
- RXUF
- PERR
- FERR
- MPAF
- START
- SIGF
- AUTOBAUDDONE
- RXTO

If EUSARTn interrupts are enabled, an interrupt will be made if one or more of the interrupt flags in EUSARTn\_IF and their corresponding bits in EUSARTn\_IEN are set. All interrupts can serve as wake up interupts if enabled (EM2 Capable instance only).

### 21.3.2.16 EM2 operation (EUSART0 Only)

EUSART0 can operate in EM2 when running from an LF oscillator source (LF mode). Note that sending and receiving data in EM2 requires that the EUSART be connected to GPIO that are capable of operating in EM2. This includes all pins on Port A and Port B. Pins on Port C and Port D are not available for digital peripheral signalling in EM2 or EM3.

EM2 operation allows the EUSART to wait for an incoming UART frame, or even wait on the programmable start or signal frames while the system is consuming very little energy. When a UART frame is completely received, or a start/signal frame is detected, the CPU can quickly be woken up. Alternatively, multiple frames can be transferred via the Direct Memory Access (DMA) module into RAM memory before waking up the CPU. Similarly, data can be transmitted in EM2 with data from the CPU or through use of the DMA.

All interrupts can be used as wake up interrupts if enabled. None of the interrupts are sticky, i.e., the interrupt triggers only once whenever the interrupt condition is reached.

**Note:** When RXDMAWU or TXDMAWU is set in EUSART0\_CFG1, the system will not be able to go to EM2 before all related EUSART0 DMA requests have been processed. This means that if RXDMAWU is set and the EUSART receives a frame, the system will wait to go to EM2 before the frame has been read from the EUSART. In order for the system to go back to EM2 during or after the final transmission (i.e. when DMA will no add more data to the TX FIFO), the wake request to DMA must be removed. There are two methods for doing this:

1. If RX does not need to remain active, software can disable the peripheral and clear the TXDMAWU bit in the ISR to prevent further DMA requests. The peripheral may be re-enabled after TXDMAWU is cleared. Note that while the peripheral is disabled, the EUSART cannot receive any new data, so this option should only be used if no data is expected.
2. If RX must remain active, it is recommended to disable TX, and then write dummy information into the FIFO until the TXFL flag will no longer trigger a new wakeup. This will prevent new DMA requests.

### 21.3.2.17 PRS

All PRS inputs are synchronized to the peripheral clock (clk\_per) for the EUSART instance.

- RX PRS: Input goes to RX module for data reception if RXPRSEN set to 1
- TRIGGER PRS: Can be used to Enable TX and/or RX if TXTEN/RXTEN are set to 1

All PRS outputs come from clk\_per flops.

- PRS\_TX: Same as TX output (tx\_out) of EUSART
- PRS\_TXC: Same as the TXC status flag
- PRS\_IRDA\_TX: Registered (clk\_per) version of IRHF output
- PRS\_RXFL: Set if (rxdata\_fifo\_cnt > RXFIW)
- PRS\_RTS: Same as RTS output (rts\_out) of EUSART

### 21.3.2.18 IrDA operation

The EUSART supports IrDA operation using both HF and LF clocks. For IrDA with HF clock, the controls are given in IRHFCFG register. For IrDA with LF clock (32.768 kHz), only RX is supported and the controls are given in IRLFCFG register. Note that OVS must be disabled for LF operation.

**Note:** Note that break generation/ detection feature is not supported while IrDA is enabled, i.e., either IRHFEN or IRLFEN is set.

### 21.3.2.18.1 IRHF

The IRHF modulator implements the physical layer of the IrDA specification, which is necessary for communication over IrDA. The modulator takes the signal output from the EUSART module, and modulates it before it leaves the EUSART. In the same way, the input signal is demodulated before it enters the actual EUSART module. The modulator implements the original Rev. 1.0 physical layer and one high speed extension which supports speeds from 2.4 kbps to 1.152 Mbps.

The data from and to the EUSART is represented in a NRZ (Non Return to Zero) format, where the signal value is at the same level through the entire bit period. For IrDA, the required format is RZI (Return to Zero Inverted), a format where a “1” is signalled by holding the line low, and a “0” is signalled by a short high pulse. An example is given in [Figure 21.13 EUSART Example RZI Signal for a given EUSART Frame on page 657](#).



**Figure 21.13. EUSART Example RZI Signal for a given EUSART Frame**

The IrDA HF module is enabled by setting IRHFEN in IRHFCFG. The EUSART transmitter output and receiver input is then routed through the IrDA HF modulator.

The width of the pulses generated by the IrDA HF modulator is set by configuring IRHFPW in IRHFCFG register. Four pulse widths are available, each defined relative to the configured bit period as listed in [Table 21.9 EUSART IrDA Pulse Widths on page 657](#).

**Table 21.9. EUSART IrDA Pulse Widths**

| IRHFPW | Pulse width OVS=0 | Pulse width OVS=1 | Pulse width OVS=2 | Pulse width OVS=3 |
|--------|-------------------|-------------------|-------------------|-------------------|
| 00     | 1/16              | 1/8               | 1/6               | 1/4               |
| 01     | 2/16              | 2/8               | 2/6               | N/A               |
| 10     | 3/16              | 3/8               | N/A               | N/A               |
| 11     | 4/16              | N/A               | N/A               | N/A               |

By default, no filter is enabled in the IrDA HF demodulator. A filter can be enabled by setting IRHFFILT in IRHFCFG. When the filter is enabled, an incoming pulse has to last for 5 consecutive clock cycles to be detected by the IrDA demodulator. When the filter is enabled, the minimum clock frequency required is based on the baud rate and OVS chosen. The frequency requirements are listed in table [Table 21.10 EUSART IrDA IRHFFILT=1, Min Clock Frequency Requirement \(MHz\) on page 657](#).

**Table 21.10. EUSART IrDA IRHFFILT=1, Min Clock Frequency Requirement (MHz)**

| OVS     | 2.4 kb/s | 9.6 kb/s | 19.2 kb/s | 38.4 kb/s | 57.6 kb/s | 115.2 kb/s | 0.576 Mb/s | 1.152 Mb/s |
|---------|----------|----------|-----------|-----------|-----------|------------|------------|------------|
| 3 (x4)  | 1.0 MHz  | 1.0 MHz  | 1.0 MHz   | 1.0 MHz   | 1.4 MHz   | 2.8 MHz    | 13.8 MHz   | 27.6 MHz   |
| 2 (x6)  | 1.0 MHz  | 1.0 MHz  | 1.0 MHz   | 1.4 MHz   | 2.1 MHz   | 4.1 MHz    | 20.7 MHz   | 41.5 MHz   |
| 1 (x8)  | 1.0 MHz  | 1.0 MHz  | 1.0 MHz   | 1.0 MHz   | 1.4 MHz   | 2.8 MHz    | 13.8 MHz   | 27.6 MHz   |
| 0 (x16) | 1.0 MHz  | 1.0 MHz  | 1.0 MHz   | 1.0 MHz   | 1.1 MHz   | 2.2 MHz    | 11.1 MHz   | 22.1 MHz   |

Note that by default, the idle value of the EUSART data signal is high. This means that the IrDA modulator generates negative pulses, and the IrDA demodulator expects negative pulses. To make the IrDA module use RZI signalling, both TXINV and RXINV in EU-SARTn\_CFG0 must be set.

Since the incoming signal is only sampled on positive clock edges, the width of the incoming pulses must be at least two clk\_per periods wide for reliable detection by the receiver.

### 21.3.2.18.2 IRLF

IRLF only supports RX operation. This feature will stay operational even in EM2. It is possible to cause a wake up when a certain frame is received and then switch to IRHF if TX is required. IRLFEN in IRLFCFG must be set for this to work.

### 21.3.2.19 DALI operation

EUSART supports DALI (Digitally Addressable Lighting Interface) operation using both HF and LF clocks. DALICFG register holds the configuration for DALI operation. Once DALIEN is set to 1 in DALICFG, DALI mode gets enabled. DALI is available only in EUSART asynchronous mode, i.e., SYNC field in CFG0 register must be set to 0.

#### 21.3.2.19.1 DALI Frame Format

DALI frames are Manchester encoded. Details:

- The TX/RX lines are high when idle.
- The Start bit is Manchester encoded to logic 1.
- Data bits are programmable (from 8-32) and are also Manchester encoded.
- Each DALI frame has two Stop bits, which are represented by a high on the line (same as idle status).
- DALI frame does not have parity bits.

DALI TX and RX data bits are independently programmable (each being from 8 to 32) using DALITXDATABITS and DALIRXDATABITS in the DALICFG register. The DALI bus is half-duplex so everything transmitted on the EUSART DALI TX pin will also show up on EUSART DALI RX pin. In order to ensure that whatever is sent out by EUSART TX is not sampled by EUSART RX, RX enable gets automatically masked to low during an active EUSART transmission. Once the transmission completes, the masking is removed (so if RX was enabled, removing the masking will result in RX getting enabled again and if RX was not enabled, RX enable will stay low even after removing the masking). This feature can be overridden for debugging by setting DALIRXENDT to 1 in DALICFG register. In that case, RX enable will not get masked during EUSART TX (i.e., if EUSART RX was already enabled, it will stay enabled during EUSART TX operation) and whatever is sent out will also be received by EUSART itself. In this case, it is important to set DALIRXDATABITS the same as DALITXDATABITS.

If LOOPBK in CFG0 is set to 1 in order to do loopback testing for DALI, then in this case DALIRXENDT should be set to 1 and DALIRXDATABITS should be set the same as DALITXDATABITS. Advantage of DALI loopback testing is that it can be done without connecting to an actual DALI bus since the data is looped back in from the TX pad.

#### 21.3.2.19.2 DALI Baud Rate Formula

The EUSART clock defines DALI transmission and reception data rate. DALI mode supports any data rate from 300 baud up to 115.2 kbaud. DALI has a baudrate formula that differs from the standard EUSART UART mode baud rate formula. Whenever DALIEN in DALICFG is set to 1, then the DALI mode is enabled and the baud rate is given by [Figure 21.14 DALI Baud Rate on page 658](#):

$$br = f_{EUSARTn}/(\text{oversample} \times 2 \times (1 + EUSARTn\_CLKDIV/256))$$

**Figure 21.14. DALI Baud Rate**

where  $f_{EUSARTn}$  is the peripheral clock frequency and oversample is the oversampling rate as defined by OVS in EUSARTn\_CFG0.

Given a desired baud rate  $br_{desired}$ , the clock divider  $EUSARTn\_CLKDIV$  can be calculated by using [Figure 21.15 DALI Desired Baud Rate DIV on page 658](#):

$$EUSARTn\_CLKDIV = 256 \times (f_{EUSARTn}/(\text{oversample} \times 2 \times br_{desired}) - 1)$$

**Figure 21.15. DALI Desired Baud Rate DIV**

The EUSART DALI mode can tolerate a 10% variation in baud rate as required in the DALI standard.

### 21.3.2.19.3 DALI Features

DALI mode is enabled by setting DALIEN to 1 in DALICFG register. A limited set of UART mode features are supported in DALI mode. Details below capture the feature set in DALI mode:

- A framing error interrupt (FERRIF) is generated if 2 stop bits are not received at the end of the frame. The received frame is still loaded into the RXDATA register.
- RXDATA and RXDATAP registers serve as RX FIFO. All 16 bits in these registers are treated as data in DALI mode. When DALI is disabled (DALIEN=0) while CFG0.SYNC=0, then these registers contain both data (max 9 bits) and also control information (PERR, FERR).
- When DALIEN is set to 1, then all 16 bits in TXDATA are treated as data. When DALIEN is 0 (DALI mode disabled) and CFG0.SYNC=0, then TXDATA contains both data bits and control bits.
- TXDATA and RXDATA registers are 16 bits wide but the DALI TX and RX data bits can be programmed to be anywhere between 8 and 32. In order to support data bits greater than 16 bits, special programming model applies. Please see the programming model section for details.
- DALI mode is not supported in EM2. TXDMAWU and RXDMAWU in CFG1 register are not supported in DALI mode.
- SKIPERR feature in CFG0 register is not supported in DALI mode.
- ERRSDMA, ERRSRX and ERRSTX features in CFG0 register are not supported in DALI mode.
- Multiprocessor mode is not supported in DALI mode.
- TX-tristating is not supported in DALI mode. The TX pin is driven high when idle.
- Collision detection is not supported in DALI mode.
- Autobaud detection is not supported in DALI mode.
- Hardware flow control and DBGHALT are not supported in DALI mode.
- RXTIMEOUT and TXDELAY features are not supported in DALI mode.
- Start frame feature is not supported in DALI mode.
- All settings in FRAMECFG are not used in DALI mode. DALICFG register settings are used instead.
- RX blocking feature is not supported in DALI mode.
- IrDA feature (IRLFCFG, IRHFCFG) cannot be enabled while DALI mode is enabled.

### 21.3.3 Synchronous Operation

Synchronous mode shares some common features with asynchronous mode such as: Loopback, inversion of RX/TX, MSBF, TX/RX Interrupt watermarks. They both share the EUSARTn\_TRIGCTRL, CMD, TXDATA, RXDATA, STATUS and Interrupt registers.

In synchronous mode, EUSART can be configured to work either as a main (clock driver) or secondary (clock receiver) interface through EUSARTn\_CFG2.MASTER.

#### 21.3.3.1 Frame Format

The frames used in synchronous mode need no start and stop bits since a single clock is available to all parts participating in the communication. Parity bits cannot be used in synchronous mode.

The EUSART supports frame lengths of 8 to 16 bits per frame. Larger frames can be simulated by transmitting multiple smaller frames, i.e. a 22 bit frame can be sent using two 11-bit frames, and a 24 bit frame can be generated by transmitting three 8-bit frames. The number of bits in a frame is set using DATABITS in EUSARTn\_FRAMECFG.

The frames in synchronous mode are by default transmitted with the least significant bit first like in asynchronous mode. The bit-order can be reversed by setting MSBF in EUSARTn\_CFG0.

The frame format used by the transmitter can be inverted by setting TXINV in EUSARTn\_CFG0, and the format expected by the receiver can be inverted by setting RXINV, also in EUSARTn\_CFG0.

### 21.3.3.2 Clock Generation

The bit-rate in synchronous mode is given by [Figure 21.16 EUSART Synchronous Mode Bit Rate on page 660](#). The clock division is derived from EUSARTn\_CFG2.SDIV, which is applicable when acting as a Main interface only.

$$br = f_{HFPERCLK} / (1 + \text{EUSARTn\_CFG2.SDIV})$$

**Figure 21.16. EUSART Synchronous Mode Bit Rate**

Given a desired baud rate  $br_{desired}$ , the clock divider EUSARTn\_CFG2.SDIV can be calculated using [Figure 21.17 EUSART Synchronous Mode Clock Division Factor on page 660](#)

$$\text{EUSARTn\_CFG2.SDIV} = (f_{HFPERCLK}/br_{desired} - 1)$$

**Figure 21.17. EUSART Synchronous Mode Clock Division Factor**

On every clock edge data on the data lines, MOSI and MISO, is either set up or sampled. When CLKPHA in EUSARTn\_CTRL is cleared, data is sampled on the leading clock edge and set-up is done on the trailing edge. If CLKPHA is set however, data is set-up on the leading clock edge, and sampled on the trailing edge. In addition to this, the polarity of the clock signal can be changed by setting CLKPOL in EUSARTn\_CTRL, which also defines the idle state of the clock. This results in four different modes which are summarized in [Table 21.11 EUSART SPI Modes on page 660](#). [Figure 21.18 EUSART SPI Timing on page 660](#) shows the resulting timing of data set-up and sampling relative to the bus clock.

**Table 21.11. EUSART SPI Modes**

| SPI mode | CLKPOL | CLKPHA | Leading edge    | Trailing edge   |
|----------|--------|--------|-----------------|-----------------|
| 0        | 0      | 0      | Rising, sample  | Falling, set-up |
| 1        | 0      | 1      | Rising, set-up  | Falling, sample |
| 2        | 1      | 0      | Falling, sample | Rising, set-up  |
| 3        | 1      | 1      | Falling, set-up | Rising, sample  |



**Figure 21.18. EUSART SPI Timing**

The RX overflow interrupt flag, RXOF, is set at the end of the overflow frame if the receive FIFO is full. When a transfer has been performed, interrupt flags TXC are updated on the first setup clock edge of the succeeding frame, or when CS is deasserted.

### 21.3.3.3 Main SPI Interface Mode (Clock Driver)

EUSART operating as a main SPI interface is available only in EM0/EM1 with an HF clock source selected. When configured as a main interface, the EUSART is in full control of the data flow on the synchronous bus. When operating in full duplex mode, the secondary devices cannot transmit data to the main device without the main device transmitting to the secondary. The main device outputs the bus clock on SCLK.

Communication starts whenever there is data in the transmit FIFO and the transmitter is enabled. The EUSART clock then starts, and the main device shifts bits out from the transmit shift register using the internal clock.

When there are no more frames in the transmit FIFO and the transmit shift register is empty, the clock stops, and communication ends. When the receiver is enabled, it samples incoming data when the transmitter transmits data. Operation of the RX and TX FIFOs is as in asynchronous mode.

EUSARTn\_CFG2.RXBLOCK can be used to block incoming RX data from pushing into RX FIFO.

### 21.3.3.4 Operation of CS Pin

When operating as a main interface, the CS pin can have one of two functions, or it can be disabled by clearing CSPEN in GPIO\_EU-SARn\_ROUTEEN register.

If CS is disabled and there is a need to disable TX during the operation, then TX should be disabled at the end of transaction only indicated by the trigger of TXC interrupt to maintain synchronicity between TX and RX and avoid causing sudden stop to secondary devices.

If CS is configured as an output, it can be used to automatically generate a chip select for a single secondary device by setting AUTOCS in EUSARTn\_CTRL. If AUTOCS is set, CS is activated before a transmission begins, and deactivated after the last bit has been transmitted and there is no more data in the transmit FIFO.

The time duration between assertion of CS and the start of transmission can be controlled using CSSETUP in EUSARTn\_TIMINGCFG. If new data is ready for transmission before CS is deasserted, the data is sent without deasserting CS in between. CSHOLD in EU-SARTn\_TIMINGCFG keeps CS asserted after the end of frame for the number of baud-times specified.

By default, CS is active low, but its polarity can be inverted by setting CSINV in EUSARTn\_CFG2.

### 21.3.3.5 AUTOTX

The main device on a synchronous bus is required to transmit data (send a clock) to a secondary device in order to receive data from that device. In some cases, only a few words are transmitted and a lot of data is then received from the secondary device. In that case, one solution is to keep feeding the TX with data to transmit, but that consumes system bandwidth. Instead AUTOTX can be used.

When AUTOTX in EUSARTn\_CFG2 is set and TX FIFO is filled with initial data, EUSART will fully transmit the loaded data and then continue transmitting the last sent bit as long as there is available space in the RX FIFO for the chosen frame size. This happens even though there is no more data in the TX FIFO. The TX underflow interrupt flag TXUF in EUSARTn\_IF is set on the first word that is transmitted which does not contain valid data.

During AUTOTX the EUSART will always send the previous sent bit, thus reducing the number of transitions on the TX output. So if the last bit sent was a 0, 0's will be sent during AUTOTX and if the last bit sent was a 1, 1's will be sent during AUTOTX.

### 21.3.3.6 Secondary SPI Interface Mode (Clock Receiver)

When the EUSART is in secondary interface mode, data transmission is not controlled by the EUSART, but by an external main SPI device. The EUSART is therefore not able to initiate a transmission, and has no control over the number of bytes written to the external main device.

The output and input to the EUSART are also swapped when in secondary mode, making the receiver take its input from TX (MOSI) and the transmitter drive RX (MISO).

To transmit data when in secondary mode, the device must load data into the transmit FIFO and enable the transmitter. The data will remain in the EUSART until the main device starts a transmission by pulling the CS input low and transmitting data. For every frame transmitted from main to secondary device, a frame is transferred from secondary to main as well.

If the transmitter is enabled in synchronous secondary mode and the main device starts transmission of a frame, the underflow interrupt flag TXUF in EUSARTn\_IF will be set if no data is available for transmission. At the same time, the secondary device will transmit the default TX data, which can be set through EUSARTn\_DTXDATCFG for the current and subsequent frames until the FIFO is filled. Note that when TX is enabled (with or without data in TXFIFO) in the middle of transaction, TXUF can be triggered if it's transmitting default TX data.

Similar to when operating as a synchronous main interface, EUSARTn\_CFG2.RXBLOCK can be used to block incoming RX data from pushing into RX FIFO.

If the secondary device needs to control its own chip select signal, this can be achieved by clearing CSPEN in the GPIO\_EUSARTn\_ROUTEEN register. The internal chip select signal can then be controlled through CSINV in the CTRL register. The chip select signal will be CSINV inverted, i.e. if CSINV is cleared, the chip select is active and vice versa. In such cases, SCLK could arrive anytime that the device doesn't have prior notification from CS. Hence, EUSARTn\_CFG2.FORCELOAD bit can be used to control how the device transmits the first dataword. If this bit is not set, the next outgoing dataword will be a DEFAULT TX data even if the FIFO had been loaded before SCLK arrives, followed by the loaded TX data. EUSARTn\_IF.LOADERRIF Interrupt will never be triggered when EUSARTn\_CFG2.FORCELOAD is not set. If this bit is set, as soon as the transmitter becomes ready the shift register will be loaded immediately and send data once SCLK arrives. The transmitter becomes ready when TX is enabled and TXFIFO is filled. On top of that, at word-boundary it will automatically trigger setup window check against the programmed EUSARTn\_TIMINGCFG.SETUPWINDOW, which specifies the minimum duration (in APB bus clock cycles) between transmitter becoming ready and the incoming SCLK. If the measured duration is less than SETUPWINDOW bus clock cycles, an EUSARTn\_IF.LOADERRIF Interrupt will be triggered. Besides, if the transmitter is enabled or disabled or the empty TXFIFO is loaded not at word-boundary during a transaction (SCLK is toggling), LOADERRIF will also be triggered immediately without checking for SETUPWINDOW. It's recommended that the transmitter should be ready while SCLK is idling or at word-boundary and at sufficient margin before SCLK toggles. Once LOADERRIF Interrupt is set, it may require to reset the secondary interface by disabling the module and re-enabling it because the transmitted data could be undeterministic.

### 21.3.4 Debug Halt

When DBGHALT in EUSART\_CTRLX is clear, RTS is only dependent on the RX FIFO having space available to receive data. Incoming data is always received until both the RX FIFO is full and the RX shift register is full regardless of the state of DBGHALT or chip halt. Additional incoming data is discarded. When DBGHALT is set, RTS deasserts on RX FIFO full or when chip halt is high. However, a low pulse detected on chip halt will keep RTS asserted when no frame is being received. At the start of frame reception, RTS will deassert if chip halt is high and DBGHALT is set. This behavior allows single stepping to pulse the chip halt low for a cycle, and receive the next frame. The link partner must stop transmitting when RTS is deasserted, or the RX FIFO could overflow. All data in the transmit FIFO is sent out even when chip halt is asserted; therefore, the DMA will need to be set to stop sending the EUSART TX data during chip halt.

### 21.3.5 PRS-triggered Transmissions

If a transmission must be started on an event with very little delay, the PRS system can be used to trigger the transmission. The PRS channel to use as a trigger can be selected using TSEL in EUSARTn\_TRIGCTRL. When a positive edge is detected on this signal, the receiver is enabled if RXTEN in EUSARTn\_TRIGCTRL is set, and the transmitter is enabled if TXTEN in EUSARTn\_TRIGCTRL is set. Only one signal input is supported by the EUSART.

AUTOTXTEN can also be combined with TXTEN to make the EUSART transmit a command to the external device prior to clocking out data. To do this, disable TX using the TXDIS command, load the TX FIFO with the command and enable AUTOTXTEN and TXTEN. When the selected PRS input goes high, the EUSART will now transmit the loaded command, and then continue clocking out while both the PRS input is high and there is room in the RX FIFO

### 21.3.6 PRS RX Input

The EUSART can be configured to receive data directly from a PRS channel by setting RXPRS in EUSARTn\_INPUT. The PRS channel used is selected using RXPRSSEL in EUSARTn\_INPUT. This way, for example, a differential RX signal can be input to the ACMP and the output routed via PRS to the EUSART.

### 21.3.7 PRS CLK Input

The EUSART can be configured to receive clock directly from a PRS channel by setting CLKPRS in EUSARTn\_INPUT. The PRS channel used is selected using CLKPRSSEL in EUSARTn\_INPUT. This is useful in secondary synchronous mode and can together with RX PRS input be used to input data from PRS.

### 21.3.8 DMA Support

The EUSART has full DMA support. The DMA controller can write to the transmit FIFO using the registers EUSARTn\_TXDATA and it can read from the receive FIFO using the registers EUSARTn\_RXDATA. This enables single byte transfers, 9 bit data + control/status bits, double byte and double byte + control/status transfers both to and from the EUSART.

A request for the DMA controller to read from the EUSART receive FIFO can come from the following source:

- Receive FIFO level satisfying EUSARTn\_CFG1.RXFIW setting

A write request can come from one of the following sources:

- Transmit FIFO level satisfying EUSARTn\_CFG1.TXFIW setting.

Even though there are two sources for write requests to the DMA, only one should be used at a time, since the requests from both sources are cleared even though only one of the requests are used.

In some cases, it may be sensible to temporarily stop DMA access to the EUSART when an error such as a framing error has occurred. This is enabled by setting ERRSDMA in EUSARTn\_CTRL.

Note: For Synchronous mode full duplex operation, if both receive FIFO and transmit FIFO are served by DMA, to make sure receive FIFO is not overflowed the settings below should be followed.

- The DMA channel that serves receive FIFO should have higher priority than the DMA channel that serves transmit FIFO.
- IGNORESREQ should be set for both DMA channel.

## 21.4 EUSART Register Map

The offset register address is relative to the registers base address.

| Offset | Name                      | Type        | Description                   |
|--------|---------------------------|-------------|-------------------------------|
| 0x000  | EUSART_IPVERSION          | R           | IP Version ID                 |
| 0x004  | EUSART_EN                 | RW ENABLE   | Enable Register               |
| 0x008  | EUSART_CFG0               | RW CONFIG   | Configuration 0 Register      |
| 0x00C  | EUSART_CFG1               | RW CONFIG   | Configuration 1 Register      |
| 0x010  | EUSART_CFG2               | RW CONFIG   | Configuration 2 Register      |
| 0x014  | EUSART_FRAMECFG           | RW CONFIG   | Frame Format Register         |
| 0x018  | EUSART_DTXDATCFG          | RW CONFIG   | Default TX DATA Register      |
| 0x01C  | EUSART_IRHFCFG            | RW CONFIG   | HF IrDA Mod Config Register   |
| 0x020  | EUSART_IRLFCFG            | RW CONFIG   | LF IrDA Pulse Config Register |
| 0x024  | EUSART_TIMINGCFG          | RW CONFIG   | Timing Register               |
| 0x028  | EUSART_STARTFRAMECFG      | RW CONFIG   | Start Frame Register          |
| 0x02C  | EUSART_SIGFRAMECFG        | RW CONFIG   | Signal Frame Register         |
| 0x030  | EUSART_CLKDIV             | RWH LFSYNC  | Clock Divider Register        |
| 0x034  | EUSART_TRIGCTRL           | RW LFSYNC   | Trigger Control Register      |
| 0x038  | EUSART_CMD                | W LFSYNC    | Command Register              |
| 0x03C  | EUSART_RXDATA             | RH          | RX Data Register              |
| 0x040  | EUSART_RXDATAP            | RH          | RX Data Peek Register         |
| 0x044  | EUSART_TXDATA             | W           | TX Data Register              |
| 0x048  | EUSART_STATUS             | RH          | Status Register               |
| 0x04C  | EUSART_IF                 | RWH INTFLAG | Interrupt Flag Register       |
| 0x050  | EUSART_IEN                | RW          | Interrupt Enable Register     |
| 0x054  | EUSART_SYNCBUSY           | RH          | Synchronization Busy Register |
| 0x058  | EUSART_DALICFG            | RW CONFIG   | DALI Config Register          |
| 0x1000 | EUSART_IPVERSION_SET      | R           | IP Version ID                 |
| 0x1004 | EUSART_EN_SET             | RW ENABLE   | Enable Register               |
| 0x1008 | EUSART_CFG0_SET           | RW CONFIG   | Configuration 0 Register      |
| 0x100C | EUSART_CFG1_SET           | RW CONFIG   | Configuration 1 Register      |
| 0x1010 | EUSART_CFG2_SET           | RW CONFIG   | Configuration 2 Register      |
| 0x1014 | EUSART_FRAMECFG_SET       | RW CONFIG   | Frame Format Register         |
| 0x1018 | EUSART_DTXDATCFG_SET      | RW CONFIG   | Default TX DATA Register      |
| 0x101C | EUSART_IRHFCFG_SET        | RW CONFIG   | HF IrDA Mod Config Register   |
| 0x1020 | EUSART_IRLFCFG_SET        | RW CONFIG   | LF IrDA Pulse Config Register |
| 0x1024 | EUSART_TIMINGCFG_SET      | RW CONFIG   | Timing Register               |
| 0x1028 | EUSART_STARTFRA-MECFG_SET | RW CONFIG   | Start Frame Register          |

| Offset | Name                      | Type        | Description                   |
|--------|---------------------------|-------------|-------------------------------|
| 0x102C | EUSART_SIGFRAMECFG_SET    | RW CONFIG   | Signal Frame Register         |
| 0x1030 | EUSART_CLKDIV_SET         | RWH LFSYNC  | Clock Divider Register        |
| 0x1034 | EUSART_TRIGCTRL_SET       | RW LFSYNC   | Trigger Control Register      |
| 0x1038 | EUSART_CMD_SET            | W LFSYNC    | Command Register              |
| 0x103C | EUSART_RXDATA_SET         | RH          | RX Data Register              |
| 0x1040 | EUSART_RXDATAP_SET        | RH          | RX Data Peek Register         |
| 0x1044 | EUSART_TXDATA_SET         | W           | TX Data Register              |
| 0x1048 | EUSART_STATUS_SET         | RH          | Status Register               |
| 0x104C | EUSART_IF_SET             | RWH INTFLAG | Interrupt Flag Register       |
| 0x1050 | EUSART_IEN_SET            | RW          | Interrupt Enable Register     |
| 0x1054 | EUSART_SYNCBUSY_SET       | RH          | Synchronization Busy Register |
| 0x1058 | EUSART_DALICFG_SET        | RW CONFIG   | DALI Config Register          |
| 0x2000 | EUSART_IPVERSION_CLR      | R           | IP Version ID                 |
| 0x2004 | EUSART_EN_CLR             | RW ENABLE   | Enable Register               |
| 0x2008 | EUSART_CFG0_CLR           | RW CONFIG   | Configuration 0 Register      |
| 0x200C | EUSART_CFG1_CLR           | RW CONFIG   | Configuration 1 Register      |
| 0x2010 | EUSART_CFG2_CLR           | RW CONFIG   | Configuration 2 Register      |
| 0x2014 | EUSART_FRAMECFG_CLR       | RW CONFIG   | Frame Format Register         |
| 0x2018 | EUSART_DTXDATCFG_CLR      | RW CONFIG   | Default TX DATA Register      |
| 0x201C | EUSART_IRHFCFG_CLR        | RW CONFIG   | HF IrDA Mod Config Register   |
| 0x2020 | EUSART_IRLFCFG_CLR        | RW CONFIG   | LF IrDA Pulse Config Register |
| 0x2024 | EUSART_TIMINGCFG_CLR      | RW CONFIG   | Timing Register               |
| 0x2028 | EUSART_STARTFRA-MECFG_CLR | RW CONFIG   | Start Frame Register          |
| 0x202C | EUSART_SIGFRAMECFG_CLR    | RW CONFIG   | Signal Frame Register         |
| 0x2030 | EUSART_CLKDIV_CLR         | RWH LFSYNC  | Clock Divider Register        |
| 0x2034 | EUSART_TRIGCTRL_CLR       | RW LFSYNC   | Trigger Control Register      |
| 0x2038 | EUSART_CMD_CLR            | W LFSYNC    | Command Register              |
| 0x203C | EUSART_RXDATA_CLR         | RH          | RX Data Register              |
| 0x2040 | EUSART_RXDATAP_CLR        | RH          | RX Data Peek Register         |
| 0x2044 | EUSART_TXDATA_CLR         | W           | TX Data Register              |
| 0x2048 | EUSART_STATUS_CLR         | RH          | Status Register               |
| 0x204C | EUSART_IF_CLR             | RWH INTFLAG | Interrupt Flag Register       |
| 0x2050 | EUSART_IEN_CLR            | RW          | Interrupt Enable Register     |
| 0x2054 | EUSART_SYNCBUSY_CLR       | RH          | Synchronization Busy Register |
| 0x2058 | EUSART_DALICFG_CLR        | RW CONFIG   | DALI Config Register          |
| 0x3000 | EUSART_IPVERSION_TGL      | R           | IP Version ID                 |

| Offset | Name                      | Type        | Description                   |
|--------|---------------------------|-------------|-------------------------------|
| 0x3004 | EUSART_EN_TGL             | RW ENABLE   | Enable Register               |
| 0x3008 | EUSART_CFG0_TGL           | RW CONFIG   | Configuration 0 Register      |
| 0x300C | EUSART_CFG1_TGL           | RW CONFIG   | Configuration 1 Register      |
| 0x3010 | EUSART_CFG2_TGL           | RW CONFIG   | Configuration 2 Register      |
| 0x3014 | EUSART_FRAMECFG_TGL       | RW CONFIG   | Frame Format Register         |
| 0x3018 | EUSART_DTXDATCFG_TGL      | RW CONFIG   | Default TX DATA Register      |
| 0x301C | EUSART_IRHFCFG_TGL        | RW CONFIG   | HF IrDA Mod Config Register   |
| 0x3020 | EUSART_IRLFCFG_TGL        | RW CONFIG   | LF IrDA Pulse Config Register |
| 0x3024 | EUSART_TIMINGCFG_TGL      | RW CONFIG   | Timing Register               |
| 0x3028 | EUSART_STARTFRA-MECFG_TGL | RW CONFIG   | Start Frame Register          |
| 0x302C | EUSART_SIGFRAMECFG_TGL    | RW CONFIG   | Signal Frame Register         |
| 0x3030 | EUSART_CLKDIV_TGL         | RWH LFSYNC  | Clock Divider Register        |
| 0x3034 | EUSART_TRIGCTRL_TGL       | RW LFSYNC   | Trigger Control Register      |
| 0x3038 | EUSART_CMD_TGL            | W LFSYNC    | Command Register              |
| 0x303C | EUSART_RXDATA_TGL         | RH          | RX Data Register              |
| 0x3040 | EUSART_RXDATAP_TGL        | RH          | RX Data Peek Register         |
| 0x3044 | EUSART_TXDATA_TGL         | W           | TX Data Register              |
| 0x3048 | EUSART_STATUS_TGL         | RH          | Status Register               |
| 0x304C | EUSART_IF_TGL             | RWH INTFLAG | Interrupt Flag Register       |
| 0x3050 | EUSART_IEN_TGL            | RW          | Interrupt Enable Register     |
| 0x3054 | EUSART_SYNCBUSY_TGL       | RH          | Synchronization Busy Register |
| 0x3058 | EUSART_DALICFG_TGL        | RW CONFIG   | DALI Config Register          |

## 21.5 EUSART Register Description

### 21.5.1 EUSART\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|----------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x2   | R      | <b>IP version ID</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                      |

### 21.5.2 EUSART\_EN - Enable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0 | 1 |   |     |   |           |   |     |   |    |    |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|---|---|-----|---|-----------|---|-----|---|----|----|-----|---|
| 0x004  | 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 | 0x0 | 1 |           |   |     |   |    |    |     |   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |   |   |     |   |           |   |     |   |    |    |     |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |   |   |     |   |           |   |     |   |    |    |     |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |   |   |     |   | DISABLING | R | 0x0 | 1 |    |    |     |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |   |   |     |   |           |   |     |   | EN | RW | 0x0 | 0 |

| Bit  | Name                                          | Reset                                                                                                                                                             | Access | Description                    |
|------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------|
| 31:2 | Reserved                                      | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                |
| 1    | DISABLING                                     | 0x0                                                                                                                                                               | R      | <b>Disablement busy status</b> |
|      | Disabling status when the module is disabled. |                                                                                                                                                                   |        |                                |
| 0    | EN                                            | 0x0                                                                                                                                                               | RW     | <b>Module enable</b>           |
|      | Set to enable the module.                     |                                                                                                                                                                   |        |                                |

## 21.5.3 EUSART\_CFG0 - Configuration 0 Register

| Offset | Bit Position |       |     |     |    |    |        |        |         |          |         |       |       |      |     |      |     |      |        |      |
|--------|--------------|-------|-----|-----|----|----|--------|--------|---------|----------|---------|-------|-------|------|-----|------|-----|------|--------|------|
| 0x008  | 31           | 29    | 28  | 27  | 26 | 25 | 24     | 23     | 22      | 21       | 20      | 19    | 18    | 17   | 16  | 15   |     |      |        |      |
| Reset  | 0x0          | 0x0   | 0x0 | 0x0 |    |    |        |        |         |          |         |       |       |      |     |      |     |      |        |      |
| Access | RW           | RW    |     |     |    |    | RW     | RW     | RW      | RW       | RW      | RW    | RW    | RW   | RW  | RW   | RW  |      |        |      |
| Name   | AUTOBAUDEN   | MVDIS |     |     |    |    | ERRSTX | ERRSRX | ERRSDMA | SKIPERRF | AUTOTRI | TXINV | RXINV | MSBF | OVS | MPAB | MPM | CCEN | LOOPBK | SYNC |

| Bit   | Name       | Reset                                                                                                                                     | Access | Description                                                                                                                                                                       |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | AUTOBAUDEN | 0x0                                                                                                                                       | RW     | <b>AUTOBAUD detection enable</b>                                                                                                                                                  |
|       |            | Detects the baud rate based on receiving a 0x55 frame (0x00 for IrDA). Only applicable when CFG0.SYNC bit is set to 'ASYNC'.              |        |                                                                                                                                                                                   |
| 30    | MVDIS      | 0x0                                                                                                                                       | RW     | <b>Majority Vote Disable</b>                                                                                                                                                      |
|       |            | Disable majority vote for 16x, 8x and 6x oversampling modes. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                        |        |                                                                                                                                                                                   |
| 29:25 | Reserved   |                                                                                                                                           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 24    | ERRSTX     | 0x0                                                                                                                                       | RW     | <b>Disable TX On Error</b>                                                                                                                                                        |
|       |            | When set, the transmitter is disabled on framing and parity errors in the receiver. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |        |                                                                                                                                                                                   |
|       | Value      | Mode                                                                                                                                      |        | Description                                                                                                                                                                       |
|       | 0          | DISABLE                                                                                                                                   |        | Received framing and parity errors have no effect on transmitter                                                                                                                  |
|       | 1          | ENABLE                                                                                                                                    |        | Received framing and parity errors disable the transmitter                                                                                                                        |
| 23    | ERRSRX     | 0x0                                                                                                                                       | RW     | <b>Disable RX On Error</b>                                                                                                                                                        |
|       |            | When set, the receiver is disabled on framing and parity errors. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                    |        |                                                                                                                                                                                   |
|       | Value      | Mode                                                                                                                                      |        | Description                                                                                                                                                                       |
|       | 0          | DISABLE                                                                                                                                   |        | Framing and parity errors have no effect on receiver                                                                                                                              |
|       | 1          | ENABLE                                                                                                                                    |        | Framing and parity errors disable the receiver                                                                                                                                    |
| 22    | ERRSDMA    | 0x0                                                                                                                                       | RW     | <b>Halt DMA Read On Error</b>                                                                                                                                                     |
|       |            | When set, DMA read requests will be cleared on framing and parity errors. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.           |        |                                                                                                                                                                                   |
|       | Value      | Mode                                                                                                                                      |        | Description                                                                                                                                                                       |
|       | 0          | DISABLE                                                                                                                                   |        | Framing and parity errors have no effect on DMA requests from the EUSART                                                                                                          |
|       | 1          | ENABLE                                                                                                                                    |        | DMA requests from the EUSART are blocked while the PERR or FERR interrupt flags are set                                                                                           |
| 21    | Reserved   |                                                                                                                                           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

| Bit   | Name     | Reset   | Access | Description                                                                                                                                                                                                 |
|-------|----------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20    | SKIPPERF | 0x0     | RW     | <b>Skip Parity Error Frames</b>                                                                                                                                                                             |
|       |          |         |        | When set, the receiver discards frames with parity errors. The PERR interrupt flag is still set. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                      |
| 19:18 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                           |
| 17    | AUTOTRI  | 0x0     | RW     | <b>Automatic TX Tristate</b>                                                                                                                                                                                |
|       |          |         |        | When enabled, TXTRI is set by hardware whenever the transmitter is idle, and TXTRI is cleared by hardware when transmission starts. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                   |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                 |
|       | 0        | DISABLE |        | The output on UARTn_TX when the transmitter is idle is defined by TXINV                                                                                                                                     |
|       | 1        | ENABLE  |        | UARTn_TX is tristated whenever the transmitter is idle                                                                                                                                                      |
| 16:15 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                           |
| 14    | TXINV    | 0x0     | RW     | <b>Transmitter output Invert</b>                                                                                                                                                                            |
|       |          |         |        | The output from the EUSART transmitter can optionally be inverted by setting this bit.                                                                                                                      |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                 |
|       | 0        | DISABLE |        | Output from the transmitter is passed unchanged to UARTn_TX                                                                                                                                                 |
|       | 1        | ENABLE  |        | Output from the transmitter is inverted before it is passed to UARTn_TX                                                                                                                                     |
| 13    | RXINV    | 0x0     | RW     | <b>Receiver Input Invert</b>                                                                                                                                                                                |
|       |          |         |        | Setting this bit will invert the input to the EUSART receiver.                                                                                                                                              |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                 |
|       | 0        | DISABLE |        | Input is passed directly to the receiver                                                                                                                                                                    |
|       | 1        | ENABLE  |        | Input is inverted before it is passed to the receiver                                                                                                                                                       |
| 12:11 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                           |
| 10    | MSBF     | 0x0     | RW     | <b>Most Significant Bit First</b>                                                                                                                                                                           |
|       |          |         |        | Decides whether data is sent with the least significant bit first, or the most significant bit first.                                                                                                       |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                 |
|       | 0        | DISABLE |        | Data is sent with the least significant bit first                                                                                                                                                           |
|       | 1        | ENABLE  |        | Data is sent with the most significant bit first                                                                                                                                                            |
| 9:8   | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                           |
| 7:5   | OVS      | 0x0     | RW     | <b>Oversampling</b>                                                                                                                                                                                         |
|       |          |         |        | Sets the number of clock periods in a EUSART bit-period. More clock cycles gives better robustness, while less clock cycles gives better performance. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |
|       | Value    | Mode    |        | Description                                                                                                                                                                                                 |

| Bit   | Name    | Reset                                                                                                                                                       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
|-------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|---------|--------------------------------------------------------------|---|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     |         | X16                                                                                                                                                         |        | 16X oversampling                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 1     |         | X8                                                                                                                                                          |        | 8X oversampling                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 2     |         | X6                                                                                                                                                          |        | 6X oversampling                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 3     |         | X4                                                                                                                                                          |        | 4X oversampling                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 4     |         | DISABLE                                                                                                                                                     |        | Disable oversampling (for LF operation)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 4     | MPAB    | 0x0                                                                                                                                                         | RW     | <b>Multi-Processor Address-Bit</b><br><br>Defines the value of the multi-processor address bit. An incoming frame with its 9th bit equal to the value of this bit marks the frame as a multi-processor address frame. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                                                                                                                                                                                                                                                                                                                   |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 3     | MPM     | 0x0                                                                                                                                                         | RW     | <b>Multi-Processor Mode</b><br><br>Multi-processor mode uses the 9th bit of the EUSART frames to tell whether the frame is an address frame or a data frame. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>The 9th bit of incoming frames has no special function</td></tr> <tr> <td>1</td><td>ENABLE</td><td>An incoming frame with the 9th bit equal to MPAB will be loaded into the RX FIFO regardless of RXBLOCK and will result in the MPAB interrupt flag being set</td></tr> </tbody> </table> | Value | Mode | Description | 0 | DISABLE | The 9th bit of incoming frames has no special function       | 1 | ENABLE | An incoming frame with the 9th bit equal to MPAB will be loaded into the RX FIFO regardless of RXBLOCK and will result in the MPAB interrupt flag being set |
| Value | Mode    | Description                                                                                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 0     | DISABLE | The 9th bit of incoming frames has no special function                                                                                                      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 1     | ENABLE  | An incoming frame with the 9th bit equal to MPAB will be loaded into the RX FIFO regardless of RXBLOCK and will result in the MPAB interrupt flag being set |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 2     | CCEN    | 0x0                                                                                                                                                         | RW     | <b>Collision Check Enable</b><br><br>Enables collision checking on data when operating in half duplex modus. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>Collision check is disabled</td></tr> <tr> <td>1</td><td>ENABLE</td><td>Collision check is enabled. The receiver must be enabled for the check to be performed</td></tr> </tbody> </table>                                                                                                                                                 | Value | Mode | Description | 0 | DISABLE | Collision check is disabled                                  | 1 | ENABLE | Collision check is enabled. The receiver must be enabled for the check to be performed                                                                      |
| Value | Mode    | Description                                                                                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 0     | DISABLE | Collision check is disabled                                                                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 1     | ENABLE  | Collision check is enabled. The receiver must be enabled for the check to be performed                                                                      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 1     | LOOPBK  | 0x0                                                                                                                                                         | RW     | <b>Loopback Enable</b><br><br>Allows the receiver to be connected directly to the EUSART transmitter for loopback and half duplex communication.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>The receiver is connected to and receives data from UARTn_RX</td></tr> <tr> <td>1</td><td>ENABLE</td><td>The receiver is connected to and receives data from UARTn_TX</td></tr> </tbody> </table>                                                                                                                                                            | Value | Mode | Description | 0 | DISABLE | The receiver is connected to and receives data from UARTn_RX | 1 | ENABLE | The receiver is connected to and receives data from UARTn_TX                                                                                                |
| Value | Mode    | Description                                                                                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 0     | DISABLE | The receiver is connected to and receives data from UARTn_RX                                                                                                |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 1     | ENABLE  | The receiver is connected to and receives data from UARTn_TX                                                                                                |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 0     | SYNC    | 0x0                                                                                                                                                         | RW     | <b>Synchronous Mode</b><br><br>Determines whether the EUSART is operating in asynchronous or synchronous mode. When switching between SYNC and ASYNC mode, module Disablement is required.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>ASYNC</td><td>The EUSART operates in asynchronous mode</td></tr> <tr> <td>1</td><td>SYNC</td><td>The EUSART operates in synchronous mode</td></tr> </tbody> </table>                                                                                                                                                               | Value | Mode | Description | 0 | ASYNC   | The EUSART operates in asynchronous mode                     | 1 | SYNC   | The EUSART operates in synchronous mode                                                                                                                     |
| Value | Mode    | Description                                                                                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 0     | ASYNC   | The EUSART operates in asynchronous mode                                                                                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |
| 1     | SYNC    | The EUSART operates in synchronous mode                                                                                                                     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |         |                                                              |   |        |                                                                                                                                                             |

## 21.5.4 EUSART\_CFG1 - Configuration 1 Register

| Offset | Bit Position |       |    |    |         |    |    |    |    |    |    |    |       |    |        |    |    |    |    |         |    |        |    |     |    |    |     |    |         |    |     |   |
|--------|--------------|-------|----|----|---------|----|----|----|----|----|----|----|-------|----|--------|----|----|----|----|---------|----|--------|----|-----|----|----|-----|----|---------|----|-----|---|
| 0x00C  | 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 |
| Reset  |              |       |    |    |         |    |    |    |    |    |    |    |       |    |        |    |    |    |    |         |    |        |    |     |    |    |     |    |         |    |     |   |
| Access |              | RW    |    |    | RW      |    |    |    |    |    |    |    |       | RW | 0x0    |    |    |    |    |         |    |        |    |     |    |    |     | RW | 0x0     |    |     |   |
| Name   |              | RXFIW |    |    | RTSRXFW |    |    |    |    |    |    |    | TXFIW |    | RXPSEN | RW |    |    |    |         |    | SFUBRX | RW | 0x0 | 11 |    |     | RW | 0x0     | 3  |     |   |
|        |              |       |    |    |         |    |    |    |    |    |    |    |       |    |        |    |    |    |    | RXDMAWU | RW | 0x0    | 10 |     |    | RW | 0x0 | 2  |         |    |     |   |
|        |              |       |    |    |         |    |    |    |    |    |    |    |       |    |        |    |    |    |    | TXDMAWU | RW | 0x0    | 9  |     |    | RW | 0x0 | 1  |         |    |     |   |
|        |              |       |    |    |         |    |    |    |    |    |    |    |       |    |        |    |    |    |    |         |    |        |    |     |    |    |     |    | DBGHALT | RW | 0x0 | 0 |

| Bit   | Name     | Reset          | Access | Description                                                                                                                                                       |
|-------|----------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 30:27 | RXFIW    | 0x0            | RW     | <b>RX FIFO Interrupt Watermark</b>                                                                                                                                |
|       |          |                |        | Determines the interrupt and status level of the Receive FIFO. Also impacts RX DMA request.                                                                       |
|       | Value    | Mode           |        | Description                                                                                                                                                       |
|       | 0        | ONEFRAME       |        | RXFL status flag and IF are set when the RX FIFO has at least one frame in it.                                                                                    |
|       | 1        | TWOFRAMES      |        | RXFL status flag and IF are set when the RX FIFO has at least two frames in it.                                                                                   |
|       | 2        | THREEFRAMES    |        | RXFL status flag and IF are set when the RX FIFO has at least three frames in it.                                                                                 |
|       | 3        | FOURFRAMES     |        | RXFL status flag and IF are set when the RX FIFO has at least four frames in it.                                                                                  |
|       | 4        | FIVEFRAMES     |        | RXFL status flag and IF are set when the RX FIFO has at least five frames in it.                                                                                  |
|       | 5        | SIXFRAMES      |        | RXFL status flag and IF are set when the RX FIFO has at least six frames in it.                                                                                   |
|       | 6        | SEVENFRAMES    |        | RXFL status flag and IF are set when the RX FIFO has at least seven frames in it.                                                                                 |
|       | 7        | EIGHTFRAMES    |        | RXFL status flag and IF are set when the RX FIFO has at least eight frames in it.                                                                                 |
|       | 8        | NINEFRAMES     |        | RXFL status flag and IF are set when the RX FIFO has at least nine frames in it.                                                                                  |
|       | 9        | TENFRAMES      |        | RXFL status flag and IF are set when the RX FIFO has at least ten frames in it.                                                                                   |
|       | 10       | ELEVENFRAMES   |        | RXFL status flag and IF are set when the RX FIFO has at least eleven frames in it.                                                                                |
|       | 11       | TWELVEFRAMES   |        | RXFL status flag and IF are set when the RX FIFO has at least twelve frames in it.                                                                                |
|       | 12       | THIRTEENFRAMES |        | RXFL status flag and IF are set when the RX FIFO has at least thirteen frames in it.                                                                              |
|       | 13       | FOURTEENFRAMES |        | RXFL status flag and IF are set when the RX FIFO has at least fourteen frames in it.                                                                              |

| Bit   | Name          | Reset          | Access | Description                                                                                                                                                                       |
|-------|---------------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14    | FIFTEENFRAMES |                |        | RXFL status flag and IF are set when the RX FIFO has at least fifteen frames in it.                                                                                               |
| 15    | SIXTEENFRAMES |                |        | RXFL status flag and IF are set when the RX FIFO has at least sixteen frames in it.                                                                                               |
| 26    | Reserved      |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 25:22 | RTSRXFW       | 0x0            | RW     | <b>Request-to-send RX FIFO Watermark</b><br><br>Set Request-to-send watermark level. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                        |
|       | Value         | Mode           |        | Description                                                                                                                                                                       |
|       | 0             | ONEFRAME       |        | RTS is set if there is space for at least one more frame in the RX FIFO.                                                                                                          |
|       | 1             | TWOFRAMES      |        | RTS is set if there is space for at least two more frames in the RX FIFO.                                                                                                         |
|       | 2             | THREEFRAMES    |        | RTS is set if there is space for at least three more frames in the RX FIFO.                                                                                                       |
|       | 3             | FOURFRAMES     |        | RTS is set if there is space for four more frames in the RX FIFO.                                                                                                                 |
|       | 4             | FIVEFRAMES     |        | RTS is set if there is space for five more frames in the RX FIFO.                                                                                                                 |
|       | 5             | SIXFRAMES      |        | RTS is set if there is space for six more frames in the RX FIFO.                                                                                                                  |
|       | 6             | SEVENFRAMES    |        | RTS is set if there is space for seven more frames in the RX FIFO.                                                                                                                |
|       | 7             | EIGHTFRAMES    |        | RTS is set if there is space for eight more frames in the RX FIFO.                                                                                                                |
|       | 8             | NINEFRAMES     |        | RTS is set if there is space for nine more frames in the RX FIFO.                                                                                                                 |
|       | 9             | TENFRAMES      |        | RTS is set if there is space for ten more frames in the RX FIFO.                                                                                                                  |
|       | 10            | ELEVENFRAMES   |        | RTS is set if there is space for eleven more frames in the RX FIFO.                                                                                                               |
|       | 11            | TWELVEFRAMES   |        | RTS is set if there is space for twelve more frames in the RX FIFO.                                                                                                               |
|       | 12            | THIRTEENFRAMES |        | RTS is set if there is space for thirteen more frames in the RX FIFO.                                                                                                             |
|       | 13            | FOURTEENFRAMES |        | RTS is set if there is space for fourteen more frames in the RX FIFO.                                                                                                             |
|       | 14            | FIFTEENFRAMES  |        | RTS is set if there is space for fifteen more frames in the RX FIFO.                                                                                                              |
|       | 15            | SIXTEENFRAMES  |        | RTS is set if there is space for sixteen more frames in the RX FIFO.                                                                                                              |
| 21:20 | Reserved      |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | TXFIW         | 0x0            | RW     | <b>TX FIFO Interrupt Watermark</b><br><br>Determines the interrupt and status level of the transmit FIFO. Also impacts TX DMA request.                                            |
|       | Value         | Mode           |        | Description                                                                                                                                                                       |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                       |
|-------|----------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ONEFRAME       |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least one more frame.                                                                           |
| 1     | TWOFRAMES      |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least two more frames.                                                                          |
| 2     | THREEFRAMES    |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least three more frames.                                                                        |
| 3     | FOURFRAMES     |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least four more frames.                                                                         |
| 4     | FIVEFRAMES     |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least five more frames.                                                                         |
| 5     | SIXFRAMES      |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least six more frames.                                                                          |
| 6     | SEVENFRAMES    |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least seven more frames.                                                                        |
| 7     | EIGHTFRAMES    |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least eight more frames.                                                                        |
| 8     | NINEFRAMES     |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least nine more frames.                                                                         |
| 9     | TENFRAMES      |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least ten more frames.                                                                          |
| 10    | ELEVENFRAMES   |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least eleven more frames.                                                                       |
| 11    | TWELVEFRAMES   |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least twelve more frames.                                                                       |
| 12    | THIRTEENFRAMES |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least thirteen more frames.                                                                     |
| 13    | FOURTEENFRAMES |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least fourteen more frames.                                                                     |
| 14    | FIFTEENFRAMES  |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least fifteen more frames.                                                                      |
| 15    | SIXTEENFRAMES  |       |        | TXFL status flag and IF are set when the TX FIFO has space for at least sixteen more frames.                                                                      |
| 15    | RXPRSEN        | 0x0   | RW     | <b>PRS RX Enable</b>                                                                                                                                              |
|       |                |       |        | When set, the PRS channel selected as input to RX.                                                                                                                |
| 14:12 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 11    | SFUBRX         | 0x0   | RW     | <b>Start Frame Unblock Receiver</b>                                                                                                                               |
|       |                |       |        | Set to unlock RX on Start frame reception. Only applicable when CFG0 SYNC bit is set to 'ASYNC'.                                                                  |
| 10    | RXDMAWU        | 0x0   | RW     | <b>Receiver DMA Wakeup</b>                                                                                                                                        |
|       |                |       |        | Set to enable wakeup from EM2 to EM1 for DMA/ RX interaction. Only applicable when CFG0 SYNC bit is set to 'ASYNC'.                                               |
| 9     | TXDMAWU        | 0x0   | RW     | <b>Transmitter DMA Wakeup</b>                                                                                                                                     |
|       |                |       |        | Set to enable wakeup from EM2 to EM1 for DMA/ TX interaction. Only applicable when CFG0 SYNC bit is set to 'ASYNC'.                                               |

| Bit   | Name        | Reset                                                   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
|-------|-------------|---------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|----------|---------------------------------------------------------|---|----------|----------------------------------------|---|-----------|--|---|-------------|--|---|------------|--|---|------------|--|---|-----------|--|---|-------------|--|
| 8:7   | Reserved    |                                                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 6:4   | RXTIMEOUT   | 0x0                                                     | RW     | <b>RX Timeout</b><br><br>When enabled, determines how long, in units of frame, RX needs to remain idle after a frame reception before RXTOIF gets set. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLED</td><td></td></tr> <tr> <td>1</td><td>ONEFRAME</td><td></td></tr> <tr> <td>2</td><td>TWOFRAMES</td><td></td></tr> <tr> <td>3</td><td>THREEFRAMES</td><td></td></tr> <tr> <td>4</td><td>FOURFRAMES</td><td></td></tr> <tr> <td>5</td><td>FIVEFRAMES</td><td></td></tr> <tr> <td>6</td><td>SIXFRAMES</td><td></td></tr> <tr> <td>7</td><td>SEVENFRAMES</td><td></td></tr> </tbody> </table> | Value | Mode | Description | 0 | DISABLED |                                                         | 1 | ONEFRAME |                                        | 2 | TWOFRAMES |  | 3 | THREEFRAMES |  | 4 | FOURFRAMES |  | 5 | FIVEFRAMES |  | 6 | SIXFRAMES |  | 7 | SEVENFRAMES |  |
| Value | Mode        | Description                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 0     | DISABLED    |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 1     | ONEFRAME    |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 2     | TWOFRAMES   |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 3     | THREEFRAMES |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 4     | FOURFRAMES  |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 5     | FIVEFRAMES  |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 6     | SIXFRAMES   |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 7     | SEVENFRAMES |                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 3     | RTSINV      | 0x0                                                     | RW     | <b>Request-to-send Invert Enable</b><br><br>When set, the RTS pin polarity is inverted. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>The RTS pin is active low</td></tr> <tr> <td>1</td><td>ENABLE</td><td>The RTS pin is active high</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                      | Value | Mode | Description | 0 | DISABLE  | The RTS pin is active low                               | 1 | ENABLE   | The RTS pin is active high             |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| Value | Mode        | Description                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 0     | DISABLE     | The RTS pin is active low                               |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 1     | ENABLE      | The RTS pin is active high                              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 2     | CTSEN       | 0x0                                                     | RW     | <b>Clear-to-send Enable</b><br><br>When set, frames in the TX FIFO will not be sent until link partner asserts CTS. Any data in the TX shift register will continue transmitting, the next TX FIFO data will not load into the TX shift register. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>Ignore CTS</td></tr> <tr> <td>1</td><td>ENABLE</td><td>Stop transmitting when CTS is inactive</td></tr> </tbody> </table>                                                                                                                                                               | Value | Mode | Description | 0 | DISABLE  | Ignore CTS                                              | 1 | ENABLE   | Stop transmitting when CTS is inactive |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| Value | Mode        | Description                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 0     | DISABLE     | Ignore CTS                                              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 1     | ENABLE      | Stop transmitting when CTS is inactive                  |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 1     | CTSINV      | 0x0                                                     | RW     | <b>Clear-to-send Invert Enable</b><br><br>When set, the CTS pin polarity is inverted. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>The CTS pin is active low</td></tr> <tr> <td>1</td><td>ENABLE</td><td>The CTS pin is active high</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                        | Value | Mode | Description | 0 | DISABLE  | The CTS pin is active low                               | 1 | ENABLE   | The CTS pin is active high             |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| Value | Mode        | Description                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 0     | DISABLE     | The CTS pin is active low                               |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 1     | ENABLE      | The CTS pin is active high                              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 0     | DBGHALT     | 0x0                                                     | RW     | <b>Debug halt</b><br><br>Set to halt operation when core is halted. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>DISABLE</td><td>Continue normal EUSART operation even if core is halted</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                   | Value | Mode | Description | 0 | DISABLE  | Continue normal EUSART operation even if core is halted |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| Value | Mode        | Description                                             |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |
| 0     | DISABLE     | Continue normal EUSART operation even if core is halted |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |          |                                                         |   |          |                                        |   |           |  |   |             |  |   |            |  |   |            |  |   |           |  |   |             |  |

| Bit | Name | Reset  | Access | Description                                                                                                                                                      |
|-----|------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   |      | ENABLE |        | If core is halted, receive one frame and then halt reception by deactivating RTS. Next frame reception happens when the core is unhalted during single stepping. |

### 21.5.5 EUSART\_CFG2 - Configuration 2 Register

| Offset    | Bit Position |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
|-----------|--------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--|--|
| 0x010     | 31           | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| Reset     | 0x0          |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| Access    | RW           |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| Name      | SDIV         |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| ForceLoad | RW           | 0x0 | 7  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| CLKPRSEN  | RW           | 0x0 | 6  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| AUTOCS    | RW           | 0x1 | 5  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| AUTOTX    | RW           | 0x0 | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| CSINV     | RW           | 0x0 | 3  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| CLKPHA    | RW           | 0x0 | 2  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| CLKPOL    | RW           | 0x0 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |
| MASTER    | RW           | 0x0 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | SDIV      | 0x0   | RW     | <b>Sync Clock Div</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |           |       |        | Sets the clock rate for synchronous main mode operation only (To set the clock rate for asynchronous operation, see the CLKDIV field). Clock division value = SDIV + 1. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'MASTER'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23:8  | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7     | FORCELOAD | 0x0   | RW     | <b>Force Load to Shift Register</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |           |       |        | When this bit is set, if TXEN is already enabled, any loading of an empty FIFO will immediately load the data into the shift register. This bit is recommended to be used in 3-wire setting where CS is not used, or in a custom 4-wire mode where SCLK is in long idle state between two transactions with CS always in active mode (this typically happens between 2 transactions where the main interface holds SCLK idling to give additional time for the secondary interface to load data). If FORCELOAD bit is not set, the next out-going frame will be a DEFAULT TX data, followed by the loaded TX data in TX FIFO. When FORCELOAD is set, it will automatically trigger setup window check against the programmed EUSARTn_TIMINGCFG.SETUPWINDOW, which specifies the minimum duration between empty fifo loading event and first encountered edge of SCLK. If the measured duration is less than SETUPWINDOW bus clock cycles, a EUSARTn_IF.LOADER-RIF Interrupt will be triggered. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'SLAVE'. |
| 6     | CLKPRSEN  | 0x0   | RW     | <b>PRS CLK Enable</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |           |       |        | When set, the PRS channel selected as input to CLK. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'SLAVE'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5     | AUTOCS    | 0x1   | RW     | <b>Automatic Chip Select</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|       |           |       |        | When enabled, the output on CS will be activated one baud-period before transmission starts, and deactivated when transmission ends. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'MASTER'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4     | AUTOTX    | 0x0   | RW     | <b>Always Transmit When RXFIFO Not Full</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |           |       |        | Transmits as long as RXFIFO is not full. If TX is empty, underflows are generated. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'MASTER'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3     | CSINV     | 0x0   | RW     | <b>Chip Select Invert</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |           |       |        | Default value is active low. This affects both the selection of external secondary devices, as well as the selection of the microcontroller in secondary mode. Only applicable when CFG0.SYNC bit is set to 'SYNC'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       | Value     | Mode  |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       | 0         | AL    |        | Chip select is active low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | 1         | AH    |        | Chip select is active high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2     | CLKPHA    | 0x0   | RW     | <b>Clock Edge for Setup/Sample</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit | Name                                                                                                                                                                                                                                            | Reset          | Access                                                                                                   | Description           |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------|-----------------------|
|     | Determines where data is set-up and sampled according to the bus clock when in synchronous mode. Only applicable when CFG0.SYNC bit is set to 'SYNC'.                                                                                           |                |                                                                                                          |                       |
|     | Value                                                                                                                                                                                                                                           | Mode           | Description                                                                                              |                       |
|     | 0                                                                                                                                                                                                                                               | SAMPLELEADING  | Data is sampled on the leading edge and set-up on the trailing edge of the bus clock in synchronous mode |                       |
|     | 1                                                                                                                                                                                                                                               | SAMPLETRAILING | Data is set-up on the leading edge and sampled on the trailing edge of the bus clock in synchronous mode |                       |
| 1   | CLKPOL                                                                                                                                                                                                                                          | 0x0            | RW                                                                                                       | <b>Clock Polarity</b> |
|     | Determines the clock polarity of the bus clock used in synchronous mode. Only applicable when CFG0.SYNC bit is set to 'SYNC'.                                                                                                                   |                |                                                                                                          |                       |
|     | Value                                                                                                                                                                                                                                           | Mode           | Description                                                                                              |                       |
|     | 0                                                                                                                                                                                                                                               | IDLELOW        | The bus clock used in synchronous mode has a low base value                                              |                       |
|     | 1                                                                                                                                                                                                                                               | IDLEHIGH       | The bus clock used in synchronous mode has a high base value                                             |                       |
| 0   | MASTER                                                                                                                                                                                                                                          | 0x0            | RW                                                                                                       | <b>Main mode</b>      |
|     | Set this bit to put EUSART to main interface mode. When unset, EUSART operates in secondary interface mode. When changing between Main and Secondary mode, module Disablement is required. Only applicable when CFG0.SYNC bit is set to 'SYNC'. |                |                                                                                                          |                       |
|     | Value                                                                                                                                                                                                                                           | Mode           | Description                                                                                              |                       |
|     | 0                                                                                                                                                                                                                                               | SLAVE          | Secondary mode                                                                                           |                       |
|     | 1                                                                                                                                                                                                                                               | MASTER         | Main mode                                                                                                |                       |

### 21.5.6 EUSART\_FRAMECFG - Frame Format Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |        |    |    |   |   |   |   |   |   |          |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|--------|----|----|---|---|---|---|---|---|----------|---|---|---|
| 0x014  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x1      |    |    | 0x0    |    |    |   |   |   |   |   |   | 0x2      |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW       |    |    | RW     |    |    |   |   |   |   |   |   | RW       |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | STOPBITS |    |    | PARITY |    |    |   |   |   |   |   |   | DATABITS |   |   |   |

| Bit   | Name     | Reset                                                                                                                                                                             | Access                                                                                      | Description                                                                                                                                                                    |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |                                                                                             |                                                                                                                                                                                |
| 13:12 | STOPBITS | 0x1                                                                                                                                                                               | RW                                                                                          | <b>Stop-Bit Mode</b><br><br>Determines the number of stop-bits used. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                     |
|       | Value    | Mode                                                                                                                                                                              | Description                                                                                 |                                                                                                                                                                                |
|       | 0        | HALF                                                                                                                                                                              | The transmitter generates a half stop bit. Stop-bits are not verified by receiver           |                                                                                                                                                                                |
|       | 1        | ONE                                                                                                                                                                               | One stop bit is generated and verified                                                      |                                                                                                                                                                                |
|       | 2        | ONEANDAHALF                                                                                                                                                                       | The transmitter generates one and a half stop bit. The receiver verifies the first stop bit |                                                                                                                                                                                |
|       | 3        | TWO                                                                                                                                                                               | The transmitter generates two stop bits. The receiver checks the first stop-bit only        |                                                                                                                                                                                |
| 11:10 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |                                                                                             |                                                                                                                                                                                |
| 9:8   | PARITY   | 0x0                                                                                                                                                                               | RW                                                                                          | <b>Parity-Bit Mode</b><br><br>Determines whether parity bits are enabled, and whether even or odd parity should be used. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |
|       | Value    | Mode                                                                                                                                                                              | Description                                                                                 |                                                                                                                                                                                |
|       | 0        | NONE                                                                                                                                                                              | Parity bits are not used                                                                    |                                                                                                                                                                                |
|       | 2        | EVEN                                                                                                                                                                              | Even parity are used. Parity bits are automatically generated and checked by hardware.      |                                                                                                                                                                                |
|       | 3        | ODD                                                                                                                                                                               | Odd parity is used. Parity bits are automatically generated and checked by hardware.        |                                                                                                                                                                                |
| 7:4   | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |                                                                                             |                                                                                                                                                                                |
| 3:0   | DATABITS | 0x2                                                                                                                                                                               | RW                                                                                          | <b>Data-Bit Mode</b><br><br>Sets the number of data bits in a EUSART frame.                                                                                                    |
|       | Value    | Mode                                                                                                                                                                              | Description                                                                                 |                                                                                                                                                                                |
|       | 1        | SEVEN                                                                                                                                                                             | Each frame contains 7 data bits                                                             |                                                                                                                                                                                |
|       | 2        | EIGHT                                                                                                                                                                             | Each frame contains 8 data bits                                                             |                                                                                                                                                                                |

| Bit | Name     | Reset | Access | Description                      |
|-----|----------|-------|--------|----------------------------------|
| 3   | NINE     |       |        | Each frame contains 9 data bits  |
| 4   | TEN      |       |        | Each frame contains 10 data bits |
| 5   | ELEVEN   |       |        | Each frame contains 11 data bits |
| 6   | TWELVE   |       |        | Each frame contains 12 data bits |
| 7   | THIRTEEN |       |        | Each frame contains 13 data bits |
| 8   | FOURTEEN |       |        | Each frame contains 14 data bits |
| 9   | FIFTEEN  |       |        | Each frame contains 15 data bits |
| 10  | SIXTEEN  |       |        | Each frame contains 16 data bits |

#### 21.5.7 EUSART\_DTXDATCFG - Default TX DATA Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset  | 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 |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW     | 0x0 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DTXDAT |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                         |
|-------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>   |
| 15:0  | DTXDAT   | 0x0   | RW     | <b>Default TX DATA</b><br><br>This is the default transmitted data when the TXFIFO is empty. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'SLAVE'. |

### 21.5.8 EUSART\_IRHFCFG - HF IrDA Mod Config Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x01C         | 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 |  |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit  | Name                                                                                                                                        | Reset   | Access | Description                                                                                                                                                                       |
|------|---------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved                                                                                                                                    |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3    | IRHFFILT                                                                                                                                    | 0x0     | RW     | <b>IrDA RX Filter</b>                                                                                                                                                             |
|      | Set to enable filter on demodulator.                                                                                                        |         |        |                                                                                                                                                                                   |
|      | Value                                                                                                                                       | Mode    |        | Description                                                                                                                                                                       |
|      | 0                                                                                                                                           | DISABLE |        | No filter enabled                                                                                                                                                                 |
|      | 1                                                                                                                                           | ENABLE  |        | Filter enabled. IrDA pulse must be high for at least 5 consecutive clock cycles to be detected                                                                                    |
| 2:1  | IRHFPW                                                                                                                                      | 0x0     | RW     | <b>IrDA TX Pulse Width</b>                                                                                                                                                        |
|      | Configure the pulse width generated by the modulator as a fraction of the configured EUSART bit period.                                     |         |        |                                                                                                                                                                                   |
|      | Value                                                                                                                                       | Mode    |        | Description                                                                                                                                                                       |
|      | 0                                                                                                                                           | ONE     |        | IrDA pulse width is 1/16 for OVS=0 and 1/8 for OVS=1                                                                                                                              |
|      | 1                                                                                                                                           | TWO     |        | IrDA pulse width is 2/16 for OVS=0 and 2/8 for OVS=1                                                                                                                              |
|      | 2                                                                                                                                           | THREE   |        | IrDA pulse width is 3/16 for OVS=0 and 3/8 for OVS=1                                                                                                                              |
|      | 3                                                                                                                                           | FOUR    |        | IrDA pulse width is 4/16 for OVS=0 and 4/8 for OVS=1                                                                                                                              |
| 0    | IRHFEN                                                                                                                                      | 0x0     | RW     | <b>Enable IrDA Module</b>                                                                                                                                                         |
|      | Enable IrDA module and route EUSART signals through it. Used when EUSART has HF clock. Only applicable when CFG0.SYNC bit is set to 'ASYNC' |         |        |                                                                                                                                                                                   |

### 21.5.9 EUSART\_IRLFCFG - LF IrDA Pulse Config Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |        |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|--------|
| 0x020  | 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   |        |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0 |        |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW  |        |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     | IRLFEN |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                             |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                       |
| 0    | IRLFEN   | 0x0   | RW     | <b>Pulse Generator/Extender Enable</b><br><br>Filter EUSART output through pulse generator and the EUSART input through the pulse extender. Used for LF operation. Only applicable when CFG0.SYNC bit is set to 'ASYNC' |

### 21.5.10 EUSART\_TIMINGCFG - Timing Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |             |    |    |    |     |     |    |    |        |     |   |   |         |     |   |   |         |     |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|----|-----|-----|----|----|--------|-----|---|---|---------|-----|---|---|---------|-----|---|---|
| 0x024  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    | 0x5         |    |    |    |     | 0x0 |    |    |        | 0x0 |   |   |         | 0x0 |   |   |         | 0x0 |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    | RW          |    |    |    | RW  |     |    |    | RW     |     |   |   | RW      |     |   |   | RW      |     |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | SETUPWINDOW |    |    |    | ICS |     |    |    | CSHOLD |     |   |   | CSSETUP |     |   |   | TXDELAY |     |   |   |

| Bit   | Name        | Reset                                         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
|-------|-------------|-----------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|------|--------------------------------------|---|-----|-----------------------------------------------|---|-----|-----------------------------------------------|---|-------|-----------------------------------------------|---|------|-----------------------------------------------|---|------|-----------------------------------------------|---|-----|-----------------------------------------------|---|-------|-----------------------------------------------|
| 31:20 | Reserved    |                                               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 19:16 | SETUPWINDOW | 0x5                                           | RW     | <b>Setup Window</b><br><br>When CFG2.FORCELOAD is set, this defines the number of bus clock cycles that empty FIFO load or enabling of TX or disabling of TX must be performed before the sampling edge of SCLK at word-boundary to avoid load error. Word boundary is defined as followsings: before the transaction starts, or between 2 transactions or the first bit between 2 datawords. If baud-rate is more than 5 MHz, a value of 4 is recommended, any values smaller than that can be tried out but avoid using 0. If baud-rate is less than 5 MHz, value of 5 is recommended, any values higher than 5 can be used but it may make the load error easy to occur. The recommended values for frequency bands should be sufficient to work all the time. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'SLAVE' and CFG2.FORCELOAD is set.                                                                                                                                                      |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 15    | Reserved    |                                               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 14:12 | ICS         | 0x0                                           | RW     | <b>Inter-Character Spacing</b><br><br>Inter-character spacing after each TX frame while the TX FIFO is not empty. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'MASTER'.<br><br><table border="1"><thead><tr><th>Value</th><th>Mode</th><th>Description</th></tr></thead><tbody><tr><td>0</td><td>ZERO</td><td>There is no space between characters</td></tr><tr><td>1</td><td>ONE</td><td>Create a space of 1 baud-times between frames</td></tr><tr><td>2</td><td>TWO</td><td>Create a space of 2 baud-times between frames</td></tr><tr><td>3</td><td>THREE</td><td>Create a space of 3 baud-times between frames</td></tr><tr><td>4</td><td>FOUR</td><td>Create a space of 4 baud-times between frames</td></tr><tr><td>5</td><td>FIVE</td><td>Create a space of 5 baud-times between frames</td></tr><tr><td>6</td><td>SIX</td><td>Create a space of 6 baud-times between frames</td></tr><tr><td>7</td><td>SEVEN</td><td>Create a space of 7 baud-times between frames</td></tr></tbody></table> | Value | Mode | Description | 0 | ZERO | There is no space between characters | 1 | ONE | Create a space of 1 baud-times between frames | 2 | TWO | Create a space of 2 baud-times between frames | 3 | THREE | Create a space of 3 baud-times between frames | 4 | FOUR | Create a space of 4 baud-times between frames | 5 | FIVE | Create a space of 5 baud-times between frames | 6 | SIX | Create a space of 6 baud-times between frames | 7 | SEVEN | Create a space of 7 baud-times between frames |
| Value | Mode        | Description                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 0     | ZERO        | There is no space between characters          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 1     | ONE         | Create a space of 1 baud-times between frames |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 2     | TWO         | Create a space of 2 baud-times between frames |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 3     | THREE       | Create a space of 3 baud-times between frames |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 4     | FOUR        | Create a space of 4 baud-times between frames |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 5     | FIVE        | Create a space of 5 baud-times between frames |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 6     | SIX         | Create a space of 6 baud-times between frames |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 7     | SEVEN       | Create a space of 7 baud-times between frames |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 11    | Reserved    |                                               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| 10:8  | CSHOLD      | 0x0                                           | RW     | <b>Chip Select Hold</b><br><br>Chip Select will be de-asserted after the end of frame transmission. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'MASTER'.<br><br><table border="1"><thead><tr><th>Value</th><th>Mode</th><th>Description</th></tr></thead></table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Value | Mode | Description |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |
| Value | Mode        | Description                                   |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |      |             |   |      |                                      |   |     |                                               |   |     |                                               |   |       |                                               |   |      |                                               |   |      |                                               |   |     |                                               |   |       |                                               |

| Bit   | Name     | Reset                                                                                                                  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
|-------|----------|------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|------|------------------------------------------------------------------------------------------------------------------------|---|-----|--------------------------------------------------------------------|---|-----|---------------------------------------------------------------------|---|-------|---------------------------------------------------------------------|---|------|---------------------------------------------------------------------|---|------|---------------------------------------------------------------------|---|-----|---------------------------------------------------------------------|---|-------|---------------------------------------------------------------------|
| 0     | ZERO     |                                                                                                                        |        | CS is de-asserted half or 1 baud-time after the end of transmission depending on CLKPHASE equal to 1 or 0 respectively                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 1     | ONE      |                                                                                                                        |        | CS is de-asserted 1 additional baud-time after the end of transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 2     | TWO      |                                                                                                                        |        | CS is de-asserted 2 additional baud-times after the end of transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 3     | THREE    |                                                                                                                        |        | CS is de-asserted 3 additional baud-times after the end of transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 4     | FOUR     |                                                                                                                        |        | CS is de-asserted 4 additional baud-times after the end of transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 5     | FIVE     |                                                                                                                        |        | CS is de-asserted 5 additional baud-times after the end of transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 6     | SIX      |                                                                                                                        |        | CS is de-asserted 6 additional baud-times after the end of transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 7     | SEVEN    |                                                                                                                        |        | CS is de-asserted 7 additional baud-times after the end of transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 7     | Reserved |                                                                                                                        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 6:4   | CSSETUP  | 0x0                                                                                                                    | RW     | <b>Chip Select Setup</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
|       |          |                                                                                                                        |        | Chip Select will be asserted before the start of frame transmission. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'MASTER'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
|       |          |                                                                                                                        |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>ZERO</td><td>CS is asserted half or 1 baud-time before the start of transmission depending on CLKPHASE equal to 1 or 0 respectively</td></tr> <tr> <td>1</td><td>ONE</td><td>CS is asserted 1 additional baud-time before start of transmission</td></tr> <tr> <td>2</td><td>TWO</td><td>CS is asserted 2 additional baud-times before start of transmission</td></tr> <tr> <td>3</td><td>THREE</td><td>CS is asserted 3 additional baud-times before start of transmission</td></tr> <tr> <td>4</td><td>FOUR</td><td>CS is asserted 4 additional baud-times before start of transmission</td></tr> <tr> <td>5</td><td>FIVE</td><td>CS is asserted 5 additional baud-times before start of transmission</td></tr> <tr> <td>6</td><td>SIX</td><td>CS is asserted 6 additional baud-times before start of transmission</td></tr> <tr> <td>7</td><td>SEVEN</td><td>CS is asserted 7 additional baud-times before start of transmission</td></tr> </tbody> </table> | Value | Mode | Description | 0 | ZERO | CS is asserted half or 1 baud-time before the start of transmission depending on CLKPHASE equal to 1 or 0 respectively | 1 | ONE | CS is asserted 1 additional baud-time before start of transmission | 2 | TWO | CS is asserted 2 additional baud-times before start of transmission | 3 | THREE | CS is asserted 3 additional baud-times before start of transmission | 4 | FOUR | CS is asserted 4 additional baud-times before start of transmission | 5 | FIVE | CS is asserted 5 additional baud-times before start of transmission | 6 | SIX | CS is asserted 6 additional baud-times before start of transmission | 7 | SEVEN | CS is asserted 7 additional baud-times before start of transmission |
| Value | Mode     | Description                                                                                                            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 0     | ZERO     | CS is asserted half or 1 baud-time before the start of transmission depending on CLKPHASE equal to 1 or 0 respectively |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 1     | ONE      | CS is asserted 1 additional baud-time before start of transmission                                                     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 2     | TWO      | CS is asserted 2 additional baud-times before start of transmission                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 3     | THREE    | CS is asserted 3 additional baud-times before start of transmission                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 4     | FOUR     | CS is asserted 4 additional baud-times before start of transmission                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 5     | FIVE     | CS is asserted 5 additional baud-times before start of transmission                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 6     | SIX      | CS is asserted 6 additional baud-times before start of transmission                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 7     | SEVEN    | CS is asserted 7 additional baud-times before start of transmission                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 3:2   | Reserved |                                                                                                                        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| 1:0   | TXDELAY  | 0x0                                                                                                                    | RW     | <b>TX Delay Transmission</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
|       |          |                                                                                                                        |        | Configurable delay before new transfers. Frames sent back-to-back are not delayed. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
|       |          |                                                                                                                        |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Value | Mode | Description |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |
| Value | Mode     | Description                                                                                                            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |      |                                                                                                                        |   |     |                                                                    |   |     |                                                                     |   |       |                                                                     |   |      |                                                                     |   |      |                                                                     |   |     |                                                                     |   |       |                                                                     |

| Bit | Name | Reset   | Access | Description                                                   |
|-----|------|---------|--------|---------------------------------------------------------------|
| 0   |      | NONE    |        | Frames are transmitted immediately.                           |
| 1   |      | SINGLE  |        | Transmission of new frames is delayed by a single bit period. |
| 2   |      | DOUBLE  |        | Transmission of new frames is delayed by a two bit periods.   |
| 3   |      | TRIPPLE |        | Transmission of new frames is delayed by a three bit periods. |

#### 21.5.11 EUSART\_STARTFRAMECFG - Start Frame Register

| Offset | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x028  | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit  | Name       | Reset | Access | Description                                                                                                                                                                                                                                                                     |
|------|------------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                               |
| 8:0  | STARTFRAME | 0x0   | RW     | <b>Start Frame</b><br><br>When a frame matching STARTFRAME is received, the receiver detects that and STARTF interrupt flag is set. If SFUBRX is set, RXBLOCK is cleared and the start frame is loaded in to the RX FIFO. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |

#### 21.5.12 EUSART\_SIGFRAMECFG - Signal Frame Register

| Offset | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 0x02C  | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                    |
|------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | SIGFRAME | 0x0   | RW     | <b>Signal Frame Value</b><br><br>When a frame matching SIGFRAME is detected by the receiver, SIGF interrupt flag is set. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |

### 21.5.13 EUSART\_CLKDIV - Clock Divider Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x030  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DIV          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                            |
|-------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                      |
| 22:3  | DIV      | 0x0   | RW     | <b>Fractional Clock Divider</b><br><br>Specifies the fractional clock divider. Setting AUTOBAUDEN in CFG1 register will overwrite the DIV field. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |
| 2:0   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                      |

### 21.5.14 EUSART\_TRIGCTRL - Trigger Control Register

| Offset | Bit Position    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x034  | 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 |
| Reset  | 0x0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | AUTOTXTEN RXTEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                                                   |
|------|-----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                             |
| 2    | AUTOTXTEN | 0x0   | RW     | <b>AUTOTX Trigger Enable</b><br><br>When set, AUTOTX is enabled as long as the selected PRS channel has a high value. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'MASTER'. |
| 1    | TXTEN     | 0x0   | RW     | <b>Transmit Trigger Enable</b><br><br>When set, the positive edge of the selected PRS channel sets TXEN, enabling the transmitter.                                                                            |
| 0    | RXTEN     | 0x0   | RW     | <b>Receive Trigger Enable</b><br><br>When set, the positive edge of the selected PRS channel sets RXEN, enabling the receiver.                                                                                |

## 21.5.15 EUSART\_CMD - Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |            |       |     |     |     |     |     |     |     |     |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------|-------|-----|-----|-----|-----|-----|-----|-----|-----|
| 0x038  | 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   |     |     |     |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | W(nB)      | 0x0   | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | W(nB)      | 0x0   | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLEARTX    | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TXTRIDIS   | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TXTRIEN    | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RXBLOCKDIS | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RXBLOCKEN  | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TXDIS      | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | TXEN       | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RXDIS      | W(nB) | 0x0 |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RXEN       | W(nB) | 0x0 |

| Bit  | Name       | Reset | Access | Description                                                                                                                                                                                                                                                                                    |
|------|------------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                              |
| 8    | CLEARTX    | 0x0   | W(nB)  | <b>Clear TX FIFO</b><br><br>Set to clear TX FIFO. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. Note that before issuing this command, firmware should first set the transmitter disable bit (CMD.TXDIS) and then poll the transmitter enable status bit until cleared (STATUS.TXENS). |
| 7    | TXTRIDIS   | 0x0   | W(nB)  | <b>Transmitter Tristate Disable</b><br><br>Disables tristating of the transmitter output.                                                                                                                                                                                                      |
| 6    | TXTRIEN    | 0x0   | W(nB)  | <b>Transmitter Tristate Enable</b><br><br>Tristates the transmitter output. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                                                                                              |
| 5    | RXBLOCKDIS | 0x0   | W(nB)  | <b>Receiver Block Disable</b><br><br>Set to clear RXBLOCK, resulting in all incoming frames being loaded into the RX FIFO.                                                                                                                                                                     |
| 4    | RXBLOCKEN  | 0x0   | W(nB)  | <b>Receiver Block Enable</b><br><br>Set to set RXBLOCK, resulting in all incoming frames being discarded.                                                                                                                                                                                      |
| 3    | TXDIS      | 0x0   | W(nB)  | <b>Transmitter Disable</b><br><br>Set to disable transmission. STATUS.TXENS should be polled to ensure disabled status in Synchronous mode.                                                                                                                                                    |
| 2    | TXEN       | 0x0   | W(nB)  | <b>Transmitter Enable</b><br><br>Set to enable data transmission. STATUS.TXENS should be polled to ensure enabled status in Synchronous mode.                                                                                                                                                  |
| 1    | RXDIS      | 0x0   | W(nB)  | <b>Receiver Disable</b><br><br>Set to disable data reception. If a frame is under reception when the receiver is disabled, the incoming frame is discarded. STATUS.RXENS should be polled to ensure disabled status in Synchronous mode.                                                       |
| 0    | RXEN       | 0x0   | W(nB)  | <b>Receiver Enable</b><br><br>Set to activate data reception. STATUS.RXENS should be polled to ensure enabled status in Synchronous mode.                                                                                                                                                      |

### 21.5.16 EUSART\_RXDATA - RX Data Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x03C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXDATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                 |
| 15:0  | RXDATA   | 0x0   | R      | <b>RX Data and Control bits</b><br><br>Use this register to access data read from the EUSART, cleared on read access. In Synchronous mode, Bit 15:0 is actual RXDATA. In Asynchronous mode, if DALICFG.DALIEN is 0, then Bit 8:0 is actual RXDATA, bit 9 is PERR (set if received data has a parity error.), bit 10 is FERR (set if received data has a framing error, can be result of a break condition). In Asynchronous mode, if DALICFG.DALIEN is set to 1, then all 16 bits represent received data. Note that FIFO is not retained in EM2. |

### 21.5.17 EUSART\_RXDATAP - RX Data Peek Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x040  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXDATAP |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | RXDATAP  | 0x0   | R      | <b>RX Data Peek</b><br><br>Use this register to access data read from the EUSART without popping the FIFO.                                                                        |

### 21.5.18 EUSART\_TXDATA - TX Data Register

| Bit   | Name     | Reset | Access | Description                                                                                                                                                       |
|-------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |

15:0 TXDATA 0x0 W TX Data and Control bits

Use this register to write data to the EUSART. If TXEN is set, a transfer will be initiated at the first opportunity. In Synchronous mode, 15:0 is TXDATA. In Asynchronous mode, if DALICFG.DALIEN is set to 1, then all 16 bits represent data. In Asynchronous mode, if DALICFG.DALIEN is set to 0 then 8:0 is TXDATA, bit 9 is UBRXAT (Set to clear RXBLOCK after transmission, unblocking the receiver), bit 10 is TXTRIAT (Set to tristate transmitter by setting TXTRI after transmission), bit 11 is TXBREAK (Set to send data as a break. Recipient will see a framing error or a break condition depending on its configuration and the value of TXDATA), bit 12 is TXDISAT (Set to disable transmitter and release data bus directly after transmission), bit 13 is RXENAT (Set to enable reception after transmission). Note that FIFO is not retained in EM2

## 21.5.19 EUSART\_STATUS - Status Register

| Offset | Bit Position |    |    |    |             |    |    |     |              |   |     |    |    |    |    |    |        |    |    |    |        |    |    |    |         |   |   |   |        |   |   |   |   |   |   |
|--------|--------------|----|----|----|-------------|----|----|-----|--------------|---|-----|----|----|----|----|----|--------|----|----|----|--------|----|----|----|---------|---|---|---|--------|---|---|---|---|---|---|
| 0x048  | 31           | 30 | 29 | 28 | 27          | 26 | 25 | 0x0 | 24           | R | 0x0 | 23 | 22 | 21 | 20 | 19 | 18     | 17 | 16 | 15 | 14     | 13 | 12 | 11 | 10      | 9 | 8 | 7 | 6      | 5 | 4 | 3 | 2 | 1 | 0 |
| Reset  |              |    |    |    |             |    |    |     | 0x0          |   |     |    |    |    |    |    |        |    |    |    |        |    |    |    |         |   |   |   |        |   |   |   |   |   |   |
| Access |              |    |    |    | R           |    |    |     | R            |   |     |    |    |    |    |    | R      |    |    |    | R      |    |    |    | R       |   |   |   | R      |   |   |   |   |   |   |
| Name   |              |    |    |    | CLEARTXBUSY |    |    |     | AUTOBAUDDONE |   |     |    |    |    |    |    | TXFCNT |    |    |    | TXIDLE |    |    |    | RXIDLE  |   |   |   | RXFULL |   |   |   |   |   |   |
|        |              |    |    |    |             |    |    |     |              |   |     |    |    |    |    |    |        |    |    |    |        |    |    |    | RXFL    |   |   |   | TXFL   |   |   |   |   |   |   |
|        |              |    |    |    |             |    |    |     |              |   |     |    |    |    |    |    |        |    |    |    |        |    |    |    | TXC     |   |   |   | TXTRI  |   |   |   |   |   |   |
|        |              |    |    |    |             |    |    |     |              |   |     |    |    |    |    |    |        |    |    |    |        |    |    |    | RXBLOCK |   |   |   | TXENS  |   |   |   |   |   |   |
|        |              |    |    |    |             |    |    |     |              |   |     |    |    |    |    |    |        |    |    |    |        |    |    |    | RXENS   |   |   |   |        |   |   |   |   |   |   |

| Bit   | Name                                                                                                                                                                                                                        | Reset | Access | Description                               |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------------------------------------|
| 31:26 | Reserved                                                                                                                                                                                                                    |       |        |                                           |
|       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |       |        |                                           |
| 25    | CLEARTXBUSY                                                                                                                                                                                                                 | 0x0   | R      | <b>TX FIFO Clear Busy</b>                 |
|       | After issuing CLEARTX command, wait on this status flag until it goes low.                                                                                                                                                  |       |        |                                           |
| 24    | AUTOBAUDDONE                                                                                                                                                                                                                | 0x0   | R      | <b>Auto Baud Rate Detection Completed</b> |
|       | Set when auto baud rate has been detected and CLKDIV has been updated with required value. If AUTOBAUDEN is not set in CFG0 register, this bit is always read as '0'. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |       |        |                                           |
| 23:21 | Reserved                                                                                                                                                                                                                    |       |        |                                           |
|       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |       |        |                                           |
| 20:16 | TXFCNT                                                                                                                                                                                                                      | 0x0   | R      | <b>Valid entries in TX FIFO</b>           |
|       | Count of TX valid FIFO entries.                                                                                                                                                                                             |       |        |                                           |
| 15:14 | Reserved                                                                                                                                                                                                                    |       |        |                                           |
|       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |       |        |                                           |
| 13    | TXIDLE                                                                                                                                                                                                                      | 0x1   | R      | <b>TX Idle</b>                            |
|       | Set when TX idle. In Synchronous secondary mode, TX is not considered idle when transmitting Default TX data.                                                                                                               |       |        |                                           |
| 12    | RXIDLE                                                                                                                                                                                                                      | 0x1   | R      | <b>RX Idle</b>                            |
|       | Set when RX is idle.                                                                                                                                                                                                        |       |        |                                           |
| 11:9  | Reserved                                                                                                                                                                                                                    |       |        |                                           |
|       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |       |        |                                           |
| 8     | RXFULL                                                                                                                                                                                                                      | 0x0   | R      | <b>RX FIFO Full</b>                       |
|       | Set when the RX FIFO is full.                                                                                                                                                                                               |       |        |                                           |
| 7     | RXFL                                                                                                                                                                                                                        | 0x0   | R      | <b>RX FIFO Level</b>                      |
|       | Set when data is available in the RX FIFO. Depends on the RXFIW setting in the CFG1 register.                                                                                                                               |       |        |                                           |
| 6     | TXFL                                                                                                                                                                                                                        | 0x1   | R      | <b>TX FIFO Level</b>                      |
|       | Set when there is space for data in the TX FIFO. Depends on the TXFIW setting in CFG1 register.                                                                                                                             |       |        |                                           |
| 5     | TXC                                                                                                                                                                                                                         | 0x0   | R      | <b>TX Complete</b>                        |
|       | Set when a transmission has completed and no more data is available in the TX FIFO and shift register.                                                                                                                      |       |        |                                           |
| 4     | TXTRI                                                                                                                                                                                                                       | 0x0   | R      | <b>Transmitter Tristated</b>              |

| Bit | Name     | Reset | Access | Description                                                                                                                                                                                                     |
|-----|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          |       |        | Set when the transmitter is tristated, and cleared when transmitter output is enabled. If AUTOTRI in UARTn_CFG is set, then this bit is always read as 0. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |
| 3   | RXBLOCK  | 0x0   | R      | <b>Block Incoming Data</b>                                                                                                                                                                                      |
|     |          |       |        | When set, the receiver discards incoming frames. An incoming frame will not be loaded into the RX FIFO if this bit is set at the instant the frame has been completely received.                                |
| 2   | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                               |
| 1   | TXENS    | 0x0   | R      | <b>Transmitter Enable Status</b>                                                                                                                                                                                |
|     |          |       |        | Set when the transmitter is enabled. In Synchronous secondary mode, default TX data will be transmitted when the transmitter is disabled.                                                                       |
| 0   | RXENS    | 0x0   | R      | <b>Receiver Enable Status</b>                                                                                                                                                                                   |
|     |          |       |        | Set when the receiver is enabled.                                                                                                                                                                               |

## 21.5.20 EUSART\_IF - Interrupt Flag Register

| Offset | Bit Position |      |             |    |     |    |     |      |        |    |     |      |     |    |        |      |         |        |
|--------|--------------|------|-------------|----|-----|----|-----|------|--------|----|-----|------|-----|----|--------|------|---------|--------|
| 0x04C  | 31           | 30   | 29          | 28 | 27  | 26 | 25  | 24   | 23     | 22 | 21  | 20   | 19  | 18 | 17     | 16   | 15      | 14     |
| Reset  |              |      |             |    |     |    |     |      |        |    |     |      |     |    |        |      |         |        |
| Access |              | RW   | 0x0         | RW | 0x0 | RW | 0x0 | RW   | 0x0    | RW | 0x0 | RW   | 0x0 | RW | 0x0    | RW   | 0x0     |        |
| Name   |              | RXTO | AUTOBAUDONE |    |     |    |     | SIGF | STARTF |    |     | CSWU |     |    | TXIDLE | CCF  | LOADERR | MPAF   |
|        |              |      |             |    |     |    |     |      |        |    |     |      |     |    | FERR   | PERR | TXUF    | TXOF   |
|        |              |      |             |    |     |    |     |      |        |    |     |      |     |    |        | RXUF | RXOF    | RXFULL |
|        |              |      |             |    |     |    |     |      |        |    |     |      |     |    |        | RXFL | RXCFL   |        |
|        |              |      |             |    |     |    |     |      |        |    |     |      |     |    |        | RW   | 0x0     | 1      |
|        |              |      |             |    |     |    |     |      |        |    |     |      |     |    |        | RW   | 0x0     | 0      |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                                                                                                                                                           |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                     |
| 25    | RXTO        | 0x0   | RW     | <b>RX Timeout Interrupt Flag</b><br>Set when RX timeout occurs. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                                                                                                                                 |
| 24    | AUTOBAUDONE | 0x0   | RW     | <b>Auto Baud Complete Interrupt Flag</b><br>Set when auto baud rate detection is complete. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                                                                                                      |
| 23:20 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                     |
| 19    | SIGF        | 0x0   | RW     | <b>Signal Frame Interrupt Flag</b><br>Set when a signal frame is detected. Please note that when MPA, START, and SIGNAL are set to match the same frame, corresponding interrupts might get triggered in arbitrary sequence due to synchronization uncertainty. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |
| 18    | STARTF      | 0x0   | RW     | <b>Start Frame Interrupt Flag</b><br>Set when a start frame is detected. Please note that when MPA, START, and SIGNAL are set to match the same frame, corresponding interrupts might get triggered in arbitrary sequence due to synchronization uncertainty. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.   |
| 17    | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                     |
| 16    | CSWU        | 0x0   | RW     | <b>CS Wake-up Interrupt Flag</b><br>Set when the CS asserts. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'SLAVE'.                                                                                                                                                                   |
| 15:14 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                     |
| 13    | TXIDLE      | 0x0   | RW     | <b>TX Idle Interrupt Flag</b><br>Set when TX goes idle. In Synchronous mode, if TX is disabled during the middle of the transactions, TXIDLEIF won't be triggered when the engine becomes disabled.                                                                                                                   |
| 12    | CCF         | 0x0   | RW     | <b>Collision Check Fail Interrupt Flag</b><br>Set when a collision check notices an error in the transmitted data. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                                                                              |
| 11    | LOADERR     | 0x0   | RW     | <b>Load Error Interrupt Flag</b>                                                                                                                                                                                                                                                                                      |

| Bit | Name   | Reset | Access | Description                                                                                                                                                                                                                                                     |
|-----|--------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        |       |        | Set when the empty TX FIFO is loaded less than the required TIMINGCFG.SETUPWINDOW bus clock cycles before the first edge of the incoming SCLK. Only applicable when CFG0.SYNC bit is set to 'SYNC' and CFG2.MASTER is set to 'SLAVE' and CFG2.FORCELOAD is set. |
| 10  | MPAF   | 0x0   | RW     | <b>Multi-Processor Address Frame Interrupt</b><br>Set when a multi-processor address frame is detected. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                                   |
| 9   | FERR   | 0x0   | RW     | <b>Framing Error Interrupt Flag</b><br>Set when a frame with a framing error is received while RXBLOCK is cleared. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                        |
| 8   | PERR   | 0x0   | RW     | <b>Parity Error Interrupt Flag</b><br>Set when a frame with a parity error is received while RXBLOCK is cleared. Only applicable when CFG0.SYNC bit is set to 'ASYNC'.                                                                                          |
| 7   | TXUF   | 0x0   | RW     | <b>TX FIFO Underflow Interrupt Flag</b><br>In Sync secondary mode, Set when reading an empty TX FIFO with TX enabled. In Synchronous main Mode with AU-TOTX enabled, set when transmitting the word that does not contain valid data.                           |
| 6   | TXOF   | 0x0   | RW     | <b>TX FIFO Overflow Interrupt Flag</b><br>Set when a write is done to the TX FIFO while it is full. The data already in the TX FIFO is preserved.                                                                                                               |
| 5   | RXUF   | 0x0   | RW     | <b>RX FIFO Underflow Interrupt Flag</b><br>Set when trying to read from the RX FIFO when it is empty.                                                                                                                                                           |
| 4   | RXOF   | 0x0   | RW     | <b>RX FIFO Overflow Interrupt Flag</b><br>Set when data is completely received in the receive shift register but the RX FIFO is full. RX FIFO is not overwritten by new data.                                                                                   |
| 3   | RXFULL | 0x0   | RW     | <b>RX FIFO Full Interrupt Flag</b><br>Set when the RX FIFO becomes full.                                                                                                                                                                                        |
| 2   | RXFL   | 0x0   | RW     | <b>RX FIFO Level Interrupt Flag</b><br>Set when data becomes available in the RX FIFO. This field depends on the RXFIW field in the CFG1 register.                                                                                                              |
| 1   | TXFL   | 0x0   | RW     | <b>TX FIFO Level Interrupt Flag</b><br>Set when space becomes available in the TX FIFO. This depends on the TXFIW field in the CFG1 register.                                                                                                                   |
| 0   | TXC    | 0x0   | RW     | <b>TX Complete Interrupt Flag</b><br>This interrupt is set after a transmission when both the TX FIFO and shift register are empty.                                                                                                                             |

### 21.5.21 EUSART\_IEN - Interrupt Enable Register

| Offset | Bit Position |      |             |      |        |      |        |     |         |      |      |      |      |      |      |      |        |      |      |     |    |    |    |    |    |    |    |    |  |  |  |  |
|--------|--------------|------|-------------|------|--------|------|--------|-----|---------|------|------|------|------|------|------|------|--------|------|------|-----|----|----|----|----|----|----|----|----|--|--|--|--|
| 0x050  | 31           | 30   | 29          | 28   | 27     | 26   | 25     | 20  | 19      | 18   | 17   | 16   | 15   | 14   | 13   | 12   | 11     | 10   | 9    | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |  |
| Reset  |              |      |             |      |        |      |        |     |         |      |      |      |      |      |      |      |        |      |      |     |    |    |    |    |    |    |    |    |  |  |  |  |
| Access |              | RW   | RW          | RW   | RW     | RW   | RW     | RW  | RW      | RW   | RW   | RW   | RW   | RW   | RW   | RW   | RW     | RW   | RW   | RW  | RW | RW | RW | RW | RW | RW | RW | RW |  |  |  |  |
| Name   |              | RXTO | AUTOBAUDONE | SIGF | STARTF | CSWU | TXIDLE | CCF | LOADERR | MPAF | FERR | PERR | TXUF | TXOF | RXUF | RXOF | RXFULL | RXFL | TXFL | TXC |    |    |    |    |    |    |    |    |  |  |  |  |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 25    | RXTO        | 0x0   | RW     | <b>RX Timeout Enable</b><br>Interrupt enable for RXTOIF.                                                                                                                          |
| 24    | AUTOBAUDONE | 0x0   | RW     | <b>Auto Baud Complete Enable</b><br>Interrupt enable for AUTOBAUDONEIF.                                                                                                           |
| 23:20 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19    | SIGF        | 0x0   | RW     | <b>Signal Frame Enable</b><br>Interrupt enable for SIGFIF.                                                                                                                        |
| 18    | STARTF      | 0x0   | RW     | <b>Start Frame Enable</b><br>Interrupt enable for STARTFIF.                                                                                                                       |
| 17    | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 16    | CSWU        | 0x0   | RW     | <b>CS Wake-up Enable</b><br>Interrupt enable for CSWUIF.                                                                                                                          |
| 15:14 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13    | TXIDLE      | 0x0   | RW     | <b>TX IDLE Enable</b><br>Interrupt enable for TXIDLEIF.                                                                                                                           |
| 12    | CCF         | 0x0   | RW     | <b>Collision Check Fail Enable</b><br>Interrupt enable for CCFIF.                                                                                                                 |
| 11    | LOADERR     | 0x0   | RW     | <b>Load Error Enable</b><br>Interrupt enable for LOADERRIF.                                                                                                                       |
| 10    | MPAF        | 0x0   | RW     | <b>Multi-Processor Addr Frame Enable</b><br>Interrupt enable for MPAFIF.                                                                                                          |
| 9     | FERR        | 0x0   | RW     | <b>Framing Error Enable</b><br>Interrupt enable for FERRIF.                                                                                                                       |

| Bit | Name   | Reset | Access | Description                                                     |
|-----|--------|-------|--------|-----------------------------------------------------------------|
| 8   | PERR   | 0x0   | RW     | <b>Parity Error Enable</b><br>Interrupt enable for PERRIF.      |
| 7   | TXUF   | 0x0   | RW     | <b>TX FIFO Underflow Enable</b><br>Interrupt enable for TXUFIG. |
| 6   | TXOF   | 0x0   | RW     | <b>TX FIFO Overflow Enable</b><br>Interrupt enable for TXOFIG.  |
| 5   | RXUF   | 0x0   | RW     | <b>RX FIFO Underflow Enable</b><br>Interrupt enable for RXUFIG. |
| 4   | RXOF   | 0x0   | RW     | <b>RX FIFO Overflow Enable</b><br>Interrupt enable for RXOFIG.  |
| 3   | RXFULL | 0x0   | RW     | <b>RX FIFO Full Enable</b><br>Interrupt enable for RXFULLIF.    |
| 2   | RXFL   | 0x0   | RW     | <b>RX FIFO Level Enable</b><br>Interrupt enable for RXFLIF.     |
| 1   | TXFL   | 0x0   | RW     | <b>TX FIFO Level Enable</b><br>Interrupt enable for TXFLIF.     |
| 0   | TXC    | 0x0   | RW     | <b>TX Complete Enable</b><br>Interrupt enable for TXCIF.        |

### 21.5.22 EUSART\_SYNCBUSY - Synchronization Busy Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |          |         |            |           |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----------|---------|------------|-----------|
| 0x054  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15        | 14       | 13      | 12         |           |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0       | 0x0      | 0x0     | 0x0        | 0x0       |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R         | R        | R       | R          | R         |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AUTOTXTEN | TXTRIDIS | TXTRIEN | RXBLOCKDIS | RXBLOCKEN |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R         | R        | R       | R          | R         |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TXDIS     | TXEN     | RXDIS   | RXEN       | TXTEN     |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R         | R        | R       | R          | R         |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DIV       |          |         |            |           |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                                                                                                  |
|-------|------------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                            |
| 11    | AUTOTXTEN  | 0x0   | R      | <b>SYNCBUSY for AUTOTXTEN in TRIGCTRL</b><br><br>This bit is set when there is an ongoing synchronization of AUTOTXTEN field. Do not do another write to the same field while this bit is set.                                               |
| 10    | TXTRIDIS   | 0x0   | R      | <b>SYNCBUSY in TXTRIDIS in CMD</b><br><br>This bit is set when there is an ongoing synchronization of TXTRIDIS field. Do not do another write to the same field while this bit is set. Only applicable when CFG0.SYNC bit is set to 'ASYNC'. |
| 9     | TXTRIEN    | 0x0   | R      | <b>SYNCBUSY for TXTRIEN in CMD</b><br><br>This bit is set when there is an ongoing synchronization of TXTRIEN field. Do not do another write to the same field while this bit is set.                                                        |
| 8     | RXBLOCKDIS | 0x0   | R      | <b>SYNCBUSY for RXBLOCKDIS in CMD</b><br><br>This bit is set when there is an ongoing synchronization of RXBLOCKDIS field. Do not do another write to the same field while this bit is set.                                                  |
| 7     | RXBLOCKEN  | 0x0   | R      | <b>SYNCBUSY for RXBLOCKEN in CMD</b><br><br>This bit is set when there is an ongoing synchronization of RXBLOCKEN field. Do not do another write to the same field while this bit is set.                                                    |
| 6     | TXDIS      | 0x0   | R      | <b>SYNCBUSY for TXDIS in CMD</b><br><br>This bit is set when there is an ongoing synchronization of TXDIS field. Do not do another write to the same field while this bit is set.                                                            |
| 5     | TXEN       | 0x0   | R      | <b>SYNCBUSY for TXEN in CMD</b><br><br>This bit is set when there is an ongoing synchronization of TXEN field. Do not do another write to the same field while this bit is set.                                                              |
| 4     | RXDIS      | 0x0   | R      | <b>SYNCBUSY for RXDIS in CMD</b><br><br>This bit is set when there is an ongoing synchronization of RXDIS field. Do not do another write to the same field while this bit is set.                                                            |
| 3     | RXEN       | 0x0   | R      | <b>SYNCBUSY for RXEN in CMD</b><br><br>This bit is set when there is an ongoing synchronization of RXEN field. Do not do another write to the same field while this bit is set.                                                              |
| 2     | TXTEN      | 0x0   | R      | <b>SYNCBUSY for TXTEN in TRIGCTRL</b><br><br>This bit is set when there is an ongoing synchronization of TXTEN field. Do not do another write to the same field while this bit is set.                                                       |

| Bit | Name  | Reset | Access | Description                                                                                                                                                                            |
|-----|-------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RXTEN | 0x0   | R      | <b>SYNCBUSY for RXTEN in TRIGCTRL</b><br><br>This bit is set when there is an ongoing synchronization of RXTEN field. Do not do another write to the same field while this bit is set. |
| 0   | DIV   | 0x0   | R      | <b>SYNCBUSY for DIV in CLKDIV</b><br><br>This bit is set when there is an ongoing synchronization of DIV field. Do not do another write to the same field while this bit is set.       |

### 21.5.23 EUSART\_DALICFG - DALI Config Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |   |   |   |   |   |   |        |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|---|---|---|---|---|---|--------|---|---|---|
| 0x058  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0        |    |    |    |    |    |    |   |   |   |   |   |   | 0x0    |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |    |    |    |    |    |    |   |   |   |   |   |   | RW     |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DALIRXENDT |    |    |    |    |    |    |   |   |   |   |   |   | DALIEN |   |   |   |

| Bit   | Name           | Reset                                                                                                                                                                             | Access | Description                                                                                                                                       |
|-------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                   |
| 15    | DALIRXENDT     | 0x0                                                                                                                                                                               | RW     | <b>DALI RX Enabled During Transmission</b><br><br>If set, then EUSART RX will stay enabled during EUSART DALI TX. Should be set in loopback mode. |
| 14:13 | Reserved       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                   |
| 12:8  | DALIRXDATABITS | 0x0                                                                                                                                                                               | RW     | <b>DALI RX Databits</b><br><br>DALI RX databits (8-32). Only used if DALIEN is set.                                                               |
| Value | Mode           | Description                                                                                                                                                                       |        |                                                                                                                                                   |
| 0     | EIGHT          | Each frame contains 8 data bits                                                                                                                                                   |        |                                                                                                                                                   |
| 1     | NINE           | Each frame contains 9 data bits                                                                                                                                                   |        |                                                                                                                                                   |
| 2     | TEN            | Each frame contains 10 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 3     | ELEVEN         | Each frame contains 11 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 4     | TWELVE         | Each frame contains 12 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 5     | THIRTEEN       | Each frame contains 13 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 6     | FOURTEEN       | Each frame contains 14 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 7     | FIFTEEN        | Each frame contains 15 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 8     | SIXTEEN        | Each frame contains 16 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 9     | SEVENTEEN      | Each frame contains 17 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 10    | EIGHTEEN       | Each frame contains 18 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 11    | NINETEEN       | Each frame contains 19 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 12    | TWENTY         | Each frame contains 20 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 13    | TWENTYONE      | Each frame contains 21 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 14    | TWENTYTWO      | Each frame contains 22 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 15    | TWENTYTHREE    | Each frame contains 23 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 16    | TWENTYFOUR     | Each frame contains 24 data bits                                                                                                                                                  |        |                                                                                                                                                   |
| 17    | TWENTYFIVE     | Each frame contains 25 data bits                                                                                                                                                  |        |                                                                                                                                                   |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18    | TWENTYSIX      |       |        | Each frame contains 26 data bits                                                                                                                                                  |
| 19    | TWENTYSEVEN    |       |        | Each frame contains 27 data bits                                                                                                                                                  |
| 20    | TWENTYEIGHT    |       |        | Each frame contains 28 data bits                                                                                                                                                  |
| 21    | TWENTYNINE     |       |        | Each frame contains 29 data bits                                                                                                                                                  |
| 22    | THIRTY         |       |        | Each frame contains 30 data bits                                                                                                                                                  |
| 23    | THIRTYONE      |       |        | Each frame contains 31 data bits                                                                                                                                                  |
| 24    | THIRTYTWO      |       |        | Each frame contains 32 data bits                                                                                                                                                  |
| 7:6   | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:1   | DALITXDATABITS | 0x0   | RW     | <b>DALI TX Databits</b>                                                                                                                                                           |
|       |                |       |        | DALI TX databits (8-32). Only used if DALIEN is set.                                                                                                                              |
| Value | Mode           |       |        | Description                                                                                                                                                                       |
| 0     | EIGHT          |       |        | Each frame contains 8 data bits                                                                                                                                                   |
| 1     | NINE           |       |        | Each frame contains 9 data bits                                                                                                                                                   |
| 2     | TEN            |       |        | Each frame contains 10 data bits                                                                                                                                                  |
| 3     | ELEVEN         |       |        | Each frame contains 11 data bits                                                                                                                                                  |
| 4     | TWELVE         |       |        | Each frame contains 12 data bits                                                                                                                                                  |
| 5     | THIRTEEN       |       |        | Each frame contains 13 data bits                                                                                                                                                  |
| 6     | FOURTEEN       |       |        | Each frame contains 14 data bits                                                                                                                                                  |
| 7     | FIFTEEN        |       |        | Each frame contains 15 data bits                                                                                                                                                  |
| 8     | SIXTEEN        |       |        | Each frame contains 16 data bits                                                                                                                                                  |
| 9     | SEVENTEEN      |       |        | Each frame contains 17 data bits                                                                                                                                                  |
| 10    | EIGHTEEN       |       |        | Each frame contains 18 data bits                                                                                                                                                  |
| 11    | NINETEEN       |       |        | Each frame contains 19 data bits                                                                                                                                                  |
| 12    | TWENTY         |       |        | Each frame contains 20 data bits                                                                                                                                                  |
| 13    | TWENTYONE      |       |        | Each frame contains 21 data bits                                                                                                                                                  |
| 14    | TWENTYTWO      |       |        | Each frame contains 22 data bits                                                                                                                                                  |
| 15    | TWENTYTHREE    |       |        | Each frame contains 23 data bits                                                                                                                                                  |
| 16    | TWENTYFOUR     |       |        | Each frame contains 24 data bits                                                                                                                                                  |
| 17    | TWENTYFIVE     |       |        | Each frame contains 25 data bits                                                                                                                                                  |
| 18    | TWENTYSIX      |       |        | Each frame contains 26 data bits                                                                                                                                                  |
| 19    | TWENTYSEVEN    |       |        | Each frame contains 27 data bits                                                                                                                                                  |
| 20    | TWENTYEIGHT    |       |        | Each frame contains 28 data bits                                                                                                                                                  |
| 21    | TWENTYNINE     |       |        | Each frame contains 29 data bits                                                                                                                                                  |
| 22    | THIRTY         |       |        | Each frame contains 30 data bits                                                                                                                                                  |
| 23    | THIRTYONE      |       |        | Each frame contains 31 data bits                                                                                                                                                  |
| 24    | THIRTYTWO      |       |        | Each frame contains 32 data bits                                                                                                                                                  |

| Bit | Name   | Reset | Access | Description                            |
|-----|--------|-------|--------|----------------------------------------|
| 0   | DALIEN | 0x0   | RW     | <b>DALI Enable Bit</b><br>DALI EN bit. |

## 22. I2C - Inter-Integrated Circuit Interface



### Quick Facts

#### What?

The I<sup>2</sup>C interface allows communication on I<sup>2</sup>C-buses with the lowest energy consumption possible.

#### Why?

I<sup>2</sup>C is a popular serial bus that enables communication with a number of external devices using only two I/O pins.

#### How?

With the help of DMA, the I<sup>2</sup>C interface allows I<sup>2</sup>C communication with minimal CPU intervention. Address recognition is available in all energy modes (except EM4), allowing the MCU to wait for data on the I<sup>2</sup>C-bus with sub- $\mu$ A current consumption.

### 22.1 Introduction

The I<sup>2</sup>C module provides an interface between the MCU and a serial I<sup>2</sup>C-bus. It is capable of acting as both a leader and a follower and supports multi-leader buses. Standard-mode, fast-mode and fast-mode plus speeds are supported, allowing transmission rates all the way from 10 kbit/s up to 1 Mbit/s. Follower arbitration and timeouts are also provided to allow implementation of an SMBus compliant system. The interface provided to software by the I<sup>2</sup>C module allows precise control of the transmission process and highly automated transfers. Automatic recognition of follower addresses is provided in all energy modes (except EM4).

### 22.2 Features

- True multi-leader capability
- Support for different bus speeds
  - Standard-mode (Sm) bit rate up to 100 kbit/s
  - Fast-mode (Fm) bit rate up to 400 kbit/s
  - Fast-mode Plus (Fm+) bit rate up to 1 Mbit/s
- Arbitration for both leader and follower (allows SMBus ARP)
- Clock synchronization and clock stretching
- Hardware address recognition
  - 7-bit masked address
  - General call address
  - Supported in EM2/3 (I2C0-only)
- 10-bit address support
- Error handling
  - Clock low timeout
  - Bus idle (clock high) timeout
  - Arbitration lost
  - Bus error detection
- Separate receive/ transmit 2-level buffers, with additional separate shift registers
- Full DMA support

## 22.3 Functional Description

An overview of the I2C module is shown in [Figure 22.1 I2C Overview on page 701](#).



**Figure 22.1. I<sup>2</sup>C Overview**

### 22.3.1 I2C-Bus Overview

The I<sup>2</sup>C-bus uses two wires for communication; a serial data line (SDA) and a serial clock line (SCL) as shown in [Figure 22.2 I2C-Bus Example on page 702](#). As a true multi-leader bus it includes collision detection and arbitration to resolve situations where multiple leaders transmit data at the same time without data loss.



**Figure 22.2. I2C-Bus Example**

Each device on the bus is addressable by a unique address, and an I<sup>2</sup>C leader can address all the devices on the bus, including other leaders.

Both the bus lines are open-drain. The maximum value of the pull-up resistor can be calculated as a function of the maximal rise-time  $t_r$  for the given bus speed, and the estimated bus capacitance  $C_b$  as shown in [Figure 22.3 I2C Pull-up Resistor Equation on page 702](#).

$$R_p(\max) = t_r / (0.8473 \times C_b).$$

**Figure 22.3. I2C Pull-up Resistor Equation**

The maximal rise times for 100 kHz, 400 kHz and 1 MHz I<sup>2</sup>C are 1  $\mu$ s, 300 ns and 120 ns respectively.

**Note:** The GPIO slew rate control should be set for the desired slew rate..

**Note:** If  $V_{dd}$  drops below the voltage on SCL and SDA lines, the MCU could become back powered and pull the SCL and SDA lines low.

### 22.3.1.1 START and STOP Conditions

START and STOP conditions are used to initiate and stop transactions on the I<sup>2</sup>C-bus. All transactions on the bus begin with a START condition (S) and end with a STOP condition (P). As shown in [Figure 22.4 I2C START and STOP Conditions on page 703](#), a START condition is generated by pulling the SDA line low while SCL is high, and a STOP condition is generated by pulling the SDA line high while SCL is high.



**Figure 22.4. I2C START and STOP Conditions**

The START and STOP conditions are easily identifiable bus events as they are the only conditions on the bus where a transition is allowed on SDA while SCL is high. During the actual data transmission, SDA is only allowed to change while SCL is low, and must be stable while SCL is high. One bit is transferred per clock pulse on the I<sup>2</sup>C-bus as shown in [Figure 22.5 I2C Bit Transfer on I<sup>2</sup>C-Bus on page 703](#).



**Figure 22.5. I2C Bit Transfer on I<sup>2</sup>C-Bus**

### 22.3.1.2 Bus Transfer

When a leader wants to initiate a transfer on the bus, it waits until the bus is idle and transmits a START condition on the bus. The leader then transmits the address of the follower it wishes to interact with and a single R/W bit telling whether it wishes to read from the follower (R/W bit set to 1) or write to the follower (R/W bit set to 0).

After the 7-bit address and the R/W bit, the leader releases the bus, allowing the follower to acknowledge the request. During the next bit-period, the follower pulls SDA low (ACK) if it acknowledges the request, or keeps it high if it does not acknowledge it (NACK).

Following the address acknowledge, either the follower or leader transmits data, depending on the value of the R/W bit. After every 8 bits (one byte) transmitted on the SDA line, the transmitter releases the line to allow the receiver to transmit an ACK or a NACK. Both the data and the address are transmitted with the most significant bit first.

The number of bytes in a bus transfer is unrestricted. The leader ends the transmission after a (N)ACK by sending a STOP condition on the bus. After a STOP condition, any leader wishing to initiate a transfer on the bus can try to gain control of it. If the current leader wishes to make another transfer immediately after the current, it can start a new transfer directly by transmitting a repeated START condition (Sr) instead of a STOP followed by a START.

Examples of I<sup>2</sup>C transfers are shown in [Figure 22.6 I2C Single Byte Write to Follower on page 704](#), [Figure 22.7 I2C Double Byte Read from Follower on page 704](#), and [Figure 22.8 I2C Single Byte Write, then Repeated Start and Single Byte Read on page 704](#).

The identifiers used are:

- ADDR - Address
- DATA - Data
- S - Start bit
- Sr - Repeated start bit
- P - Stop bit
- W/R - Read(1)/Write(0)
- A - ACK
- N - NACK



Figure 22.6. I2C Single Byte Write to Follower



Figure 22.7. I2C Double Byte Read from Follower



Figure 22.8. I2C Single Byte Write, then Repeated Start and Single Byte Read

### 22.3.1.3 Addresses

I<sup>2</sup>C supports both 7-bit and 10-bit addresses. When using 7-bit addresses, the first byte transmitted after the START-condition contains the address of the follower that the leader wants to contact. In the 7-bit address space, several addresses are reserved. These addresses are summarized in [Table 22.1 I<sup>2</sup>C Reserved I<sup>2</sup>C Addresses on page 705](#), and include a General Call address which can be used to broadcast a message to all followers on the I<sup>2</sup>C-bus.

**Table 22.1. I<sup>2</sup>C Reserved I<sup>2</sup>C Addresses**

| I <sup>2</sup> C Address | R/W | Description                         |
|--------------------------|-----|-------------------------------------|
| 0000-000                 | 0   | General Call address                |
| 0000-000                 | 1   | START byte                          |
| 0000-001                 | X   | Reserved for the C-Bus format       |
| 0000-010                 | X   | Reserved for a different bus format |
| 0000-011                 | X   | Reserved for future purposes        |
| 0000-1XX                 | X   | Reserved for future purposes        |
| 1111-1XX                 | X   | Reserved for future purposes        |
| 1111-0XX                 | X   | 10 Bit follower addressing mode     |

### 22.3.1.4 10-bit Addressing

To address a follower using a 10-bit address, two bytes are required to specify the address instead of one. The seven first bits of the first byte must then be 1111 0XX, where XX are the two most significant bits of the 10-bit address. As with 7-bit addresses, the eighth bit of the first byte determines whether the leader wishes to read from or write to the follower. The second byte contains the eight least significant bits of the follower address.

When a follower receives a 10-bit address, it must acknowledge both the address bytes if they match the address of the follower.

When performing a leader transmitter operation, the leader transmits the two address bytes and then the remaining data, as shown in [Figure 22.9 I<sup>2</sup>C Leader Transmitter/Follower Receiver with 10-bit Address on page 705](#).

**Figure 22.9. I<sup>2</sup>C Leader Transmitter/Follower Receiver with 10-bit Address**

When performing a leader receiver operation however, the leader first transmits the two address bytes in a leader transmitter operation, then sends a repeated START followed by the first address byte and then receives data from the addressed follower. The follower addressed by the 10-bit address in the first two address bytes must remember that it was addressed, and respond with data if the address transmitted after the repeated start matches its own address. An example of this (with one byte transmitted) is shown in [Figure 22.10 I<sup>2</sup>C Leader Receiver/Follower Transmitter with 10-bit Address on page 705](#).

**Figure 22.10. I<sup>2</sup>C Leader Receiver/Follower Transmitter with 10-bit Address**

### 22.3.1.5 Arbitration, Clock Synchronization, Clock Stretching

Arbitration and clock synchronization are features aimed at allowing multi-leader buses. Arbitration occurs when two devices try to drive the bus at the same time. If one device drives it low, while the other drives it high, the one attempting to drive it high will not be able to do so due to the open-drain bus configuration. Both devices sample the bus, and the one that was unable to drive the bus in the desired direction detects the collision and backs off, letting the other device continue communication on the bus undisturbed.

Clock synchronization is a means of synchronizing the clock outputs from several leaders driving the bus at once, and is a requirement for effective arbitration.

Followers on the bus are allowed to force the clock output on the bus low in order to pause the communication on the bus and give themselves time to process data or perform any real-time tasks they might have. This is called clock stretching.

Arbitration is supported by the I<sup>2</sup>C module for both leaders and followers. Clock synchronization and clock stretching is also supported.

### 22.3.2 Enable and Reset

The I<sup>2</sup>C is enabled by setting the EN bit in the I2C\_EN register.

To reset the internal state of the I<sup>2</sup>C module and terminate any ongoing transfers, set the CORERST bit in I2C\_CTRL. After resetting, the CORERST bit must be cleared to resume I<sup>2</sup>C operation.

**Note:** When enabling the I<sup>2</sup>C, the ABORT command or the Bus Idle Timeout feature must be applied prior to use even if the BUSY flag is not set.

### 22.3.3 Pin Configuration

The I<sup>2</sup>C SDA and SCL pins are configured and enabled in the GPIO\_I2Cn\_ROUTEEN, GPIO\_I2Cn\_SCLROUTE, and GPIO\_I2Cn\_SDAROUTE registers.

The I<sup>2</sup>C module must be configured to use pins on either Port A or B if wakeup on address recognition from EM2/3 is desired. All other ports are available only in EM0/1. See GPIO chapter for more details on Port limitations.

If the I<sup>2</sup>C module is configured to use pins other than Port A or B, firmware should reset the module before entering EM2/3 by setting the CORERST bit in I2C\_CTRL. After resuming EM0/1 operation, firmware should then clear CORERST.

### 22.3.4 Safely Disabling and Changing Follower Configuration

The I<sup>2</sup>C follower is partially asynchronous, and some precautions are necessary to always ensure a safe follower disable or follower configuration change. These measures should be taken, if (while the follower is enabled) the user cannot guarantee that an address match will not occur at the exact time of follower disable or follower configuration change.

Worst case consequences for an address match while disabling follower or changing configuration is that the follower may end up in an undefined state. To reset the follower back to a known state, the EN bit in I2C\_EN must be cleared. This should be done regardless of whether the follower is going to be re-enabled or not.

### 22.3.5 Clock Generation

The I<sup>2</sup>C peripheral clock (I2CCLK) for I2C0 is derived from the LSPCLK, and for I2C1 is derived from the PCLK.

The SCL signal generated by the I<sup>2</sup>C leader determines the maximum transmission rate on the bus. The clock is generated as a division of the peripheral clock (I2CCLK), and is given by the following equation:

$$f_{SCL} = f_{I2CCLK} / (((N_{low} + N_{high}) \times (DIV + 1)) + 8 + N_{fall} + N_{rise})$$

**Figure 22.11. I2C Maximum Transmission Rate**

Where DIV is the clock divider value set in I2C\_CLKDIV, the values of  $N_{low}$  and  $N_{high}$  (and thus the ratio between the high and low parts of the clock signal) are controlled by CLHR in the I2C\_CTRL register, and  $N_{fall}$  and  $N_{rise}$  represent the number of I2CCLK cycles required for clock synchronization.

The values of  $N_{low}$  and  $N_{high}$  specify the number of prescaled clock cycles in the low and high periods of the clock signal respectively. The worst case low and high periods of the signal are:

$$\begin{aligned} t_{high} &\geq (N_{high} \times (DIV + 1) + 4) / f_{I2CCLK} \\ t_{low} &\geq (N_{low} \times (DIV + 1) + 4) / f_{I2CCLK} \end{aligned}$$

**Figure 22.12. I2C High and Low Cycles Equations**

Clock synchronization is used to ensure that requested low and high times are met on the bus. The counters establishing high and low time are only active once the pin logic has reached the high or low logic levels, and so the rise and fall times will impact the maximum transmission rate on the bus. The clock logic level is sampled at a rate of  $f_{I2CCLK}$ , and will therefore be quantized to an integer number of I2CCLK clock cycles, as:

$$N_{rise} = \text{CEILING}(t_{rise} / f_{I2CCLK})$$

$$N_{fall} = \text{CEILING}(t_{fall} / f_{I2CCLK})$$

**Figure 22.13. I2C Clock Synchronization Cycles**

Note that there is an inherent propagation delay between driving SCL and sampling the signal, so the above equations can result in  $N = 0$  for fast rise or fall times.

For example, a system with a weak pull-up on SCL may result in long  $t_{rise}$ , requiring several  $N_{rise}$  synchronization cycles, and subsequently impact the I<sup>2</sup>C transmission rate. In the same system,  $t_{fall}$  may be faster than the sampling delay, resulting in  $N_{fall} = 0$ .

**Note:** DIV must be set to 1 during follower mode operation.

### 22.3.6 Arbitration

Arbitration is enabled by default, but can be disabled by setting the ARBDIS bit in I2C\_CTRL. When arbitration is enabled, the value on SDA is sensed every time the I<sup>2</sup>C module attempts to change its value. If the sensed value is different than the value the I<sup>2</sup>C module tried to output, it is interpreted as a simultaneous transmission by another device, and that the I<sup>2</sup>C module has lost arbitration.

Whenever arbitration is lost, the ARBLOST interrupt flag in I2C\_IF is set, any lines held are released, and the I<sup>2</sup>C device goes idle. If an I<sup>2</sup>C leader loses arbitration during the transmission of an address, another leader may be trying to address it. The leader therefore receives the rest of the address, and if the address matches the follower address of the leader, the leader goes into either follower transmitter or follower receiver mode.

**Note:**

Arbitration can be lost both when operating as a leader and when operating as a follower.

### 22.3.7 Buffers

### 22.3.7.1 Transmit Buffer and Shift Register

The I<sup>2</sup>C transmitter has a 2-level FIFO transmit buffer and a transmit shift register as shown in [Figure 22.1 I2C Overview on page 701](#). A byte is loaded into the transmit buffer by writing to I2C\_TXDATA or 2 bytes can be loaded simultaneously in the transmit buffer by writing to I2C\_TXDOUBLE. [Figure 22.14 I2C Transmit Buffer Operation on page 708](#) shows the basics of the transmit buffer. When the transmit shift register is empty and ready for new data, the byte from the transmit buffer is then loaded into the shift register. The byte is then kept in the shift register until it is transmitted. When a byte has been transmitted, a new byte is loaded into the shift register (if available in the transmit buffer). If the transmit buffer is empty, then the shift register also remains empty. The TXC flag in I2C\_STA-TUS and the TXC interrupt flags in I2C\_IF are then set, signaling that the transmit shift register is out of data. TXC is cleared when new data becomes available, but the TXC interrupt flag must be cleared by software.



**Figure 22.14. I2C Transmit Buffer Operation**

The TXBL flags in I2C\_STATUS and I2C\_IF are used to indicate the level of the transmit buffer. The TXBIL bit in I2C\_CTRL controls the level at which these flag bits are set:

- If TXBIL is cleared, the TXBL flags are set whenever the transmit buffer becomes empty (used when transmitting using I2C\_TXDOUBLE).
- If TXBIL is set, the TXBL flags are set whenever the transmit buffer goes from full to half-empty or empty (used when transmitting with I2C\_TXDATA).

The TXBL status flag in I2C\_STATUS is cleared automatically when the condition becomes false. After the transmit FIFOs are filled, software needs to manually clear the TXBL interrupt flag. Note that the TXBL interrupt flag is 0 by default, but immediately after software sets I2C\_EN.EN = 1, the TXBL interrupt flag will be set to indicate the transmit FIFO is empty. When the I<sup>2</sup>C module is disabled (I2C\_EN.EN= 0), software needs to manually clear the TXBL interrupt flag (or ignore it).

Additionally, the TXBUFCNT bitfield in I2C\_STATUS can be read to determine the exact number of transmit buffers filled with valid data. This is particularly useful for determining whether the transmit buffers are full. For example, if TXBUFCNT = '2', firmware can determine that both transmit buffers are filled, and that any additional data written to the transmit buffer would result in an overflow condition. Note that the TXBUFCNT count does not include the TX shift register.

If an attempt is made to write more bytes to the transmit buffer than the space available, the TXOF interrupt flag in I2C\_IF is set, indicating the overflow. The data already in the buffer remains preserved, and no new data is written.

The transmit buffer and the transmit shift register can be cleared by setting command bit CLEARTX in I2C\_CMD. This will prevent the I<sup>2</sup>C module from transmitting the data in the buffer and the shift register, and will make them available for new data. Any byte currently being transmitted will not be aborted. Transmission of this byte will be completed.

### 22.3.7.2 Receive Buffer and Shift Register

The I<sup>2</sup>C receiver uses a 2-level FIFO receive buffer and a receive shift register as shown in [Figure 22.15 I2C Receive Buffer Operation on page 709](#). When a byte has been fully received by the receive shift register, it is loaded into the receive buffer if there is room for it, making the shift register empty to receive another byte. Otherwise, the byte waits in the shift register until space becomes available in the buffer.



**Figure 22.15. I2C Receive Buffer Operation**

When a byte becomes available in the receive buffer, the RXDATAV flags in I2C\_STATUS and I2C\_IF are set. When the buffer becomes full, the RXFULL flags in I2C\_STATUS and I2C\_IF are set. The RXDATAV and RXFULL flags in I2C\_STATUS are automatically cleared by hardware when their condition is no longer true. The RXDATAV and RXFULL flags in I2C\_IF must be manually cleared by software after the receive FIFO is emptied. Note that when the RXFULL flag is set, indicating the buffer is full, space is still available in the receive shift register for one more byte.

The data can be fetched from the buffer in two ways. I2C\_RXDATA gives access to the received byte (if two bytes are received then the one received first is fetched first). I2C\_RXDOUBLE makes it possible to read the two received bytes simultaneously. If an attempt is made to read more bytes from the buffer than available, the RXUF interrupt flag in I2C\_IF is set to signal the underflow, and the data read from the buffer is undefined.

When using I2C\_RXDOUBLE to pick data, AUTOACK in I2C\_CTRL should be set to 1. This ensures that an ACK is automatically sent out after the first byte is received so that the reception of the next byte can begin. In order to stop receiving data bytes, a NACK must be sent out through the I2C\_CMD register.

I2C\_RXDATAP and I2C\_RXDOUBLEP can be used to read data from the receive buffer without removing it from the buffer. The RXUF interrupt flag in I2C\_IF will never be set as a result of reading from I2C\_RXDATAP and I2C\_RXDOUBLEP, but the data read through I2C\_RXDATAP when the receive buffer is empty is still undefined.

Once a transaction is complete (STOP sent or received), the receive buffer needs to be flushed (all received data must be read) before starting a new transaction.

### 22.3.8 Leader Operation

A bus transaction is initiated by transmitting a START condition (S) on the bus. This is done by setting the START bit in I2C\_CMD. The command schedules a START condition, and makes the I<sup>2</sup>C module generate a start condition whenever the bus becomes free.

The I<sup>2</sup>C-bus is considered busy whenever another device on the bus transmits a START condition. Until a STOP condition is detected, the bus is owned by the leader issuing the START condition. The bus is considered free when a STOP condition is transmitted on the bus. After a STOP is detected, all leaders that have data to transmit send a START condition and begin transmitting data. Arbitration ensures that collisions are avoided.

When the START condition has been transmitted, the leader must transmit a follower address (ADDR) with an R/W bit on the bus. If this address is available in the transmit buffer, the leader transmits it immediately, but if the buffer is empty, the leader holds the I<sup>2</sup>C-bus while waiting for software to write the address to the transmit buffer.

After the address has been transmitted, a sequence of bytes can be read from or written to the follower, depending on the value of the R/W bit (bit 0 in the address byte). If the bit was cleared, the leader has entered a leader transmitter role, where it now transmits data to the follower. If the bit was set, it has entered a leader receiver role, where it now should receive data from the follower. In either case, an unlimited number of bytes can be transferred in one direction during the transmission.

At the end of the transmission, the leader either transmits a repeated START condition (Sr) if it wishes to continue with another transfer, or transmits a STOP condition (P) if it wishes to release the bus. When operating in the leader mode, I2CCLK frequency must be higher than 2 MHz for Standard-mode, 9 MHz for Fast-mode, and 20 MHz for Fast-mode Plus.

### 22.3.8.1 Leader State Machine

The leader state machine is shown in [Figure 22.16 I2C Leader State Machine on page 711](#). A leader operation starts in the far left of the state machine, and follows the solid lines through the state machine, ending the operation or continuing with a new operation when arriving at the right side of the state machine.

Branches in the path through the state machine are the results of bus events and choices made by software, either directly or indirectly. The dotted lines show where I<sup>2</sup>C-specific interrupt flags are set along the path and the full-drawn circles show places where interaction may be required by software to let the transmission proceed.



Figure 22.16. I2C Leader State Machine

### 22.3.8.2 Interactions

Whenever the I<sup>2</sup>C module is waiting for interaction from software, it holds the bus clock SCL low, freezing all bus activities, and the BUSHOLD interrupt flag in I2C\_IF is set. The action(s) required by software depends on the current state of the I<sup>2</sup>C module. This state can be read from the I2C\_STATE register.

As an example, [Table 22.3 I2C Leader Transmitter on page 714](#) shows the different states the I<sup>2</sup>C goes through when operating as a Leader Transmitter, i.e., a leader that transmits data to a follower. As seen in the table, when a start condition has been transmitted, a requirement is that there is an address and an R/W bit in the transmit buffer. If the transmit buffer is empty, then the BUSHOLD interrupt flag is set, and the bus is held until data becomes available in the buffer. While waiting for the address, I2C\_STATE has a value 0x67, which can be used to identify exactly what the I<sup>2</sup>C module is waiting for.

**Note:** The bus would never stop at state 0x67 if the address was available in the transmit buffer.

The BUSHOLD interrupt flag needs to be manually cleared by software after the appropriate action has been taken.

The different interactions used by the I<sup>2</sup>C module are listed in [Table 22.2 I2C Interactions in Prioritized Order on page 712](#) in a prioritized order. If the I<sup>2</sup>C module is in such a state that multiple courses of action are possible, then the action chosen is the one that has the highest priority. For example, after sending out a START, if an address is present in the buffer and a STOP is also pending, then the I<sup>2</sup>C will send out the STOP since it has the higher priority.

**Table 22.2. I2C Interactions in Prioritized Order**

| Interaction      | Priority | Software action                                                  | Automatically continues if                                            |
|------------------|----------|------------------------------------------------------------------|-----------------------------------------------------------------------|
| STOP*            | 1        | Set the STOP command bit in I2C_CMD                              | PSTOP is set (STOP pending) in I2C_STATUS                             |
| ABORT            | 2        | Set the ABORT command bit in I2C_CMD                             | Never, the transmission is aborted                                    |
| CONT*            | 3        | Set the CONT command bit in I2C_CMD                              | PCONT is set in I2C_STATUS (CONT pending)                             |
| NACK*            | 4        | Set the NACK command bit in I2C_CMD                              | PNACK is set in I2C_STATUS (NACK pending)                             |
| ACK*             | 5        | Set the ACK command bit in I2C_CMD                               | AUTOACK is set in I2C_CTRL or PACK is set in I2C_STATUS (ACK pending) |
| ADDR+W -> TXDATA | 6        | Write an address to the transmit buffer with the R/W bit set     | Address is available in transmit buffer with R/W bit set              |
| ADDR+R -> TXDATA | 7        | Write an address to the transmit buffer with the R/W bit cleared | Address is available in transmit buffer with R/W bit cleared          |
| START*           | 8        | Set the START command bit in I2C_CMD                             | PSTART is set in I2C_STATUS (START pending)                           |
| TXDATA/ TXDOUBLE | 9        | Write data to the transmit buffer                                | Data is available in transmit buffer                                  |
| RXDATA/ RXDOUBLE | 10       | Read data from receive buffer                                    | Space is available in receive buffer                                  |
| None             | 11       | No interaction is required                                       |                                                                       |

The commands marked with a \* in [Table 22.2 I2C Interactions in Prioritized Order on page 712](#) can be issued before an interaction is required. When such a command is issued before it can be used/consumed by the I<sup>2</sup>C module, the command is set in a pending state, which can be read from the STATUS register. A pending START command can for instance be identified by PSTART having a high value.

Whenever the I<sup>2</sup>C module requires an interaction, it checks the pending commands. If one or a combination of these can fulfill an interaction, they are consumed by the module and the transmission continues without setting the BUSHOLD interrupt flag in I2C\_IF to get an interaction from software. The pending status of a command goes low when it is consumed.

When several interactions are possible from a set of pending commands, the interaction with the highest priority, i.e., the interaction closest to the top of [Table 22.2 I2C Interactions in Prioritized Order on page 712](#) is applied to the bus.

Pending commands can be cleared by setting the CLEARPC command bit in I2C\_CMD.

#### 22.3.8.3 Automatic ACK Interaction

When receiving addresses and data, an ACK command in I2C\_CMD is normally required after each received byte. When AUTOACK is set in I2C\_CTRL, an ACK is always pending, and the ACK-pending bit PACK in I2C\_STATUS is thus always set, even after an ACK has been consumed. This is used when data is picked using I2C\_RXDOUBLE and can also be used with I2C\_RXDATA in order to reduce the amount of software interaction required during a transfer.

#### 22.3.8.4 Reset State

After a reset, the state of the I<sup>2</sup>C-bus is unknown. To avoid interrupting transfers on the I<sup>2</sup>C-bus after a reset of the I<sup>2</sup>C module or the entire MCU, the I<sup>2</sup>C-bus is assumed to be busy when coming out of a reset, and the BUSY flag in I2C\_STATUS is thus set. To be able to carry through leader operations on the I<sup>2</sup>C-bus, the bus must be idle.

The bus goes idle when a STOP condition is detected on the bus, but on buses with little activity, the time before the I<sup>2</sup>C module detects that the bus is idle can be significant. There are two ways of assuring that the I<sup>2</sup>C module gets out of the busy state.

- Use the ABORT command in I2C\_CMD. When the ABORT command is issued, the I<sup>2</sup>C module is instructed that the bus is idle. The I<sup>2</sup>C module can then initiate leader operations.
- Use the Bus Idle Timeout. When SCL has been high for a long period of time, it is very likely that the bus is idle. Set BITO in I2C\_CTRL to an appropriate timeout period and set GIBITO in I2C\_CTRL. If activity has not been detected on the bus within the timeout period, the bus is then automatically assumed idle, and leader operations can be initiated.

**Note:** If operating in follower mode, the above approach is not necessary.

### 22.3.8.5 Leader Transmitter

To transmit data to a follower, the leader must operate as a leader transmitter. [Table 22.3 I2C Leader Transmitter on page 714](#) shows the states the I<sup>2</sup>C module goes through while acting as a leader transmitter. Every state where an interaction is required has the possible interactions listed, along with the result of the interactions. The table also shows which interrupt flags are set in the different states. The interrupt flags enclosed in parenthesis may be set. If the BUSHOLD interrupt in I2C\_IF is set, the module is waiting for an interaction, and the bus is frozen. The value of I2C\_STATE will be equal to the values given in the table when the BUSHOLD interrupt flag is set, and can be used to determine which interaction is required to make the transmission continue.

The interrupt flag START in I2C\_IF is set when the I<sup>2</sup>C module transmits the START.

A leader operation is started by issuing a START command by setting START in I2C\_CMD. ADDR+W, i.e., the address of the follower + the R/W bit is then required by the I<sup>2</sup>C module. If this is not available in the transmit buffer, then the bus is held and the BUSHOLD interrupt flag is set. The value of I2C\_STATE will then be 0x67. As seen in the table, the I<sup>2</sup>C module also stops in this state if the address is not available after a repeated start condition.

To continue, write a byte to I2C\_TXDATA with the address of the follower in the 7 most significant bits and the least significant bit cleared (ADDR+W). This address will then be transmitted, and the follower will reply with an ACK or a NACK. If no follower replies to the address, the response will also be NACK. If the address was acknowledged, the leader now has four choices. It can send data by placing it in I2C\_TXDATA/ I2C\_TXDOUBLE (the leader should check the TXBL interrupt flag before writing to the transmit buffer), this data is then transmitted. The leader can also stop the transmission by sending a STOP, it can send a repeated start by sending START, or it can send a STOP and then a START as soon as possible. If the leader wishes to make another transfer immediately after the current, the preferred way is to start a new transfer directly by transmitting a repeated START instead of a STOP followed by a START. This is so because if a STOP is sent out, then any leader wishing to initiate a transfer on the bus can try to gain control of it.

If a NACK was received, the leader has to issue a CONT command in addition to providing data in order to continue transmission. This is not standard I<sup>2</sup>C, but is provided for flexibility. The rest of the options are similar to when an ACK was received.

If a new byte was transmitted, an ACK or NACK is received after the transmission of the byte, and the leader has the same options as for when the address was sent.

The leader may lose arbitration at any time during transmission. In this case, the ARBLOST interrupt flag in I2C\_IF is set. If the arbitration was lost during the transfer of an address, and SLAVE in I2C\_CTRL is set, the leader then checks which address was transmitted. If it was the address of the leader, then the leader goes to follower mode.

After a leader has transmitted a START and won any arbitration, it owns the bus until it transmits a STOP. After a STOP, the bus is released, and arbitration decides which bus leader gains the bus next. The MSTOP interrupt flag in I2C\_IF is set when a STOP condition is transmitted by the leader.

**Table 22.3. I2C Leader Transmitter**

| I2C_STATE | Description                | I2C_IF                                        | Required interaction | Response                                                                             |
|-----------|----------------------------|-----------------------------------------------|----------------------|--------------------------------------------------------------------------------------|
| 0x67      | Start transmitted          | START interrupt flag (BUSHOLD interrupt flag) | ADDR+W -> TXDATA     | ADDR+W will be sent                                                                  |
|           |                            |                                               | STOP                 | STOP will be sent and bus released.                                                  |
|           |                            |                                               | STOP + START         | STOP will be sent and bus released. Then a START will be sent when bus becomes idle. |
| 0x67      | Repeated start transmitted | START interrupt flag (BUSHOLD interrupt flag) | ADDR+W -> TXDATA     | ADDR+W will be sent                                                                  |
|           |                            |                                               | STOP                 | STOP will be sent and bus released.                                                  |
|           |                            |                                               | STOP + START         | STOP will be sent and bus released. Then a START will be sent when bus becomes idle. |
| -         | ADDR+W transmitted         | TXBL interrupt flag (TXC interrupt flag)      | None                 |                                                                                      |

| I2C_STATE | Description                       | I2C_IF                                      | Required interaction | Response                                                                                    |
|-----------|-----------------------------------|---------------------------------------------|----------------------|---------------------------------------------------------------------------------------------|
| 0x97      | ADDR+W transmitted, ACK received  | ACK interrupt flag (BUSHOLD interrupt flag) | TXDATA               | DATA will be sent                                                                           |
|           |                                   |                                             | STOP                 | STOP will be sent. Bus will be released                                                     |
|           |                                   |                                             | START                | Repeated start condition will be sent                                                       |
|           |                                   |                                             | STOP + START         | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle |
| 0x9F      | ADDR+W transmitted, NACK received | NACK (BUSHOLD interrupt flag)               | CONT + TXDATA        | DATA will be sent                                                                           |
|           |                                   |                                             | STOP                 | STOP will be sent. Bus will be released                                                     |
|           |                                   |                                             | START                | Repeated start condition will be sent                                                       |
|           |                                   |                                             | STOP + START         | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle |
| -         | Data transmitted                  | TXBL interrupt flag (TXC interrupt flag)    | None                 |                                                                                             |
| 0xD7      | Data transmitted, ACK received    | ACK interrupt flag (BUSHOLD interrupt flag) | TXDATA               | DATA will be sent                                                                           |
|           |                                   |                                             | STOP                 | STOP will be sent. Bus will be released                                                     |
|           |                                   |                                             | START                | Repeated start condition will be sent                                                       |
|           |                                   |                                             | STOP + START         | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle |
| 0xDF      | Data transmitted, NACK received   | NACK(BUSHOLD interrupt flag)                | CONT + TXDATA        | DATA will be sent                                                                           |
|           |                                   |                                             | STOP                 | STOP will be sent. Bus will be released                                                     |
|           |                                   |                                             | START                | Repeated start condition will be sent                                                       |
|           |                                   |                                             | STOP + START         | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle |
| -         | Stop transmitted                  | MSTOP interrupt flag                        | None                 |                                                                                             |
| -         | Arbitration lost                  | ARBLOST interrupt flag                      | START                | START will be sent when bus becomes idle                                                    |

### 22.3.8.6 Leader Receiver

To receive data from a follower, the leader must operate as a leader receiver, see [Table 22.4 I2C Leader Receiver on page 716](#). This is done by transmitting ADDR+R as the address byte instead of ADDR+W, which is transmitted to become a leader transmitter. The address byte loaded into the data register thus has to contain the 7-bit follower address in the 7 most significant bits of the byte, and have the least significant bit set.

When the address has been transmitted, the leader receives an ACK or a NACK. If an ACK is received, the ACK interrupt flag in I2C\_IF is set, and if space is available in the receive shift register, reception of a byte from the follower begins. If the receive buffer and shift register is full however, the bus is held until data is read from the receive buffer or another interaction is made. Note that the STOP and START interactions have a higher priority than the data-available interaction, so if a STOP or START command is pending, the highest priority interaction will be performed, and data will not be received from the follower.

If a NACK was received, the CONT command in I2C\_CMD has to be issued in order to continue receiving data, even if there is space available in the receive buffer and/or shift register.

After a data byte has been received the leader must ACK or NACK the received byte. If an ACK is pending or AUTOACK in I2C\_CTRL is set, an ACK is sent automatically and reception continues if space is available in the receive buffer.

If a NACK is sent, the CONT command must be used in order to continue transmission. If an ACK or NACK is issued along with a START or STOP or both, then the ACK/NACK is transmitted and the reception is ended. If START in I2C\_CMD is set alone, a repeated start condition is transmitted after the ACK/NACK. If STOP in I2C\_CMD is set, a stop condition is sent regardless of whether START is set. If START is set in this case, it is set as pending.

As when operating as a leader transmitter, arbitration can be lost as a leader receiver. When this happens the ARBLOST interrupt flag in I2C\_IF is set, and the leader has a possibility of being selected as a follower given the correct conditions.

**Table 22.4. I2C Leader Receiver**

| I2C_STATE | Description                      | I2C_IF                                        | Required interaction | Response                                                                                    |
|-----------|----------------------------------|-----------------------------------------------|----------------------|---------------------------------------------------------------------------------------------|
| 0x63      | START transmitted                | START interrupt flag (BUSHOLD interrupt flag) | ADDR+R -> TXDATA     | ADDR+R will be sent                                                                         |
|           |                                  |                                               | STOP                 | STOP will be sent and bus released.                                                         |
|           |                                  |                                               | STOP + START         | STOP will be sent and bus released. Then a START will be sent when bus becomes idle.        |
| 0x67      | Repeated START transmitted       | START interrupt flag(BUSHOLD interrupt flag)  | ADDR+R -> TXDATA     | ADDR+R will be sent                                                                         |
|           |                                  |                                               | STOP                 | STOP will be sent and bus released.                                                         |
|           |                                  |                                               | STOP + START         | STOP will be sent and bus released. Then a START will be sent when bus becomes idle.        |
| -         | ADDR+R transmitted               | TXBL interrupt flag (TXC interrupt flag)      | None                 |                                                                                             |
| 0xA3      | ADDR+R transmitted, ACK received | ACK interrupt flag(BUS-HOLD)                  | RXDATA               | Start receiving                                                                             |
|           |                                  |                                               | STOP                 | STOP will be sent and the bus released                                                      |
|           |                                  |                                               | START                | Repeated START will be sent                                                                 |
|           |                                  |                                               | STOP + START         | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle |
| 0x9B      | ADDR+R transmitted,NACK received | NACK(BUSHOLD)                                 | CONT + RXDATA        | Continue, start receiving                                                                   |
|           |                                  |                                               | STOP                 | STOP will be sent and the bus released                                                      |
|           |                                  |                                               | START                | Repeated START will be sent                                                                 |
|           |                                  |                                               | STOP + START         | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle |

| I2C_STATE | Description      | I2C_IF                                        | Required interaction    | Response                                                                                                |
|-----------|------------------|-----------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------|
| 0xB3      | Data received    | RXDATA interrupt flag(BUSHOLD interrupt flag) | ACK + RXDATA            | ACK will be transmitted, reception continues                                                            |
|           |                  |                                               | NACK + CONT + RXDATA    | NACK will be transmitted, reception continues                                                           |
|           |                  |                                               | ACK/NACK + STOP         | ACK/NACK will be sent and the bus will be released.                                                     |
|           |                  |                                               | ACK/NACK + START        | ACK/NACK will be sent, and then a repeated start condition.                                             |
|           |                  |                                               | ACK/NACK + STOP + START | ACK/NACK will be sent and the bus will be released. Then a START will be sent when the bus becomes idle |
| -         | Stop received    | MSTOP interrupt flag                          | None                    |                                                                                                         |
| -         | Arbitration lost |                                               | START                   | START will be sent when bus becomes idle                                                                |
| -         | Arbitration lost | ARBLOST interrupt flag                        | None                    |                                                                                                         |
| -         | Arbitration lost |                                               | START                   | START will be sent when bus becomes idle                                                                |

#### 22.3.8.7 SDA/SCL Status Monitor

The I<sup>2</sup>C module supports an SDA and SCL monitoring function. Note that this functionality is only supported when the I<sup>2</sup>C module is in single leader mode, and when the follower doesn't use clock stretching. Additionally, firmware should set the ARBDIS bit in I<sup>2</sup>C\_CTRL when using the SDA/SCL monitoring to prevent the bus being released.

The SDA monitor is enabled by setting the SDAMONEN in I<sup>2</sup>C\_CTRL. Once enabled, the SDA monitor will check the status of the SDA line at the following points:

- At a Start Condition, before SDA falls
- At Stop Condition, after SDA rises

After checking, the monitor will set the SDAERR flag in I<sup>2</sup>C\_IF if it fails to read SDA==1. To allow the SDAERR flag to generate an IRQ, set the SDAERR bit in I<sup>2</sup>C\_IEN.

Similarly, the SCL monitor is enabled by setting the SCLMONEN in I<sup>2</sup>C\_CTRL. Once enabled, the SCL monitor will check the status of the SCL line at the following points:

- At a Start Condition, before SCL falls
- At every clock cycle, before SCL falls
- At Stop Condition, after SCL rises

After checking, the monitor will set the SCLERR flag in I<sup>2</sup>C\_IF if it fails to read SCL==1. To allow the SCLERR flag to generate an IRQ, set the SCLERR bit in I<sup>2</sup>C\_IEN.

### 22.3.9 Bus States

The I2C\_STATE register can be used to determine which state the I<sup>2</sup>C module and the I<sup>2</sup>C bus are in at a given time. The register consists of the STATE bit-field, which shows which state the I<sup>2</sup>C module is at in any ongoing transmission, and a set of single-bits, which reveal the transmission mode, whether the bus is busy or idle, and whether the bus is held by this I<sup>2</sup>C module waiting for a software response.

The possible values of the STATE field are summarized in [Table 22.5 I2C STATE Values on page 718](#). When this field is cleared, the I<sup>2</sup>C module is not a part of any ongoing transmission. The remaining status bits in the I2C\_STATE register are listed in [Table 22.6 I2C Transmission Status on page 718](#).

**Table 22.5. I2C STATE Values**

| Mode    | Value | Description                                                               |
|---------|-------|---------------------------------------------------------------------------|
| IDLE    | 0     | No transmission is being performed by this module.                        |
| WAIT    | 1     | Waiting for idle. Will send a start condition as soon as the bus is idle. |
| START   | 2     | Start transmit phase                                                      |
| ADDR    | 3     | Address transmit or receive phase                                         |
| ADDRACK | 4     | Address ACK/NACK transmit or receive phase                                |
| DATA    | 5     | Data transmit or receive phase                                            |
| DATAACK | 6     | Data ACK/NACK transmit or receive phase                                   |

**Table 22.6. I2C Transmission Status**

| Bit         | Description                                                                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| BUSY        | Set whenever there is activity on the bus. Whether or not this module is responsible for the activity cannot be determined by this byte.            |
| MASTER      | Set when operating as a leader. Cleared at all other times.                                                                                         |
| TRANSMITTER | Set when operating as a transmitter; either a leader transmitter or a follower transmitter. Cleared at all other times                              |
| BUSHOLD     | Set when the bus is held by this I <sup>2</sup> C module because an action is required by software.                                                 |
| NACK        | Only valid when bus is held and STATE is ADDRACK or DATAACK. In that case it is set if a NACK was received. In all other cases, the bit is cleared. |

**Note:** I2C\_STATE reflects the internal state of the I<sup>2</sup>C module, and therefore only held constant as long as the bus is held, i.e., as long as BUSHOLD in I2C\_STATUS is set.

### 22.3.10 Follower Operation

The I<sup>2</sup>C module operates in leader mode by default. To enable follower operation, i.e., to allow the device to be addressed as an I<sup>2</sup>C follower, the SLAVE bit in I2C\_CTRL must be set. In this case the I<sup>2</sup>C module operates in a mixed mode, both capable of starting transmissions as a leader, and being addressed as a follower. When operating in the follower mode, I2CCLK frequency must be higher than 2 MHz for Standard-mode, 5 MHz for Fast-mode, and 14 MHz for Fast-mode Plus.

### 22.3.10.1 Follower State Machine

The follower state machine is shown in [Figure 22.17 I2C Follower State Machine on page 719](#). The dotted lines show where I<sup>2</sup>C-specific interrupt flags are set. The full-drawn circles show places where interaction may be required by software to let the transmission proceed.



**Figure 22.17. I2C Follower State Machine**

### 22.3.10.2 Address Recognition

The I<sup>2</sup>C module provides automatic address recognition for 7-bit addresses. 10-bit address recognition is not fully automatic, but can be assisted by the 7-bit address comparator as shown in [22.3.12 Using 10-bit Addresses](#). Address recognition is supported in EM2/3 for I<sup>2</sup>C0 - however, the I<sup>2</sup>C0 module must be configured to use pins on either Port A or B if wakeup on address recognition from EM2/3 is desired. All other ports are available only in EM0/1. See GPIO chapter for more details.

The follower address, i.e., the address which the I<sup>2</sup>C module should be addressed with, is defined in the I2C\_SADDR register. In addition to the address, a mask must be specified, telling the address comparator which bits of an incoming address to compare with the address defined in I2C\_SADDR. The mask is defined in I2C\_SADDRMASK, and for every zero in the mask, the corresponding bit in the follower address is treated as a don't-care, i.e., the 0-masked bits are ignored.

An incoming address that fails address recognition is automatically replied to with a NACK. Since only the bits defined by the mask are checked, a mask with a value 0x00 will result in all addresses being accepted. A mask with a value 0x7F will only match the exact address defined in I2C\_SADDR, while a mask 0x70 will match all addresses where the three most significant bits in I2C\_SADDR and the incoming address are equal.

If GCAMEN in I2C\_CTRL is not set, the start-byte, i.e., the general call address with the R/W bit set is ignored unless it is included in the defined follower address and the address mask.

When an address is accepted by the address comparator, the decision of whether to ACK or NACK the address is passed to software.

### 22.3.10.3 Follower Transmitter

When SLAVE in I2C\_CTRL is set, the RSTART interrupt flag in I2C\_IF will be set when repeated START conditions are detected. After a START or repeated START condition, the bus leader will transmit an address along with an R/W bit. If there is no room in the receive shift register for the address, the bus will be held by the follower until room is available in the shift register. Transmission then continues and the address is loaded into the shift register. If this address does not pass address recognition, it is automatically NACK'ed by the follower, and the follower goes to an idle state. The address byte is in this case discarded, making the shift register ready for a new address. It is not loaded into the receive buffer.

If the address was accepted and the R/W bit was set (R), indicating that the leader wishes to read from the follower, the follower now goes into the follower transmitter mode. Software interaction is now required to decide whether the follower wants to acknowledge the request or not. The accepted address byte is loaded into the receive buffer like a regular data byte. If no valid interaction is pending, the bus is held until the follower responds with a command. The follower can reject the request with a single NACK command.

The follower will in that case go to an idle state, and wait for the next start condition. To continue the transmission, the follower must make sure data is loaded into the transmit buffer and send an ACK. The loaded data will then be transmitted to the leader, and an ACK or NACK will be received from the leader.

Data transmission can also continue after a NACK if a CONT command is issued along with the NACK. This is not standard I<sup>2</sup>C however.

If the leader responds with an ACK, it may expect another byte of data, and data should be made available in the transmit buffer. If data is not available, the bus is held until data is available.

If the response is a NACK however, this is an indication of that the leader has received enough bytes and wishes to end the transmission. The follower now automatically goes idle, unless CONT in I2C\_CMD is set and data is available for transmission. The latter is not standard I<sup>2</sup>C.

The leader ends the transmission by sending a STOP or a repeated START. The SSTOP interrupt flag in I2C\_IF is set when the leader transmits a STOP condition. If the transmission is ended with a repeated START, then the SSTOP interrupt flag is not set.

**Note:** The SSTOP interrupt flag in I2C\_IF will be set regardless of whether the follower is participating in the transmission or not, as long as SLAVE in I2C\_CTRL is set and a STOP condition is detected

If arbitration is lost at any time during transmission, the ARBLOST interrupt flag in I2C\_IF is set, the bus is released and the follower goes idle.

See [Table 22.7 I2C Follower Transmitter](#) on page 720 for more information.

**Table 22.7. I2C Follower Transmitter**

| I2C_STATE | Description                     | I2C_IF                                         | Required interaction | Response                              |
|-----------|---------------------------------|------------------------------------------------|----------------------|---------------------------------------|
| 0x01      | Repeated START received         | RSTART interrupt flag (BUSHOLD interrupt flag) | RXDATA               | Receive and compare address           |
| 0x75      | ADDR + R received               | ADDR interrupt flag                            | ACK + TXDATA         | ACK will be sent, then DATA           |
|           |                                 | RXDATA interrupt flag                          | NACK                 | NACK will be sent, follower goes idle |
|           |                                 | (BUSHOLD interrupt flag)                       | NACK + CONT + TXDATA | NACK will be sent, then DATA.         |
| -         | Data transmitted                | TXBL interrupt flag (TXC interrupt flag)       | None                 |                                       |
| 0xD5      | Data transmitted, ACK received  | ACK interrupt flag (BUSHOLD interrupt flag)    | TXDATA               | DATA will be transmitted              |
| 0xDD      | Data transmitted, NACK received | NACK interrupt flag                            | None                 | The follower goes idle                |
|           |                                 | (BUSHOLD interrupt flag)                       | CONT + TXDATA        | DATA will be transmitted              |

| I2C_STATE | Description      | I2C_IF                 | Required interaction | Response                                     |
|-----------|------------------|------------------------|----------------------|----------------------------------------------|
| -         | Stop received    | SSTOP interrupt flag   | None                 | The follower goes idle                       |
|           |                  |                        | START                | START will be sent when bus becomes idle     |
| -         | Arbitration lost | ARBLOST interrupt flag | None                 | The follower goes idle                       |
|           |                  |                        | START                | START will be sent when the bus becomes idle |

#### 22.3.10.4 Follower Receiver

A follower receiver operation is started in the same way as a follower transmitter operation, with the exception that the address transmitted by the leader has the R/W bit cleared (W), indicating that the leader wishes to write to the follower. The follower then goes into follower receiver mode.

To receive data from the leader, the follower should respond to the address with an ACK and make sure space is available in the receive buffer. Transmission will then continue, and the follower will receive a byte from the leader.

If a NACK is sent without a CONT, the transmission is ended for the follower, and it goes idle. If the follower issues both the NACK and CONT commands and has space available in the receive buffer, it will be open for continuing reception from the leader.

When a byte has been received from the leader, the follower must ACK or NACK the byte. The responses here are the same as for the reception of the address byte.

The leader ends the transmission by sending a STOP or a repeated START. The SSTOP interrupt flag is set when the leader transmits a STOP condition. If the transmission is ended with a repeated START, then the SSTOP interrupt flag in I2C\_IF is not set.

**Note:** The SSTOP interrupt flag in I2C\_IF will be set regardless of whether the follower is participating in the transmission or not, as long as SLAVE in I2C\_CTRL is set and a STOP condition is detected

If arbitration is lost at any time during transmission, the ARBLOST interrupt flag in I2C\_IF is set, the bus is released and the follower goes idle.

See [Table 22.8 I2C - Follower Receiver](#) on page 722 for more information.

**Table 22.8. I2C - Follower Receiver**

| I2C_STATE | Description             | I2C_IF                                                                | Required interaction | Response                                     |
|-----------|-------------------------|-----------------------------------------------------------------------|----------------------|----------------------------------------------|
| 0x01      | Repeated START received | RSTART interrupt flag (BUSHOLD interrupt flag)                        | RXDATA               | Receive and compare address                  |
| 0x71      | ADDR + W received       | ADDR interrupt flag<br>RXDATA interrupt flag (BUSHOLD interrupt flag) | ACK + RXDATA         | ACK will be sent and data will be received   |
|           |                         |                                                                       | NACK                 | NACK will be sent, follower goes idle        |
|           |                         |                                                                       | NACK + CONT + RXDATA | NACK will be sent and DATA will be received. |
| 0xB1      | Data received           | RXDATA interrupt flag (BUSHOLD interrupt flag)                        | ACK + RXDATA         | ACK will be sent and data will be received   |
|           |                         |                                                                       | NACK                 | NACK will be sent and follower will go idle  |
|           |                         |                                                                       | NACK + CONT + RXDATA | NACK will be sent and data will be received  |
| -         | Stop received           | SSTOP interrupt flag                                                  | None                 | The follower goes idle                       |
|           |                         |                                                                       | START                | START will be sent when bus becomes idle     |
| -         | Arbitration lost        | ARBLOST interrupt flag                                                | None                 | The follower goes idle                       |
|           |                         |                                                                       | START                | START will be sent when the bus becomes idle |

#### 22.3.11 Transfer Automation

The I<sup>2</sup>C can be set up to complete transfers with a minimal amount of interaction.

### 22.3.11.1 DMA

DMA can be used to automatically load data into the transmit buffer and load data out from the receive buffer. When using DMA, software is thus relieved of moving data to and from memory after each transferred byte.

### 22.3.11.2 Automatic ACK

When AUTOACK in I2C\_CTRL is set, an ACK is sent automatically whenever an ACK interaction is possible and no higher priority interactions are pending.

### 22.3.11.3 Automatic STOP

A STOP can be generated automatically on two conditions. These apply only to the leader transmitter.

If AUTOSN in I2C\_CTRL is set, the I<sup>2</sup>C module ends a transmission by transmitting a STOP condition when operating as a leader transmitter and a NACK is received.

If AUTOSE in I2C\_CTRL is set, the I<sup>2</sup>C module always ends a transmission when there is no more data in the transmit buffer. If data has been transmitted on the bus, the transmission is ended after the (N)ACK has been received by the follower. If a START is sent when no data is available in the transmit buffer and AUTOSE is set, then the STOP condition is sent immediately following the START. Software must thus make sure data is available in the transmit buffer before the START condition has been fully transmitted if data is to be transferred.

## 22.3.12 Using 10-bit Addresses

When using 10-bit addresses in follower mode, set the I2C\_SADDR register to 1111 0XX where XX are the two most significant bits of the 10-bit address, and set I2C\_SADDRMASK to 0xFF. Address matches will now be given on all 10-bit addresses where the two most significant bits are correct.

When receiving an address match, the follower must acknowledge the address and receive the first data byte. This byte contains the second part of the 10-bit address. If it matches the address of the follower, the follower should ACK the byte to continue the transmission, and if it does not match, the follower should NACK it.

When the leader is operating as a leader transmitter, the data bytes will follow after the second address byte. When the leader is operating as a leader receiver however, a repeated START condition is sent after the second address byte. The address sent after this repeated START is equal to the first of the address bytes transmitted previously, but now with the R/W byte set, and only the follower that found a match on the entire 10-bit address in the previous message should ACK this address. The repeated start should take the leader into a leader receiver mode, and after the single address byte sent this time around, the follower begins transmission to the leader.

## 22.3.13 Error Handling

**Note:** Some registers in the I<sup>2</sup>C module are considered static. This means that these need to be set before an I<sup>2</sup>C transaction starts and need to stay stable during the entire transaction.

Specifically:

- The GCAMEN and SLAVE fields in the I2C\_CTRL register
- The I2C\_SADDR register
- The GPIO\_I2Cn\_ROUTEEN, GPIO\_I2Cn\_SCLROUTE, and GPIO\_I2Cn\_SDAROUTE registers

### 22.3.13.1 ABORT Command

Some bus errors may require software intervention to be resolved. The I<sup>2</sup>C module provides an ABORT command, which can be set in I2C\_CMD, to help resolve bus errors.

When the bus for some reason is locked up and the I<sup>2</sup>C module is in the middle of a transmission it cannot get out of, or for some other reason the I<sup>2</sup>C wants to abort a transmission, the ABORT command can be used.

Setting the ABORT command will make the I<sup>2</sup>C module discard any data currently being transmitted or received, release the SDA and SCL lines and go to an idle mode. ABORT effectively makes the I<sup>2</sup>C module forget about any ongoing transfers.

### 22.3.13.2 Bus Reset

A bus reset can be performed by setting the START and STOP commands in I2C\_CMD while the transmit buffer is empty. A START condition will then be transmitted, immediately followed by a STOP condition. A bus reset can also be performed by transmitting a START command with the transmit buffer empty and AUTOSE set.

### 22.3.13.3 I2C-Bus Errors

An I<sup>2</sup>C-bus error occurs when a START or STOP condition is misplaced, which happens when the value on SDA changes while SCL is high during bit-transmission on the I<sup>2</sup>C-bus. If the I<sup>2</sup>C module is part of the current transmission when a bus error occurs, any data currently being transmitted or received is discarded, SDA and SCL are released, the BUSERR interrupt flag in I2C\_IF is set to indicate the error, and the module automatically takes a course of action as defined in [Table 22.9 I2C Bus Error Response on page 724](#).

**Table 22.9. I2C Bus Error Response**

|                                | Misplaced START                    | Misplaced STOP                        |
|--------------------------------|------------------------------------|---------------------------------------|
| In a leader/follower operation | Treated as START. Receive address. | Go idle. Perform any pending actions. |

### 22.3.13.4 Bus Lockup

A lockup occurs when a leader or follower on the I<sup>2</sup>C-bus has locked the SDA or SCL at a low value, preventing other devices from putting high values on the bus, and thus making communication on the bus impossible.

Many follower-only devices operating on an I<sup>2</sup>C-bus are not capable of driving SCL low, but in the rare case that SCL is stuck LOW, the advice is to apply a hardware reset signal to the followers on the bus. If this does not work, cycle the power to the devices in order to make them release SCL.

When SDA is stuck low and SCL is free, a leader should send 9 clock pulses on SCL while tristating the SDA. This procedure is performed in the GPIO module after clearing the GPIO\_I2Cn\_ROUTEEEN register and disabling the I<sup>2</sup>C module. The device that held the bus low should release it sometime within those 9 clocks. If not, use the same approach as for when SCL is stuck, resetting and possibly cycling power to the followers.

Lockup of SDA can be detected by keeping count of the number of continuous arbitration losses during address transmission. If arbitration is also lost during the transmission of a general call address, i.e., during the transmission of the STOP condition, which should never happen during normal operation, this is a good indication of SDA lockup.

Detection of SCL lockups can be done using the timeout functionality defined in [22.3.13.6 Clock Low Timeout](#)

### 22.3.13.5 Bus Idle Timeout

When SCL has been high for a significant amount of time, this is a good indication of that the bus is idle. On an SMBus system, the bus is only allowed to be in this state for a maximum of 50 µs before the bus is considered idle.

The bus idle timeout BITO in I2C\_CTRL can be used to detect situations where the bus goes idle in the middle of a transmission. The timeout can be configured in BITO, and when the bus has been idle for the given amount of time, the BITO interrupt flag in I2C\_IF is set. The bus can also be set idle automatically on a bus idle timeout. This is enabled by setting GIBITO in I2C\_CTRL.

When the bus idle timer times out, it wraps around and continues counting as long as its condition is true. If the bus is not set idle using GIBITO or the ABORT command in I2C\_CMD, this will result in periodic timeouts.

**Note:** This timeout will be generated even if SDA is held low.

The bus idle timeout is active as long as the bus is busy, i.e., BUSY in I2C\_STATUS is set. The timeout can be used to get the I<sup>2</sup>C module out of the busy-state it enters when reset, see [22.3.8.4 Reset State](#).

### 22.3.13.6 Clock Low Timeout

The clock timeout, which can be configured in CLTO in I2C\_CTRL, starts counting whenever SCL goes low, and times out if SCL does not go high within the configured timeout. A clock low timeout results in CLTOIF in I2C\_IF being set, allowing software to take action.

When the timer times out, it wraps around and continues counting as long as SCL is low. An SCL lockup will thus result in periodic clock low timeouts as long as SCL is low.

### 22.3.13.7 Clock Low Error

The I<sup>2</sup>C module can continue transmission in parallel with another device for the entire transaction, as long as the two communications are identical. A case may arise when (before an arbitration has been decided upon) the I<sup>2</sup>C module decides to send out a repeated START or a STOP condition while the other device is still sending data. In the I<sup>2</sup>C protocol specifications, such a combination results in an undefined condition. The I<sup>2</sup>C deals with this by generating a clock low error. This means that if the I<sup>2</sup>C is transmitting a repeated START or a STOP condition and another device (another leader or a misbehaving follower) pulls SCL low before the I<sup>2</sup>C sends out the START/STOP condition on SDA, a clock low error is generated. The CLERR interrupt flag is then set in the I2C\_IF register, any held lines are released and the I<sup>2</sup>C device goes to idle.

### 22.3.14 DMA Support

The I<sup>2</sup>C module has full DMA support. A request for the DMA controller to write to the I<sup>2</sup>C transmit buffer can come from TXBL (transmit buffer has room for more data). The DMA controller can write to the transmit buffer using the I2C\_TXDATA or the I2C\_RXDOUBLE register. DMA must be configured to transfer one byte of data when writing to the I2C\_TXDATA and configured for transferring two bytes of data when writing to the I2C\_RXDOUBLE.

A request for the DMA controller to read from the I<sup>2</sup>C receive buffer can come from RXDATAV (data available in the receive buffer). DMA must be configured to transfer one byte of data when reading from I2C\_RXDATA and configured for transferring two bytes of data when reading from I2C\_RXDOUBLE.

### 22.3.15 Interrupts

The interrupts generated by the I<sup>2</sup>C module are combined into one interrupt vector, I2C\_INT. If I<sup>2</sup>C interrupts are enabled, an interrupt will be made if one or more of the interrupt flags in I2C\_IF and their corresponding bits in I2C\_IEN are set.

### 22.3.16 Wake-up

The I<sup>2</sup>C receive section can be active all the way down to energy mode EM3 stop, and can wake up the CPU on address interrupt. All address match modes are supported.

## 22.4 I2C Register Map

The offset register address is relative to the registers base address.

| Offset | Name              | Type        | Description                              |
|--------|-------------------|-------------|------------------------------------------|
| 0x000  | I2C_IPVERSION     | R           | IP VERSION Register                      |
| 0x004  | I2C_EN            | RW          | Enable Register                          |
| 0x008  | I2C_CTRL          | RW          | Control Register                         |
| 0x00C  | I2C_CMD           | W           | Command Register                         |
| 0x010  | I2C_STATE         | RH          | State Register                           |
| 0x014  | I2C_STATUS        | RH          | Status Register                          |
| 0x018  | I2C_CLKDIV        | RW          | Clock Division Register                  |
| 0x01C  | I2C_SADDR         | RW          | Follower Address Register                |
| 0x020  | I2C_SADDRMASK     | RW          | Follower Address Mask Register           |
| 0x024  | I2C_RXDATA        | RH          | Receive Buffer Data Register             |
| 0x028  | I2C_RXDOUBLE      | RH          | Receive Buffer Double Data Register      |
| 0x02C  | I2C_RXDATAP       | RH          | Receive Buffer Data Peek Register        |
| 0x030  | I2C_RXDOUBLEP     | RH          | Receive Buffer Double Data Peek Register |
| 0x034  | I2C_TXDATA        | W           | Transmit Buffer Data Register            |
| 0x038  | I2C_TXDOUBLE      | W           | Transmit Buffer Double Data Register     |
| 0x03C  | I2C_IF            | RWH INTFLAG | Interrupt Flag Register                  |
| 0x040  | I2C_IEN           | RW          | Interrupt Enable Register                |
| 0x1000 | I2C_IPVERSION_SET | R           | IP VERSION Register                      |
| 0x1004 | I2C_EN_SET        | RW          | Enable Register                          |
| 0x1008 | I2C_CTRL_SET      | RW          | Control Register                         |
| 0x100C | I2C_CMD_SET       | W           | Command Register                         |
| 0x1010 | I2C_STATE_SET     | RH          | State Register                           |
| 0x1014 | I2C_STATUS_SET    | RH          | Status Register                          |
| 0x1018 | I2C_CLKDIV_SET    | RW          | Clock Division Register                  |
| 0x101C | I2C_SADDR_SET     | RW          | Follower Address Register                |
| 0x1020 | I2C_SADDRMASK_SET | RW          | Follower Address Mask Register           |
| 0x1024 | I2C_RXDATA_SET    | RH          | Receive Buffer Data Register             |
| 0x1028 | I2C_RXDOUBLE_SET  | RH          | Receive Buffer Double Data Register      |
| 0x102C | I2C_RXDATAP_SET   | RH          | Receive Buffer Data Peek Register        |
| 0x1030 | I2C_RXDOUBLEP_SET | RH          | Receive Buffer Double Data Peek Register |
| 0x1034 | I2C_TXDATA_SET    | W           | Transmit Buffer Data Register            |
| 0x1038 | I2C_TXDOUBLE_SET  | W           | Transmit Buffer Double Data Register     |
| 0x103C | I2C_IF_SET        | RWH INTFLAG | Interrupt Flag Register                  |
| 0x1040 | I2C_IEN_SET       | RW          | Interrupt Enable Register                |
| 0x2000 | I2C_IPVERSION_CLR | R           | IP VERSION Register                      |

| Offset | Name              | Type        | Description                              |
|--------|-------------------|-------------|------------------------------------------|
| 0x2004 | I2C_EN_CLR        | RW          | Enable Register                          |
| 0x2008 | I2C_CTRL_CLR      | RW          | Control Register                         |
| 0x200C | I2C_CMD_CLR       | W           | Command Register                         |
| 0x2010 | I2C_STATE_CLR     | RH          | State Register                           |
| 0x2014 | I2C_STATUS_CLR    | RH          | Status Register                          |
| 0x2018 | I2C_CLKDIV_CLR    | RW          | Clock Division Register                  |
| 0x201C | I2C_SADDR_CLR     | RW          | Follower Address Register                |
| 0x2020 | I2C_SADDRMASK_CLR | RW          | Follower Address Mask Register           |
| 0x2024 | I2C_RXDATA_CLR    | RH          | Receive Buffer Data Register             |
| 0x2028 | I2C_RXDOUBLE_CLR  | RH          | Receive Buffer Double Data Register      |
| 0x202C | I2C_RXDATAP_CLR   | RH          | Receive Buffer Data Peek Register        |
| 0x2030 | I2C_RXDOUBLEP_CLR | RH          | Receive Buffer Double Data Peek Register |
| 0x2034 | I2C_TXDATA_CLR    | W           | Transmit Buffer Data Register            |
| 0x2038 | I2C_TXDOUBLE_CLR  | W           | Transmit Buffer Double Data Register     |
| 0x203C | I2C_IF_CLR        | RWH INTFLAG | Interrupt Flag Register                  |
| 0x2040 | I2C_IEN_CLR       | RW          | Interrupt Enable Register                |
| 0x3000 | I2C_IPVERSION_TGL | R           | IP VERSION Register                      |
| 0x3004 | I2C_EN_TGL        | RW          | Enable Register                          |
| 0x3008 | I2C_CTRL_TGL      | RW          | Control Register                         |
| 0x300C | I2C_CMD_TGL       | W           | Command Register                         |
| 0x3010 | I2C_STATE_TGL     | RH          | State Register                           |
| 0x3014 | I2C_STATUS_TGL    | RH          | Status Register                          |
| 0x3018 | I2C_CLKDIV_TGL    | RW          | Clock Division Register                  |
| 0x301C | I2C_SADDR_TGL     | RW          | Follower Address Register                |
| 0x3020 | I2C_SADDRMASK_TGL | RW          | Follower Address Mask Register           |
| 0x3024 | I2C_RXDATA_TGL    | RH          | Receive Buffer Data Register             |
| 0x3028 | I2C_RXDOUBLE_TGL  | RH          | Receive Buffer Double Data Register      |
| 0x302C | I2C_RXDATAP_TGL   | RH          | Receive Buffer Data Peek Register        |
| 0x3030 | I2C_RXDOUBLEP_TGL | RH          | Receive Buffer Double Data Peek Register |
| 0x3034 | I2C_TXDATA_TGL    | W           | Transmit Buffer Data Register            |
| 0x3038 | I2C_TXDOUBLE_TGL  | W           | Transmit Buffer Double Data Register     |
| 0x303C | I2C_IF_TGL        | RWH INTFLAG | Interrupt Flag Register                  |
| 0x3040 | I2C_IEN_TGL       | RW          | Interrupt Enable Register                |

## 22.5 I2C Register Description

### 22.5.1 I2C\_IPVERSION - IP VERSION Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|----------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x0   | R      | <b>IP version ID</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                      |

### 22.5.2 I2C\_EN - Enable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x004  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | EN           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                              | Name     | Reset                                                                                                                                                                      | Access | Description          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------|
| 31:1                                                                                                                                                                                             | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                      |
| 0                                                                                                                                                                                                | EN       | 0x0                                                                                                                                                                        | RW     | <b>module enable</b> |
| The ENABLE bit enables the module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit. |          |                                                                                                                                                                            |        |                      |
| Value                                                                                                                                                                                            | Mode     | Description                                                                                                                                                                |        |                      |
| 0                                                                                                                                                                                                | DISABLE  | Disable Peripheral Clock                                                                                                                                                   |        |                      |
| 1                                                                                                                                                                                                | ENABLE   | Enable Peripheral Clock                                                                                                                                                    |        |                      |

## 22.5.3 I2C\_CTRL - Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x008  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name     | Reset     | Access | Description                                                                                                                                                                                                                                                 |
|-------|----------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                           |
| 21    | SDAMONEN | 0x0       | RW     | <b>SDA Monitor Enable</b><br><br>Set to enable SDA monitor feature. This will enable SDA rise check at loopback path. This monitor can not be enabled in Multi-Leader application                                                                           |
|       | Value    | Mode      |        | Description                                                                                                                                                                                                                                                 |
|       | 0        | DISABLE   |        | Disable SDA Monitor                                                                                                                                                                                                                                         |
|       | 1        | ENABLE    |        | Enable SDA Monitor                                                                                                                                                                                                                                          |
| 20    | SCLMONEN | 0x0       | RW     | <b>SCL Monitor Enable</b><br><br>Set to enable SCL monitor feature. This will enable SCL rise check at loopback path. This monitor can not be enabled in Multi-Leader application                                                                           |
|       | Value    | Mode      |        | Description                                                                                                                                                                                                                                                 |
|       | 0        | DISABLE   |        | Disable SCL monitor                                                                                                                                                                                                                                         |
|       | 1        | ENABLE    |        | Enable SCL monitor                                                                                                                                                                                                                                          |
| 19    | Reserved |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                           |
| 18:16 | CLTO     | 0x0       | RW     | <b>Clock Low Timeout</b><br><br>Use to generate a timeout when CLK has been low for the given amount of time. Wraps around and continues counting when the timeout is reached. The timeout value can be calculated by timeout = PCC/(Fscl x (Nlow + Nhigh)) |
|       | Value    | Mode      |        | Description                                                                                                                                                                                                                                                 |
|       | 0        | OFF       |        | Timeout disabled                                                                                                                                                                                                                                            |
|       | 1        | I2C40PCC  |        | Timeout after 40 prescaled clock cycles. In standard mode at 100 kHz, this results in a 50us timeout.                                                                                                                                                       |
|       | 2        | I2C80PCC  |        | Timeout after 80 prescaled clock cycles. In standard mode at 100 kHz, this results in a 100us timeout.                                                                                                                                                      |
|       | 3        | I2C160PCC |        | Timeout after 160 prescaled clock cycles. In standard mode at 100 kHz, this results in a 200us timeout.                                                                                                                                                     |
|       | 4        | I2C320PCC |        | Timeout after 320 prescaled clock cycles. In standard mode at 100 kHz, this results in a 400us timeout.                                                                                                                                                     |

| Bit   | Name     | Reset      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|----------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 5        | I2C1024PCC |        | Timeout after 1024 prescaled clock cycles. In standard mode at 100 kHz, this results in a 1280us timeout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15    | GIBITO   | 0x0        | RW     | <b>Go Idle on Bus Idle Timeout</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |          |            |        | When set, the bus automatically goes idle on a bus idle timeout, allowing new transfers to be initiated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | Value    | Mode       |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 0        | DISABLE    |        | A bus idle timeout has no effect on the bus state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       | 1        | ENABLE     |        | A bus idle timeout tells the I2C module that the bus is idle, allowing new transfers to be initiated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14    | Reserved |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 13:12 | BITO     | 0x0        | RW     | <b>Bus Idle Timeout</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |          |            |        | Use to generate a timeout when SCL has been high for a given amount time between a START and STOP condition. When in a bus transaction, i.e. the BUSY flag is set, a timer is started whenever SCL goes high. When the timer reaches the value defined by BITO, it sets the BITO interrupt flag. The BITO interrupt flag will then be set periodically as long as SCL remains high. The bus idle timeout is active as long as BUSY is set. It is thus stopped automatically on a timeout if GIBITO is set. It is also stopped a STOP condition is detected and when the ABORT command is issued. The timeout is activated whenever the bus goes BUSY, i.e. a START condition is detected. The timeout value can be calculated by timeout = PCC/(Fscl x (Nlow + Nhigh)) |
|       | Value    | Mode       |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 0        | OFF        |        | Timeout disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 1        | I2C40PCC   |        | Timeout after 40 prescaled clock cycles. In standard mode at 100 kHz, this results in a 50us timeout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       | 2        | I2C80PCC   |        | Timeout after 80 prescaled clock cycles. In standard mode at 100 kHz, this results in a 100us timeout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | 3        | I2C160PCC  |        | Timeout after 160 prescaled clock cycles. In standard mode at 100 kHz, this results in a 200us timeout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11:10 | Reserved |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9:8   | CLHR     | 0x0        | RW     | <b>Clock Low High Ratio</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |          |            |        | Determines the values of (and ratio between) the low and high parts of the clock signal generated on SCL as leader.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | Value    | Mode       |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 0        | STANDARD   |        | Nlow=4 and Nhigh=4, and the Nlow:Nhigh ratio is 4:4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | 1        | ASYMMETRIC |        | Nlow=6 and Nhigh=3, and the Nlow:Nhigh ratio is 6:3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | 2        | FAST       |        | Nlow=11 and Nhigh=6, and the Nlow:Nhigh ratio is 11:6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7     | TXBIL    | 0x0        | RW     | <b>TX Buffer Interrupt Level</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |          |            |        | Determines the interrupt and status level of the transmit buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       | Value    | Mode       |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 0        | EMPTY      |        | TXBL status and the TXBL interrupt flag are set when the transmit buffer becomes empty. TXBL is cleared when the buffer becomes nonempty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Name    | Reset     | Access | Description                                                                                                                                                 |
|-----|---------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   |         | HALF_FULL |        | TXBL status and the TXBL interrupt flag are set when the transmit buffer goes from full to half-full or empty. TXBL is cleared when the buffer becomes full |
| 6   | GCAMEN  | 0x0       | RW     | <b>General Call Address Match Enable</b><br><br>Set to enable address match on general call in addition to the programmed follower address.                 |
|     | Value   | Mode      |        | Description                                                                                                                                                 |
|     | 0       | DISABLE   |        | General call address will be NACK'ed if it is not included by the follower address and address mask.                                                        |
|     | 1       | ENABLE    |        | When a general call address is received, a software response is required                                                                                    |
| 5   | ARBDIS  | 0x0       | RW     | <b>Arbitration Disable</b><br><br>A leader or follower will not release the bus upon losing arbitration.                                                    |
|     | Value   | Mode      |        | Description                                                                                                                                                 |
|     | 0       | DISABLE   |        | When a device loses arbitration, the ARBIF interrupt flag is set and the bus is released.                                                                   |
|     | 1       | ENABLE    |        | When a device loses arbitration, the ARBIF interrupt flag is set, but communication proceeds.                                                               |
| 4   | AUTOSN  | 0x0       | RW     | <b>Automatic STOP on NACK</b><br><br>Write to 1 to make a leader transmitter send a STOP when a NACK is received from a follower.                           |
|     | Value   | Mode      |        | Description                                                                                                                                                 |
|     | 0       | DISABLE   |        | Stop is not automatically sent if a NACK is received from a follower.                                                                                       |
|     | 1       | ENABLE    |        | The leader automatically sends a STOP if a NACK is received from a follower.                                                                                |
| 3   | AUTOSE  | 0x0       | RW     | <b>Automatic STOP when Empty</b><br><br>Write to 1 to make a leader transmitter send a STOP when no more data is available for transmission.                |
|     | Value   | Mode      |        | Description                                                                                                                                                 |
|     | 0       | DISABLE   |        | A stop must be sent manually when no more data is to be transmitted.                                                                                        |
|     | 1       | ENABLE    |        | The leader automatically sends a STOP when no more data is available for transmission.                                                                      |
| 2   | AUTOACK | 0x0       | RW     | <b>Automatic Acknowledge</b><br><br>Set to enable automatic acknowledges.                                                                                   |
|     | Value   | Mode      |        | Description                                                                                                                                                 |
|     | 0       | DISABLE   |        | Software must give one ACK command for each ACK transmitted on the I2C bus.                                                                                 |
|     | 1       | ENABLE    |        | Addresses that are not automatically NACK'ed, and all data is automatically acknowledged.                                                                   |
| 1   | SLAVE   | 0x0       | RW     | <b>Addressable as Follower</b>                                                                                                                              |

| Bit                                                                                                                                                            | Name    | Reset | Access | Description                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set this bit to allow the device to be selected as an I2C follower.                                                                                            |         |       |        |                                                                                                                                                                                           |
| Value                                                                                                                                                          | Mode    |       |        | Description                                                                                                                                                                               |
| 0                                                                                                                                                              | DISABLE |       |        | All addresses will be responded to with a NACK                                                                                                                                            |
| 1                                                                                                                                                              | ENABLE  |       |        | Addresses matching the programmed follower address or the general call address (if enabled) require a response from software. Other addresses are automatically responded to with a NACK. |
| <b>0 CORERST</b><br>Set to reset the I2C_STATE register, and return the I2C module to the IDLE state. Must clear this bit to resume normal operation condition |         |       |        |                                                                                                                                                                                           |
| Value                                                                                                                                                          | Mode    |       |        | Description                                                                                                                                                                               |
| 0                                                                                                                                                              | DISABLE |       |        | No change to internal state registers                                                                                                                                                     |
| 1                                                                                                                                                              | ENABLE  |       |        | Reset the internal state registers                                                                                                                                                        |

## 22.5.4 I2C\_CMD - Command Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |         |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--|---------|
| 0x00C         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |         |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | 0x0 7   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | W(nB) 6 |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | W(nB) 5 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | W(nB) 4 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | W(nB) 3 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | W(nB) 2 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | W(nB) 1 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | W(nB) 0 |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|------|----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                                                                                       |
| 7    | CLEARPC  | 0x0   | W(nB)  | <b>Clear Pending Commands</b><br><br>Set to clear pending commands.                                                                                                                                                                                                                                                                                                                                     |
| 6    | CLEARTX  | 0x0   | W(nB)  | <b>Clear TX</b><br><br>Set to clear transmit buffer and shift register. Will not abort ongoing transfer.                                                                                                                                                                                                                                                                                                |
| 5    | ABORT    | 0x0   | W(nB)  | <b>Abort transmission</b><br><br>Abort the current transmission making the bus go idle. When used in combination with STOP, a STOP condition is sent as soon as possible before aborting the transmission. The stop condition is subject to clock synchronization.                                                                                                                                      |
| 4    | CONT     | 0x0   | W(nB)  | <b>Continue transmission</b><br><br>Set to continue transmission after a NACK has been received.                                                                                                                                                                                                                                                                                                        |
| 3    | NACK     | 0x0   | W(nB)  | <b>Send NACK</b><br><br>Set to transmit a NACK the next time an acknowledge is required.                                                                                                                                                                                                                                                                                                                |
| 2    | ACK      | 0x0   | W(nB)  | <b>Send ACK</b><br><br>Set to transmit an ACK the next time an acknowledge is required.                                                                                                                                                                                                                                                                                                                 |
| 1    | STOP     | 0x0   | W(nB)  | <b>Send stop condition</b><br><br>Set to send stop condition as soon as possible.                                                                                                                                                                                                                                                                                                                       |
| 0    | START    | 0x0   | W(nB)  | <b>Send start condition</b><br><br>Set to send start condition as soon as possible. If a transmission is ongoing and not owned, the start condition will be sent as soon as the bus is idle. If the current transmission is owned by this module, a repeated start condition will be sent. Use in combination with a STOP command to automatically send a STOP, then a START when the bus becomes idle. |

## 22.5.5 I2C\_STATE - State Register

| Offset      | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x010       | 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 |
| Reset       | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access      | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| STATE       |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| BUSHOLD     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| NACKED      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| TRANSMITTER |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| MASTER      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| BUSY        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name        | Reset   | Access | Description                                                                                                                                                                                                                                                                                                                          |
|------|-------------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved    |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                                                    |
| 7:5  | STATE       | 0x0     | R      | <b>Transmission State</b><br><br>The state of any current transmission. Cleared if the I2C module is idle.                                                                                                                                                                                                                           |
|      | Value       | Mode    |        | Description                                                                                                                                                                                                                                                                                                                          |
|      | 0           | IDLE    |        | No transmission is being performed.                                                                                                                                                                                                                                                                                                  |
|      | 1           | WAIT    |        | Waiting for idle. Will send a start condition as soon as the bus is idle.                                                                                                                                                                                                                                                            |
|      | 2           | START   |        | Start transmit phase                                                                                                                                                                                                                                                                                                                 |
|      | 3           | ADDR    |        | Address transmit or receive phase                                                                                                                                                                                                                                                                                                    |
|      | 4           | ADDRACK |        | Address ack/nack transmit or receive phase                                                                                                                                                                                                                                                                                           |
|      | 5           | DATA    |        | Data transmit or receive phase                                                                                                                                                                                                                                                                                                       |
|      | 6           | DATAACK |        | Data ack/nack transmit or receive phase                                                                                                                                                                                                                                                                                              |
| 4    | BUSHOLD     | 0x0     | R      | <b>Bus Held</b><br><br>Set if the bus is currently being held by this I2C module.                                                                                                                                                                                                                                                    |
| 3    | NACKED      | 0x0     | R      | <b>Nack Received</b><br><br>Set if a NACK was received and STATE is ADDRACK or DATAACK.                                                                                                                                                                                                                                              |
| 2    | TRANSMITTER | 0x0     | R      | <b>Transmitter</b><br><br>Set when operating as a leader transmitter or a follower transmitter. When cleared, the system may be operating as a leader receiver, a follower receiver or the current mode is not known.                                                                                                                |
| 1    | MASTER      | 0x0     | R      | <b>Leader</b><br><br>Set when operating as an I2C leader. When cleared, the system may be operating as an I2C follower.                                                                                                                                                                                                              |
| 0    | BUSY        | 0x1     | R      | <b>Bus Busy</b><br><br>Set when the bus is busy. Whether the I2C module is in control of the bus or not has no effect on the value of this bit. When the MCU comes out of reset, the state of the bus is not known, and thus BUSY is set. Use the ABORT command or a bus idle timeout to force the I2C module out of the BUSY state. |

## 22.5.6 I2C\_STATUS - Status Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| 0x014         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R  | 0x0 |    |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R  | 0x0 |    |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R  | 0x0 |    |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                    |
|-------|----------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                              |
| 11:10 | TXBUFCNT | 0x0   | R      | <b>TX Buffer Count</b><br><br>Indicates the number of buffers filled with valid data and not transmit to tx shift register                                                                                     |
| 9     | RXFULL   | 0x0   | R      | <b>RX FIFO Full</b><br><br>Set when the receive buffer is full. Cleared when the receive buffer is no longer full. When this bit is set, there is still room for one more frame in the receive shift register. |
| 8     | RXDATAV  | 0x0   | R      | <b>RX Data Valid</b><br><br>Set when data is available in the receive buffer. Cleared when the receive buffer is empty.                                                                                        |
| 7     | TXBL     | 0x1   | R      | <b>TX Buffer Level</b><br><br>Indicates the level of the transmit buffer. if TXBIL==0, set when the transmit buffer is empty. if TXBIL==1, set when the transmit buffer is half full                           |
| 6     | TXC      | 0x0   | R      | <b>TX Complete</b><br><br>Set when a transmission has completed and no more data is available in the transmit buffer. Cleared when a new transmission starts.                                                  |
| 5     | PABORT   | 0x0   | R      | <b>Pending abort</b><br><br>An abort is pending and will be transmitted as soon as possible.                                                                                                                   |
| 4     | PCONT    | 0x0   | R      | <b>Pending continue</b><br><br>A continue is pending and will be transmitted as soon as possible.                                                                                                              |
| 3     | PNACK    | 0x0   | R      | <b>Pending NACK</b><br><br>A not-acknowledge is pending and will be transmitted as soon as possible.                                                                                                           |
| 2     | PACK     | 0x0   | R      | <b>Pending ACK</b><br><br>An acknowledge is pending and will be transmitted as soon as possible.                                                                                                               |
| 1     | PSTOP    | 0x0   | R      | <b>Pending STOP</b><br><br>A stop condition is pending and will be transmitted as soon as possible.                                                                                                            |
| 0     | PSTART   | 0x0   | R      | <b>Pending START</b><br><br>A start condition is pending and will be transmitted as soon as possible.                                                                                                          |

**22.5.7 I2C\_CLKDIV - Clock Division Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x018  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8:0  | DIV      | 0x0   | RW     | <b>Clock Divider</b><br><br>Specifies the clock divider for the I2C. Note that DIV must be 1 or higher when follower is enabled.                                                  |

**22.5.8 I2C\_SADDR - Follower Address Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x01C  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:1  | ADDR     | 0x0   | RW     | <b>Follower address</b><br><br>Specifies the follower address of the device.                                                                                                      |
| 0    | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**22.5.9 I2C\_SADDRMASK - Follower Address Mask Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x020  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | SADDRMASK    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                              |
|------|-----------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>        |
| 7:1  | SADDRMASK | 0x0   | RW     | <b>Follower Address Mask</b>                                                                                                                                                             |
|      |           |       |        | Specifies the significant bits of the follower address. Setting the mask to 0x00 will match all addresses, while setting it to 0x7F will only match the exact address specified by ADDR. |
| 0    | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>        |

**22.5.10 I2C\_RXDATA - Receive Buffer Data Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x024  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | RXDATA       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | RXDATA   | 0x0   | R      | <b>RX Data</b>                                                                                                                                                                    |
|      |          |       |        | Use this register to read from the receive buffer. Buffer is emptied on read access.                                                                                              |

**22.5.11 I2C\_RXDOUBLE - Receive Buffer Double Data Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |     |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|-----|---------|---|---|---|---|---|---|
| 0x028  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |   |   | 0x0 |         |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R       |    |    |    |    |    |   |   |     | R       |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXDATA1 |    |    |    |    |    |   |   |     | RXDATA0 |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:8  | RXDATA1  | 0x0   | R      | <b>RX Data 1</b><br><br>Second byte read from buffer. Buffer is emptied on read access.                                                                                           |
| 7:0   | RXDATA0  | 0x0   | R      | <b>RX Data 0</b><br><br>First byte read from buffer. Buffer is emptied on read access.                                                                                            |

**22.5.12 I2C\_RXDATAP - Receive Buffer Data Peek Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x02C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RXDATAP |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | RXDATAP  | 0x0   | R      | <b>RX Data Peek</b><br><br>Use this register to read from the receive buffer. Buffer is not emptied on read access.                                                               |

**22.5.13 I2C\_RXDOUBLEP - Receive Buffer Double Data Peek Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| 0x030         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0      |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R        |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RXDATAP1 |   |   |   |   |   |   |   |

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:8  | RXDATAP1        | 0x0   | R      | <b>RX Data 1 Peek</b><br><br>Second byte read from buffer. Buffer is not emptied on read access.                                                                                  |
| 7:0   | RXDATAP0        | 0x0   | R      | <b>RX Data 0 Peek</b><br><br>First byte read from buffer. Buffer is not emptied on read access.                                                                                   |

**22.5.14 I2C\_TXDATA - Transmit Buffer Data Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 <td data-kind="ghost"></td> |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------------|---|---|---|---|---|---|---|
| 0x034         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W(nB)                           |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W(nB)                           |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | TXDATA                          |   |   |   |   |   |   |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | TXDATA          | 0x0   | W(nB)  | <b>TX Data</b><br><br>Use this register to write a byte to the transmit buffer.                                                                                                   |

## 22.5.15 I2C\_TXDOUBLE - Transmit Buffer Double Data Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |       |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|-------|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|
| 0x038  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0     | 0x0   |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | W(nB)   | W(nB) |    |    |    |    |   |   |   |         |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TXDATA1 | W(nB) |    |    |    |    |   |   |   | TXDATA0 |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                       |
|-------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:8  | TXDATA1  | 0x0   | W(nB)  | <b>TX Data</b><br><br>Second byte to write to buffer.                                                                                                             |
| 7:0   | TXDATA0  | 0x0   | W(nB)  | <b>TX Data</b><br><br>First byte to write to buffer.                                                                                                              |

## 22.5.16 I2C\_IF - Interrupt Flag Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |        |        |       |        |        |        |       |        |       |         |        |         |       |         |        |         |       |      |      |         |       |     |      |        |       |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|--------|--------|-------|--------|--------|--------|-------|--------|-------|---------|--------|---------|-------|---------|--------|---------|-------|------|------|---------|-------|-----|------|--------|-------|
| 0x03C  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | SDAERR | SCLERR | CLERR | RXFULL | SSTOP  | CLTO   | BITO  | RXUF   | TXOF  | BUSHOLD | BUSERR | ARBLOST | MSTOP | NACK    | ACK    | RXDATAV | TXBL  | TXC  | ADDR | RSTART  | START |     |      |        |       |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |        |        |       |        | 0x0    | 0x0    | 0x0   | 0x0    | 0x0   | 0x0     | 0x0    | 0x0     | 0x0   | 0x0     | 0x0    | 0x0     | 0x0   | 0x0  | 0x0  | 0x0     | 0x0   | 0x0 |      |        |       |
| Access |              |    |    |    |    |    |    |    |    |    |    |        |        |       |        | RW     | RW     | RW    | RW     | RW    | RW      | RW     | RW      | RW    | RW      | RW     | RW      | RW    | RW   | RW   | RW      | RW    | RW  |      |        |       |
| Name   |              |    |    |    |    |    |    |    |    |    |    |        |        |       |        | SDAERR | SCLERR | CLERR | RXFULL | SSTOP | CLTO    | BITO   | RXUF    | TXOF  | BUSHOLD | BUSERR | ARBLOST | MSTOP | NACK | ACK  | RXDATAV | TXBL  | TXC | ADDR | RSTART | START |
|        |              |    |    |    |    |    |    |    |    |    |    |        |        |       |        | 0x0    | 0x0    | 0x0   | 0x0    | 0x0   | 0x0     | 0x0    | 0x0     | 0x0   | 0x0     | 0x0    | 0x0     | 0x0   | 0x0  | 0x0  | 0x0     | 0x0   | 0x0 | 0x0  |        |       |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                                  |
|-------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                            |
| 20    | SDAERR   | 0x0   | RW     | <b>SDA Error Interrupt Flag</b><br>Set when the SDA at loopback path is not equal to SDA output                                                                                                                                                              |
| 19    | SCLERR   | 0x0   | RW     | <b>SCL Error Interrupt Flag</b><br>Set when the SCL at loopback path is not equal to SCL output                                                                                                                                                              |
| 18    | CLERR    | 0x0   | RW     | <b>Clock Low Error Interrupt Flag</b><br>Set when the clock is pulled low before a START or a STOP condition could be transmitted.                                                                                                                           |
| 17    | RXFULL   | 0x0   | RW     | <b>Receive Buffer Full Interrupt Flag</b><br>Set when the receive buffer becomes full.                                                                                                                                                                       |
| 16    | SSTOP    | 0x0   | RW     | <b>Follower STOP condition Interrupt Flag</b><br>Set when a STOP condition has been received. Will be set regardless of the follower being involved in the transaction or not.                                                                               |
| 15    | CLTO     | 0x0   | RW     | <b>Clock Low Timeout Interrupt Flag</b><br>Set on each clock low timeout. The timeout value can be set in CLTO bit field in the I2Cn_CTRL register.                                                                                                          |
| 14    | BITO     | 0x0   | RW     | <b>Bus Idle Timeout Interrupt Flag</b><br>Set on each bus idle timeout. The timeout value can be set in the BITO bit field in the I2Cn_CTRL register.                                                                                                        |
| 13    | RXUF     | 0x0   | RW     | <b>Receive Buffer Underflow Interrupt Flag</b><br>Set when data is read from the receive buffer through the I2Cn_RXDATA register while the receive buffer is empty. It is also set when data is read through the I2Cn_RXDOUBLE while the buffer is not full. |
| 12    | TXOF     | 0x0   | RW     | <b>Transmit Buffer Overflow Interrupt Flag</b><br>Set when data is written to the transmit buffer while the transmit buffer is full.                                                                                                                         |
| 11    | BUSHOLD  | 0x0   | RW     | <b>Bus Held Interrupt Flag</b><br>Set when the bus becomes held by the I2C module.                                                                                                                                                                           |
| 10    | BUSERR   | 0x0   | RW     | <b>Bus Error Interrupt Flag</b><br>Set when a bus error is detected. The bus error is resolved automatically, but the current transfer is aborted.                                                                                                           |
| 9     | ARBLOST  | 0x0   | RW     | <b>Arbitration Lost Interrupt Flag</b><br>Set when arbitration is lost.                                                                                                                                                                                      |
| 8     | MSTOP    | 0x0   | RW     | <b>Leader STOP Condition Interrupt Flag</b>                                                                                                                                                                                                                  |

| Bit | Name    | Reset | Access | Description                                                                                                                                                                  |
|-----|---------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         |       |        | Set when a STOP condition has been successfully transmitted. If arbitration is lost during the transmission of the STOP condition, then the MSTOP interrupt flag is not set. |
| 7   | NACK    | 0x0   | RW     | <b>Not Acknowledge Received Interrupt Flag</b>                                                                                                                               |
|     |         |       |        | Set when a NACK has been received.                                                                                                                                           |
| 6   | ACK     | 0x0   | RW     | <b>Acknowledge Received Interrupt Flag</b>                                                                                                                                   |
|     |         |       |        | Set when an ACK has been received.                                                                                                                                           |
| 5   | RXDATAV | 0x0   | RW     | <b>Receive Data Valid Interrupt Flag</b>                                                                                                                                     |
|     |         |       |        | Set when received data is half full                                                                                                                                          |
| 4   | TXBL    | 0x0   | RW     | <b>Transmit Buffer Level Interrupt Flag</b>                                                                                                                                  |
|     |         |       |        | if TXBIL==0, set when the transmit buffer is empty. if TXBIL==1, set when the transmit is half full                                                                          |
| 3   | TXC     | 0x0   | RW     | <b>Transfer Completed Interrupt Flag</b>                                                                                                                                     |
|     |         |       |        | Set when the transmit shift register becomes empty and there is no more data in the transmit buffer.                                                                         |
| 2   | ADDR    | 0x0   | RW     | <b>Address Interrupt Flag</b>                                                                                                                                                |
|     |         |       |        | Set when incoming address is accepted, i.e. own address or general call address is received.                                                                                 |
| 1   | RSTART  | 0x0   | RW     | <b>Repeated START condition Interrupt Flag</b>                                                                                                                               |
|     |         |       |        | Set when a repeated start condition is detected.                                                                                                                             |
| 0   | START   | 0x0   | RW     | <b>START condition Interrupt Flag</b>                                                                                                                                        |
|     |         |       |        | Set when a start condition is successfully transmitted.                                                                                                                      |

### 22.5.17 I2C\_IEN - Interrupt Enable Register

| Offset | Bit Position |    |     |    |        |    |     |    |         |    |     |    |
|--------|--------------|----|-----|----|--------|----|-----|----|---------|----|-----|----|
| Reset  | 31           | 30 | 29  | 28 | 27     | 26 | 25  | 24 | 23      | 22 | 21  |    |
| Access | SDAERR       | RW | 0x0 | 20 | SCLERR | RW | 0x0 | 19 | CLERR   | RW | 0x0 | 18 |
| Name   | RXFULL       | RW | 0x0 | 17 | SSSTOP | RW | 0x0 | 16 | CLTO    | RW | 0x0 | 15 |
|        | BITO         | RW | 0x0 | 14 | RXUF   | RW | 0x0 | 13 | TXOF    | RW | 0x0 | 12 |
|        | BUSHOLD      | RW | 0x0 | 11 | BUSERR | RW | 0x0 | 10 | ARBLOST | RW | 0x0 | 9  |
|        | MSTOP        | RW | 0x0 | 8  | NACK   | RW | 0x0 | 7  | ACK     | RW | 0x0 | 6  |
|        | RXDATAV      | RW | 0x0 | 5  | TXBL   | RW | 0x0 | 4  | TYC     | RW | 0x0 | 3  |
|        | ADDR         | RW | 0x0 | 2  | RSTART | RW | 0x0 | 1  | START   | RW | 0x0 | 0  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                                  |
|-------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                            |
| 20    | SDAERR   | 0x0   | RW     | <b>SDA Error Interrupt Flag</b><br>Set when SDA at loopback path is not equal to SDA output                                                                                                                                                                  |
| 19    | SCLERR   | 0x0   | RW     | <b>SCL Error Interrupt Flag</b><br>Set when SCL at loopback path is not equal to SCL output                                                                                                                                                                  |
| 18    | CLERR    | 0x0   | RW     | <b>Clock Low Error Interrupt Flag</b><br>Set when the clock is pulled low before a START or a STOP condition could be transmitted.                                                                                                                           |
| 17    | RXFULL   | 0x0   | RW     | <b>Receive Buffer Full Interrupt Flag</b><br>Set when the receive buffer becomes full.                                                                                                                                                                       |
| 16    | SSTOP    | 0x0   | RW     | <b>Follower STOP condition Interrupt Flag</b><br>Set when a STOP condition has been received. Will be set regardless of the follower being involved in the transaction or not.                                                                               |
| 15    | CLTO     | 0x0   | RW     | <b>Clock Low Timeout Interrupt Flag</b><br>Set on each clock low timeout. The timeout value can be set in CLTO bit field in the I2Cn_CTRL register.                                                                                                          |
| 14    | BITO     | 0x0   | RW     | <b>Bus Idle Timeout Interrupt Flag</b><br>Set on each bus idle timeout. The timeout value can be set in the BITO bit field in the I2Cn_CTRL register.                                                                                                        |
| 13    | RXUF     | 0x0   | RW     | <b>Receive Buffer Underflow Interrupt Flag</b><br>Set when data is read from the receive buffer through the I2Cn_RXDATA register while the receive buffer is empty. It is also set when data is read through the I2Cn_RXDOUBLE while the buffer is not full. |
| 12    | TXOF     | 0x0   | RW     | <b>Transmit Buffer Overflow Interrupt Flag</b><br>Set when data is written to the transmit buffer while the transmit buffer is full.                                                                                                                         |
| 11    | BUSHOLD  | 0x0   | RW     | <b>Bus Held Interrupt Flag</b><br>Set when the bus becomes held by the I2C module.                                                                                                                                                                           |
| 10    | BUSERR   | 0x0   | RW     | <b>Bus Error Interrupt Flag</b><br>Set when a bus error is detected. The bus error is resolved automatically, but the current transfer is aborted.                                                                                                           |
| 9     | ARBLOST  | 0x0   | RW     | <b>Arbitration Lost Interrupt Flag</b><br>Set when arbitration is lost.                                                                                                                                                                                      |
| 8     | MSTOP    | 0x0   | RW     | <b>Leader STOP Condition Interrupt Flag</b>                                                                                                                                                                                                                  |

| Bit | Name    | Reset | Access | Description                                                                                                                                                                  |
|-----|---------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         |       |        | Set when a STOP condition has been successfully transmitted. If arbitration is lost during the transmission of the STOP condition, then the MSTOP interrupt flag is not set. |
| 7   | NACK    | 0x0   | RW     | <b>Not Acknowledge Received Interrupt Flag</b>                                                                                                                               |
|     |         |       |        | Set when a NACK has been received.                                                                                                                                           |
| 6   | ACK     | 0x0   | RW     | <b>Acknowledge Received Interrupt Flag</b>                                                                                                                                   |
|     |         |       |        | Set when an ACK has been received.                                                                                                                                           |
| 5   | RXDATAV | 0x0   | RW     | <b>Receive Data Valid Interrupt Flag</b>                                                                                                                                     |
|     |         |       |        | Set when data is available in the receive buffer. Cleared automatically when the receive buffer is read.                                                                     |
| 4   | TXBL    | 0x0   | RW     | <b>Transmit Buffer Level Interrupt Flag</b>                                                                                                                                  |
|     |         |       |        | Set when the transmit buffer becomes empty. Cleared automatically when new data is written to the transmit buffer.                                                           |
| 3   | TXC     | 0x0   | RW     | <b>Transfer Completed Interrupt Flag</b>                                                                                                                                     |
|     |         |       |        | Set when the transmit shift register becomes empty and there is no more data in the transmit buffer.                                                                         |
| 2   | ADDR    | 0x0   | RW     | <b>Address Interrupt Flag</b>                                                                                                                                                |
|     |         |       |        | Set when incoming address is accepted, i.e. own address or general call address is received.                                                                                 |
| 1   | RSTART  | 0x0   | RW     | <b>Repeated START condition Interrupt Flag</b>                                                                                                                               |
|     |         |       |        | Set when a repeated start condition is detected.                                                                                                                             |
| 0   | START   | 0x0   | RW     | <b>START condition Interrupt Flag</b>                                                                                                                                        |
|     |         |       |        | Set when a start condition is successfully transmitted.                                                                                                                      |

## 23. IADC - Incremental Analog to Digital Converter



### Quick Facts

#### What?

The IADC is used to convert analog voltages into a digital representation and features high-speed, low-power operation.

#### Why?

In many applications there is a need to measure analog signals and record them in a digital representation, without exhausting the energy source.

#### How?

The low power IADC samples one or more input channels in a programmable sequence. With the help of PRS and DMA, the IADC can operate without CPU intervention in EM2 and EM3, minimizing the number of powered up resources. The IADC can be automatically shut down between conversions to further reduce the energy consumption.

### 23.1 Introduction

The IADC uses an Incremental Successive Approximation Architecture, with a resolution of up to 12 bits when operating at two million samples per second (2 Msps). The flexible incremental architecture uses oversampling to allow applications to trade speed for higher resolution. A high-accuracy mode enables greater than 15 bits of noise-free resolution. An integrated input multiplexer can select from external I/Os and several internal signals.

## 23.2 Features

- Flexible oversampled architecture allows for tradeoffs between speed and resolution.
  - Normal Mode
    - 1 Msps with oversampling ratio = 2
    - 76.9 ksps with oversampling ratio = 32
  - High Speed Mode
    - 2 Msps with oversampling ratio = 2
    - 153.8 ksps with oversampling ratio = 32
  - High Accuracy Mode
    - 10.7 ksps with oversampling ratio = 92
    - 3.8 ksps with oversampling ratio = 256
- Digital post-averaging
- Internal and external conversion trigger sources
  - Immediate (software triggered)
  - Local IADC timer
  - External TIMER module (synchronous with output / PWM generation)
  - General PRS hardware signal
- Integrated prescaler for conversion clock generation
- Can be run during EM2 and EM3, waking up the system on interrupts as needed
- Selectable reference sources
  - 1.21 V internal reference
  - External precision reference
  - Analog supply
- Support for offset and gain calibration
- Programmable input gain: 0.5x, 1x, 2x, 3x, or 4x
- Flexible output formatting
  - Unipolar or 2's complement bipolar data
  - Results can be saved in 12 bit, 16 bit, or 20 bit format
  - Programmable left or right justification
  - Optional channel ID tag
- Digital window comparison function detects when results are inside/outside a programmable window
- Two independent groups of configuration registers for setting IADC mode, clock prescaler, reference selection, oversample rate, unipolar/bipolar output formatting, and analog gain
- Programmable single channel conversion
  - Can use either configuration group
  - Triggered by any conversion trigger source
  - Can be tailgated after a scan sequence
  - One shot or continuous mode
  - Local FIFO for immediate data storage
  - Programmable watermark level to generate interrupt or initiate DMA transfer
  - Supports overflow and underflow interrupt generation
  - Supports window compare function
- Autonomous multi-channel scan
  - Up to 16 configurable slots in scan sequence
  - Each slot allows independent selection of configuration group, channel selection, and window compare enable
  - Triggered by any conversion trigger source
  - One shot or continuous mode
  - Local FIFO for immediate data storage
  - Programmable watermark level to generate interrupt or initiate DMA transfer
  - Supports overflow and underflow interrupt generation
  - Conversion tailgating support for predictable periodic scans

- Available interrupt sources:

- Single FIFO has DVL (data valid level) entries available (also generates DMA request)
- Scan FIFO has DVL (data valid level) entries available (also generates DMA request)
- Single FIFO result compared true for digital compare window
- Scan FIFO result compared true for digital compare window
- Single queue conversion has completed
- Scan queue entry conversion has completed
- Scan queue table conversion has completed
- Single FIFO overflow or underflow
- Scan FIFO overflow or underflow
- Polarity Error interrupt
- Port Allocation Error interrupt
- EM23 clock configuration error

### 23.3 Functional Description

The incremental ADC module block diagram is shown in [Figure 23.1 IADC Overview on page 747](#).



Figure 23.1. IADC Overview

### 23.3.1 Register Access

Many of the IADC module's configuration registers can only be written while the module is disabled (`IADC_EN_EN = 0`). These are `IADC_CTRL`, `IADC_TIMER`, `IADC_CMPTHR`, `IADC_TRIGGER`, `IADC_CFGx`, `IADC_SCALEx`, `IADC_SCHEDx`, and `IADC_SCANx`. A typical setup sequence for the IADC module is:

1. With the IADC disabled (`IADC_EN_EN = 0`), program all configuration registers listed above.
2. Enable the IADC by setting EN in `IADC_EN` to 1.
3. Program the remaining configuration registers.
4. Enable the single or scan queue.
5. The IADC is ready for use.

### 23.3.2 Clocking

The IADC logic is partitioned into two clock domains: CLK\_BUS (APBIF) and CLK\_SRC\_ADC (CORE). The APBIF domain contains the IADC registers and FIFO read logic. The rest of the IADC is clocked mainly by CLK\_SRC\_ADC and ADC\_CLK, both of which are derived from CLK\_CMU\_ADC, as shown in .

CLK\_CMU\_ADC is the incoming clock routed to the ADC by the CMU, and may be up to 80 MHz. It is selected within the CMU module. If the ADC is to be used synchronously with an external TIMER module, the clock should be configured to derive from the group A clock. If configuring for operation in EM2 or EM3, a clock source available in EM2 and EM3 must be used directly, as the group A clock multiplexer will be shut down in EM2 and EM3.

CLK\_SRC\_ADC is derived from CLK\_CMU\_ADC, and must be no faster than 40 MHz. The HSCLKRATE field in IADC\_CTRL sets the prescaler to divide CLK\_CMU\_ADC. If CLK\_CMU\_ADC is already 40 MHz or slower, HSCLKRATE can be set to 0x0 to pass the clock through to CLK\_SRC\_ADC without dividing it. CLK\_SRC\_ADC is the clock source used for the TIMEBASE prescaler as well as the local IADC timer.

ADC\_CLK is used to drive the ADC front-end and state machine logic. Another prescaler is used to reduce CLK\_SRC\_ADC to a suitable frequency for the ADC operating mode. Different operational modes have different restrictions on the IADC clock speed. Because the operational mode may be different for single vs. scan conversions, or even for different conversions within a scan, each configuration group has a PRESCALE bit field in the IADC\_SCHEDx register.

When IADC\_CFGx.ADCMODE is set to NORMAL, PRESCALE must be set to limit ADC\_CLK to no faster than 10 MHz for 0.5x and 1x analog gain settings. For analog gain of 2x, 3x, and 4x, the maximum ADC\_CLK is 5 MHz, 2.5 MHz, or 2.5 MHz respectively.

When IADC\_CFGx.ADCMODE is set to HIGHSPEED, everything from NORMAL mode is scaled by a factor of 2. PRESCALE must be set to limit ADC\_CLK to no faster than 20 MHz for 0.5x and 1x analog gain settings. For analog gain of 2x, 3x, and 4x, the maximum ADC\_CLK is 10 MHz, 5 MHz, or 5 MHz respectively. It is recommended to run ADC\_CLK no slower than 100 kHz.

When IADC\_CFGx.ADCMODE is set to HIGHACCURACY, PRESCALE must be set to limit ADC\_CLK to no faster than 5 MHz, regardless of the analog gain setting.

These restrictions are summarized in [Table 23.1 Maximum ADC\\_CLK Speed vs Analog Gain and ADCMODE Settings on page 749](#).

**Table 23.1. Maximum ADC\_CLK Speed vs Analog Gain and ADCMODE Settings**

| Analog Gain | CFGx.ADCMODE = NORMAL | CFGx.ADCMODE = HIGH-SPEED | CFGx.ADCMODE = HIGHACCURACY |
|-------------|-----------------------|---------------------------|-----------------------------|
| 0.5 x       | 10 MHz                | 20 MHz                    | 5 MHz                       |
| 1 x         | 10 MHz                | 20 MHz                    | 5 MHz                       |
| 2 x         | 5 MHz                 | 10 MHz                    | 5 MHz                       |
| 3 x         | 2.5 MHz               | 5 MHz                     | 5 MHz                       |
| 4 x         | 2.5 MHz               | 5 MHz                     | 5 MHz                       |

**Note:** If HSCLKRATE is configured to divide CLK\_CMU\_ADC by more than 1 (HSCLKRATE != 0), then PRESCALE must not be set to divide by 1 (PRESCALE = 0). When this condition is detected, a PRESCALE value of 1 (divide by 2) will be automatically be used instead of the programmed PRESCALE value.

The suspend mode fields IADC\_CTRL\_ADCCLKSUSPEND0 (for scan conversions) or IADC\_CTRL\_ADCCLKSUSPEND1 (for single conversions) can be used to shut down the clock between conversions and save power. The ADC logic will wake up the clock before starting IADC warmup and performing a conversion. If the suspend mode is set, the clock will shut down again once the conversion is complete.

When IADC\_TRIGGER\_SCANTRIGSEL or IADC\_TRIGGER\_SINGLETRIGSEL is set to IMMEDIATE, IADC\_CTRL\_ADCCLKSUSPENDn will force the clock to only be running when one of the queues is enabled.

**Figure 23.2. Clocking**

### 23.3.3 Conversion Timing

The IADC takes multiple samples of the analog signal to produce each output. The number of input samples contributing to an output word is determined by the oversampling ratio (OSR). Higher OSR settings will improve the ADC's INL and DNL, and reduce system-level noise, but require more time for each conversion. Different OSRs may be specified for each configuration group. It is important to note that oversampling is an analog process which provides more input samples to the digital filter. For Normal and High-Speed modes, the OSR is configured with the OSRHS bit field in the IADC\_CFGx register. The OSR options for High-Accuracy mode are different, and are configured with the OSRHA bit field in the IADC\_CFGx register.

During a conversion, the effective front-end sampling frequency ( $F_{sample}$ ) in Normal and High-Speed modes is equal to  $ADC\_CLK / 4$ . In High-Accuracy mode,  $F_{sample}$  is  $ADC\_CLK / 5$ .

### 23.3.3.1 Warmup Time

To save energy, the IADC can be configured to power down completely or enter a standby state between conversions, if full speed operation is not required for the application. The required ADC warm up time from a full powered-down state is 5 us. Warmup from a standby state requires 1 us. Warmup is automatically timed by the ADC logic when it is required, but software must configure the TIMEBASE field in IADC\_CTRL for a minimum 1 us interval. Note that the TIMEBASE counter receives CLK\_SRC\_ADC, and should be programmed based on that frequency. For example, if CLK\_SRC\_ADC is 40 MHz, TIMEBASE should be set to at least 0x27 (39) to produce the minimum 1 us interval. When transitioning from a powered-down state, the IADC will use five TIMEBASE intervals. When in standby the IADC will use one TIMEBASE interval.

The WARMUPMODE field in the IADC\_CTRL register defines whether the IADC is powered down between conversions (WARMUPMODE = NORMAL), in standby between conversions (WARMUPMODE = KEEPINSTANDBY), or remains powered up (WARMUPMODE = KEEPWARM). The resulting start-up time is shown in [Figure 23.3 Start-up Timing on page 751](#). Note that even in WARMUPMODE = KEEPWARM or KEEPINSTANDBY, the ADC will implement 5 TIMEBASE intervals of warmup on initial power up, or any configuration change affecting PRESCALE, ADCMODE, or REFSEL. IADC\_STATUS\_ADCWARM reflects the current warmup status of the IADC.



Each change in ADCMODE, REFSEL, or PRESCALE require a 5us warm up period

**Figure 23.3. Start-up Timing**

### 23.3.3.2 Conversion Pipeline in Normal and High-Speed Modes

The IADC uses a pipelined architecture to perform different stages of the ADC conversion in parallel.

In Normal and High-Speed modes, the conversion time for a single sample can be determined from the OSR and the pre-scaled ADC\_CLK frequency ( $f_{ADC\_CLK}$ ) as:

$$\text{Conversion Time} = ((4 * \text{OSR}) + 2) / f_{ADC\_CLK}$$

The minimum OSR is 2, meaning that the fastest possible conversion lasts 10 ADC\_CLK clock cycles.

In Normal or High Speed mode, the IADC will automatically insert 2 additional cycles in the pipeline when changing channels to a new input. This allows for hold timing on the previous conversion and allows for time to tristate the ABUS analog buses before connecting the next input to the analog bus. Therefore the maximum sampling rate while continuously sampling on one channel in Normal mode (with ADC\_CLK = 10 MHz) is 1 Msps, and the maximum sampling rate while switching channels is 833 ksps.

In High-Speed mode the allowed ADC\_CLK speed is doubled to 20 MHz. The maximum sampling rate while continuously converting a single channel is 2 Msps, and the maximum sampling rate while switching channels is 1.67 Msps.

[Figure 23.4 Normal Mode ADC Pipeline on page 752](#) and [Figure 23.5 High-Speed Mode ADC Pipeline on page 753](#) show both single-channel and channel-switching scenarios powering up from a shutdown state with WARMUPMODE = NORMAL. The 5 us warm-up is shown in pink, a first conversion pipeline in green, and a second conversion in orange. The blue area in the top diagram represents the extra time to tristate while changing channels.

Normal mode switching channel between conversions



Normal mode converting same channel twice



Figure 23.4. Normal Mode ADC Pipeline

## High speed mode switching channel between conversions



## High speed mode with same channel between conversions

**Figure 23.5. High-Speed Mode ADC Pipeline****23.3.3.3 Conversion Pipeline in High-Accuracy Mode**

In High-Accuracy mode, the conversion time for a single sample can be determined from the OSR and the pre-scaled ADC\_CLK frequency ( $f_{ADC\_CLK}$ ) as:

$$\text{Conversion Time} = ((5 * \text{OSR}) + 7) / f_{ADC\_CLK}$$

The minimum OSR is 16, meaning that the fastest possible conversion in High-Accuracy mode lasts 87 ADC\_CLK clock cycles.

In High-Accuracy mode, there are no additional cycles required to change channels to a new input. [Figure 23.6 High-Accuracy Mode ADC Pipeline on page 753](#) shows the pipeline timing when powering up from a shutdown state with WARMUPMODE = NORMAL. The 5 us warmup is shown in pink, a first conversion pipeline in green, and a second conversion pipeline in orange.

## High accuracy mode switching channel between conversions does not require any extra cycles

**Figure 23.6. High-Accuracy Mode ADC Pipeline**

### 23.3.3.4 Scheduling and Triggers

The IADC has several triggering options available for both the Single queue and the Scan queue. When a conversion trigger occurs and there are no other conversions active or pending, the request is serviced immediately. If both the single and scan queues are being used in an application, it is possible to serve the conversion requests as needed, and specify their priority.

Conversion triggering is configured using bit fields in the IADC\_TRIGGER register. The SINGLETRIGSEL and SCANTRIGSEL fields specify the trigger source for Single and Scan conversion queues, respectively. The options for trigger source are:

- IMMEDIATE - Trigger from software. This is useful for triggering conversions on-demand from software with no specific sampling frequency requirements, or initiating continuous conversions at full speed.
- TIMER - Use the IADC local timer to trigger conversions. This is useful for triggering conversions at precise intervals.
- PRSCLKGRP - Use a synchronous PRS channel to trigger from an external peripheral in the same clock group domain (i.e. clock group A). This is useful for synchronizing conversions precisely with external TIMER events or PWM outputs.

**Note:** It is recommended to configure the PRS consumer registers prior to enabling synchronous PRS triggers to avoid false triggers.

- PRSPOS - Use a positive edge of an asynchronous PRS channel to trigger conversions. The trigger source will require 1-2 CLK\_SRC\_ADC cycles to synchronize. This is useful for triggering conversions as needed from asynchronous peripheral sources such as GPIO inputs, SYSRTC events, etc.
- PRSNEG - Use a negative edge of an asynchronous PRS channel to trigger conversions. This is the same as PRSPOS, but operates on negative edges of the selected input.

Both the single and scan trigger sources can be configured to generate one request per trigger, or begin continuous conversions. Setting SINGLETRIGACTION to ONCE will make one conversion request each time the selected single trigger occurs, and a single ADC output will be converted. Setting SINGLETRIGACTION to CONTINUOUS allows the single trigger to begin the first conversion, and when a conversion completes a new one will be requested immediately without requiring a new trigger. Channel selections and configuration should not be changed while SINGLETRIGACTION is set to CONTINUOUS. Doing so can produce conversion errors. The scan queue should be used if channel or configuration switching is required.

The SCANTRIGACTION field works to request conversion scans in a similar manner. Setting SCANTRIGACTION to ONCE will make one request each time the selected scan trigger occurs, and the IADC will perform all conversions specified in the scan once before stopping. Setting SCANTRIGACTION to CONTINUOUS allows the scan trigger to initiate continuous scans. When a scan cycle completes, a new one will be requested immediately without requiring a new trigger.

Conversion priority can be adjusted using the SINGLETAILGATE bit. By default, SINGLETAILGATE is set to TAILGATEOFF, meaning that conversion triggers are queued in the order they are received. Any conversion trigger for the Single queue or the Scan queue will initiate a conversion as soon as possible. If any conversion is already in progress or pending, the new conversion will be handled after the current operation.

Setting SINGLETAILGATE to TAILGATEON gives ultimate priority to the Scan queue. The IADC will only perform single conversions immediately after completion of a scan. This allows systems to use the scan queue for high-priority conversions with tight timing requirements, and the single queue for low-priority, on-demand conversion events. Note that this setting should only be used when scan conversions are guaranteed to trigger. If no scan sequence is triggered, any single conversion trigger will remain pending indefinitely. It is also important to note that if there is not enough time between scan conversions to service a single conversion, the next scan conversion will be delayed.

### 23.3.3.4.1 Conversion Triggering Examples

#### Scheduling a Single Sample

The simplest use case for the IADC is performing one conversion on-demand from the Single queue. [Figure 23.7 Immediate Single Conversion on page 755](#) shows the configuration and timing of this use case. The IADC warmup mode is configured for normal (shuts down between conversions). The single queue trigger is configured for immediate triggering of one conversion, and tailgating is turned off. When the conversion is requested (by setting IADC\_CMD\_SINGLESTART), the IADC block warms up and then begins converting. During the conversion, the CONVERTING bit in IADC\_STATUS is set. When the conversion is complete, the queue is disabled, and SINGLEQEN returns low.



**Figure 23.7. Immediate Single Conversion**

## Periodic Scans

Another common use case is to periodically trigger the IADC to perform a multi-channel scan. [Figure 23.8 Periodic Scan Example on page 756](#) shows the timing of a periodic scan triggered by the IADC's local timer. The scanner is configured to sample four different channels; two using configuration 0 and two using configuration 1. Note that a single TIMER trigger is used to initiate each scan, and all four samples are taken for each trigger. Note also that the IADC inserts another warmup time between conversions 1 and 2, when it switches from configuration 0 to configuration 1. The single queue is disabled and not used in this example.



Figure 23.8. Periodic Scan Example

## Tailgating Examples

An example using conversion tailgating is shown in [Figure 23.9 Simple Conversion with Tailgating Enabled on page 757](#). In the example, the Scan queue is configured to trigger a two-channel conversion periodically on the IADC local timer, while the Single queue is configured to trigger on-demand from software. When a single conversion is requested, it waits until after the scan sequence is complete, and then the single conversion is performed. The scan conversions are using configuration 0, and the single conversion is using configuration 1, so a warmup delay is inserted between the end of the scan and the beginning of the single conversion cycle. Note that this example provides plenty of time between IADC scan conversions for the single conversion to occur, and no scan conversions are delayed.



**Figure 23.9. Simple Conversion with Tailgating Enabled**

Another example, shown in [Figure 23.10 Conversions with Tailgating Disabled on page 758](#), demonstrates how requests are handled on the different conversion queues with tailgating disabled.

In this example, the scan queue is being triggered on the internal timer while the single queue is being triggered on a PRS positive edge. Since tailgating is not enabled, the queues will be serviced on a first come first served basis. The first single queue trigger falls between two scan queue triggers and does not interfere with scan queue timing. The second single queue trigger happens just before the scan queue trigger. The IADC will complete this single queue conversion and delay the next scan queue conversions.

**Figure 23.10. Conversions with Tailgating Disabled**

### Continuous Conversions

An example of continuous conversions triggered from the scan queue is shown in [Figure 23.11 Continuous Conversions on page 758](#). In this example the SCANTRIGACTION field in IADC\_TRIGGER is set to CONTINUOUS, and the conversion trigger source is software (SCANTRIGSEL = IMMEDIATE). When the scan queue is enabled with IADC\_CMD\_SCANSTART, the ADC warms up and then performs repeated back-to-back scans until software disables the scan queue using IADC\_CMD\_SCANSTOP. While this example shows only one channel converted continuously, it is possible to enable multiple channels for the scan sequence.

### Continuous

**Figure 23.11. Continuous Conversions**

### 23.3.4 Reference Selection and Analog Gain

The default IADC reference is to use the internal band gap circuit. The analog power supply voltage can also be used as a voltage reference. The reference voltage is selected using the REFSEL field in IADC\_CFGx.

**Table 23.2. Mode Settings**

| Reference | Description         | Normal and High-Speed Mode Voltage Range | High-Accuracy Mode Voltage Range |
|-----------|---------------------|------------------------------------------|----------------------------------|
| VBGR      | Internal            | 1.21V                                    | 1.21V                            |
| VDDX      | Analog Power Supply | AVDD                                     | AVDD                             |
| VREF      | External            | 1.0V - AVDD (1.25V Nominal)              | 1.0V - 1.25V (1.25V Nominal)     |
| VREF2P5   | External            | 1.0V - AVDD (1.25V Nominal)              | 1.0V - 2.5V (2.5V Nominal)       |

**Note:**

- 1. In high-accuracy mode with VREF2P5 selected, the AVDD supply must be at least 3V.

The IADC also has analog gain selection, controlled via the ANALOGGAIN field in IADC\_CFGx. The analog gain can be set to 0.5x, 1x, 2x, 3x, or 4x. Note that 2x, 3x, and 4x gain modes may require slower ADC\_CLK. The analog gain impacts where the full-scale input reading occurs. For example, with a 1.25 V external reference and ANALOGGAIN set to 2x, the analog input to the IADC is multiplied by a factor of 2, and a full-scale reading occurs at  $1.25 \text{ V} / 2 = 0.625 \text{ V}$ . If ANALOGGAIN is set to 0.5x, the full-scale reading of the ADC will not occur until the input reaches 2.5 V. Note that the ADC is only capable of measuring inputs within the supply rails of the device. If the full scale is configured to be greater than the supply voltage, the maximum input will be limited to the supply.

The sampling capacitance ( $C_{\text{sample}}$ ) is changed according to the analog gain setting.

**Table 23.3. Input Sampling Capacitance vs. Analog Gain**

| Analog Gain Setting | Input Sampling Capacitance |
|---------------------|----------------------------|
| 0.5x                | 1 pF                       |
| 1x                  | 2 pF                       |
| 2x                  | 4 pF                       |
| 3x                  | 6 pF                       |
| 4x                  | 8 pF                       |

Given the sampling capacitance and the front-end sampling rate ( $F_{\text{sample}}$ ), the input impedance of the converter can be calculated as:

$$Z_{\text{in}} = 1 / (C_{\text{sample}} * F_{\text{sample}})$$

Note that the input is not sampled when the converter is inactive between conversions and operating with WARMUPMODE = NORMAL or KEEPINSTANDBY with longer intervals between conversion triggers can increase the effective input impedance of the converter.

### 23.3.5 Input and Configuration Selection

The IADC supports measurement on a number of internal and external signals. External signals are routed to GPIO through shared ABUS resources on the device, or (on some devices) through dedicated analog inputs available to the IADC block.

The single queue and the scan queue have separate registers available to select inputs and configurations. The IADC\_SINGLE register is used to select the input and configuration for the single queue. The IADC\_SCANx registers are used to select the inputs and configurations for each of the scan table entries. In both cases, the register contents and setup are similar. The PORTPOS and PINPOS fields are used to select a signal for the positive ADC input, while PORTNEG and PINNEG are used to select a signal for the negative ADC input. The CFG field selects which of the two configuration sets will be used with the input (i.e. configuration options specified in IADC\_CFGx, IADC\_SCALEx, and IADC\_SCHEDx).

To perform single-ended conversions, the PORTNEG field should be set to GND. This indicates that the positive ADC input will be measured with reference to chip ground. PORTPOS and PINPOS should be used to select the desired input signal. The PINNEG field is not used for single-ended conversions.

To perform differential conversions, PORTPOS, PINPOS are used to select the positive input to the ADC, while PORTNEG and PINNEG are used to select the negative input. Note that there are two independent multiplexers in the ADC, and firmware cannot select two signals from the same multiplexer for a differential measurement. The "even" multiplexer consists of all EVEN ABUS selections, Supply voltage options, and GND. The "odd" multiplexer consists of all ODD ABUS selections and GND. One selection from each multiplexer is allowed on the positive and negative input. More detailed examples may be found in [23.3.5.3 ABUS Input Selection Examples](#).

The scan queue has one additional register, IADC\_MASKREQ, to specify which of the 16 possible channel slots will be converted during a scan operation. Each channel in the scan queue is enabled by writing the corresponding bit in the IADC\_MASKREQ register to 1. Enabled channels will be converted in sequence from lowest to highest, during a scan. See [23.3.5.4 Scan Queue](#) for more details on using the scan queue.

#### 23.3.5.1 External GPIO Inputs

GPIO input selections are routed through shared ABUS resources. In order for the IADC to use any GPIO as an input, the IADC must be allocated appropriate analog bus resources in the GPIO\_ABUSALLOC, GPIO\_BBUSALLOC, or GPIO\_CDBUSALLOC registers. For example, if IADC0 will be using both odd and even numbered pins on GPIO port PA, then AEVEN0 and AODD0 in GPIO\_ABUSALLOC could both be set to IADC0. This gives IADC0 access to these two buses. Generally, bus access is set to specific peripherals at configuration time and left alone - it is not normally required to change the bus allocation on the fly. If the IADC requests a pin from a bus that has not been allocated to the IADC, an error will be generated, the PORTALLOCERRIF in IADC\_IF will be set, and any conversion result will be 0. For more details on analog bus structure and capabilities, refer to the GPIO section.

When the appropriate analog buses have been configured to route to the IADC, GPIO selection is a simple matter of programming the desired port and pin into the PORTPOS, PINPOS, PORTNEG, and PINNEG fields. For example, to configure a channel to convert the differential voltage between pins PA5 and PA4, PORTPOS = PORTA, PINPOS = 5, PORTNEG = PORTA, PINNEG = 4. If an invalid selection is made, a polarity error will be generated. More specific examples are described in [23.3.5.3 ABUS Input Selection Examples](#).

### 23.3.5.2 Internal and Dedicated Inputs

Internal signals and dedicated inputs are not routed through the shared ABUS resources. In general, these resources are selected directly by the settings of PORTPOS and PORTNEG, while the PINPOS and PINNEG fields are not used. When PORTPOS is set to SUPPLY, PINPOS is used to select which of the power supplies is connected. To facilitate power supply measurements using internal reference options, higher voltage supplies are attenuated by a factor of 4.

**Table 23.4. Supply Selection (PORTPOS = SUPPLY)**

| PINPOS | Supply Connection | Voltage at Positive Input |
|--------|-------------------|---------------------------|
| 0      | AVDD              | AVDD / 4                  |
| 1      | IOVDD             | IOVDD / 4                 |
| 2      | VSS               | VSS                       |
| 3      | VSS               | VSS                       |
| 4      | DVDD              | DVDD / 4                  |
| 7      | DECOPLE           | DECOPLE                   |

If an internal signal is selected for PORTPOS or PORTNEG, selecting GND on the opposite input will instruct the converter to perform a single-ended conversion. In the case where PORTPOS = GND, the IADC logic will automatically swap the direct input selected by PORTNEG to the positive input of the ADC. Otherwise, a differential conversion is performed with PORTPOS selecting the positive and PORTNEG selecting the negative input.

### 23.3.5.3 ABUS Input Selection Examples

When configuring to measure a single-ended signal through the ABUS, the positive input selection should always point to the desired input, and PORTNEG should be programmed to GND.

Correct configuration examples for single-ended conversions are shown in [Figure 23.12 Single-Ended Port/Pin Selection Odd Channel on page 762](#) and [Figure 23.13 Single-Ended Port/Pin Selection Even Channel on page 762](#). Note that the IADC logic will automatically swap the appropriate multiplexer to the positive input of the ADC.



**Figure 23.12. Single-Ended Port/Pin Selection Odd Channel**



**Figure 23.13. Single-Ended Port/Pin Selection Even Channel**

[Figure 23.14 Single-Ended Port/Pin Selection Polarity Error on page 763](#) shows an example where the PORTPOS input has been configured to GND, with PORTNEG and PINNEG configured for a GPIO pin. This will result in a polarity error (POLARITYERRIF in IADC\_IF will be set) and any conversion result will be 0.



**Figure 23.14. Single-Ended Port/Pin Selection Polarity Error**

Correct configuration examples for differential conversions are shown in [Figure 23.15 Differential Port/Pin Selection without Swap on page 763](#) and [Figure 23.16 Differential Port/Pin Selection with Swap on page 764](#). In both these examples, the inputs were selected from one EVEN multiplexer channel and one ODD multiplexer channel. As with single-ended mode, the IADC logic will automatically swap the multiplexer connections to the IADC input if needed.



**Figure 23.15. Differential Port/Pin Selection without Swap**

**Figure 23.16. Differential Port/Pin Selection with Swap**

[Figure 23.17 Differential Port/Pin Selection Polarity Error on page 764](#) shows an example where both the positive and the negative input selections point to ODD buses. Even though the IADC has been allocated both buses, they both route through the ODD input multiplexer and cannot be measured against one another. This will result in a polarity error (POLARITYERRIF in IADC\_IF will be set) and any conversion result will be 0x7FFF. Likewise, a polarity error will occur if both inputs are selected from EVEN buses.

**Figure 23.17. Differential Port/Pin Selection Polarity Error**

### 23.3.5.4 Scan Queue

The scan queue allows the IADC to automatically convert up to 16 channels in sequence without CPU intervention. Input and configuration selection for each channel in the scan table is specified by the IADC\_SCANx register for that channel (channel 0 is configured with IADC\_SCAN0, channel 1 is configured with IADC\_SCAN1, and so on). The IADC\_MASKREQ register allows software to define which of the scan table entries (IADC\_SCANx) to convert during a scan. For example, channels 0, 1, and 7 can be enabled by writing bits 0, 1, and 7 of IADC\_MASKREQ to 1 (IADC\_MASKREQ = 0x0083).

The IADC\_SCANx registers must be configured when the IADC module is disabled (IADC\_EN\_EN = 0). IADC\_MASKREQ can be written while IADC\_EN\_EN is set to 1. If a scan operation is in progress, MASKREQ will be synchronized and held until the current scan operation has completed. Then MASKREQ is copied into the STMASK register for the next scan operation. IADC\_STMASK is the working copy of the MASKREQ used by the IADC during a scan. MASKREQ will only transfer to STMASK when the scan queue is not scanning and converting the scan table. IADC\_STATUS\_MASKWRITERPENDING can be used by software to see when the MASKREQ write has been transferred to STMASK. Writing a new MASKREQ in the middle of a scan will not corrupt the current scan. Software which writes to MASKREQ during a scan operation must ensure IADC\_STATUS\_MASKWRITERPENDING returns to 0 before updating IADC\_MASKREQ again. [Figure 23.18 MASKREQ Updates on page 765](#) shows a time line of when the MASKREQ write is updated.



**Figure 23.18. MASKREQ Updates**

### 23.3.6 Gain and Offset Correction

The IADC has built in gain and offset correction capabilities. Each of the two configuration groups contains its own correction values stored in the IADC\_SCALEx register, allowing the IADC to automatically apply the appropriate correction for the IADC configuration that is being used.

Gain correction is performed through a fixed-point 16-bit value with a range from 0.75x to 1.2499x. The 3 MSBs of the gain value are not directly writeable. The GAIN3MSB bit in IADC\_SCALEx is used to select between 011 and 100 for the 3 MSBs, and the lower 13 bits are programmed directly into IADC\_SCALEx\_GAIN13LSB. Clearing GAIN3MSB to 0 selects the most significant bits of the gain as 011, representing a range from 0.75x to 0.9999x. Setting GAIN3MSB to 1 selects the most significant bits of the gain as 100, representing a range from 1.00x to 1.2499x.

Offset correction is controlled by the OFFSET field in IADC\_SCALEx. It is important to note that the offset correction does not have a direct 1-to-1 relationship with the LSB of the IADC output, and depends on both the OSR and gain correction settings. The offset correction range is +/- 12.5% of full scale. OFFSET is encoded as a 2's complement, 18-bit number with the LSB representing  $1 / 2^{20}$  of full scale. Thus, bit 8 of OFFSET aligns with bit 0 of the 12-bit IADC output word.

#### 23.3.6.1 Using Production Calibration Parameters

IADC calibration is performed on every device during Silicon Labs production test and production calibration parameters are stored in the flash DI page. The production calibration values are useful for a wide variety of possible IADC configurations, but do not map directly to the offset and gain correction fields in the IADC\_SCALEx registers. Software must calculate the actual offset and gain correction values from the factory calibration values.

### 23.3.6.1.1 Gain Correction

Gain error is measured during production test at various settings of ANALOGGAIN, and stored in the DEVINFO\_IADC0GAIN0 and DEVINFO\_IADC0GAIN1 locations. The GAINCANA1 field is used for 0.5x and 1x ANALOGGAIN settings, while GAINCANA2, GAINCANA3, and GANCANA4 are used for ANALOGGAIN settings of 2x, 3x, and 4x, respectively.

The GAINCANA values are expressed as the full 16-bit fixed-point gain, and must be compressed before writing to the IADC\_SCALEEx register.

#### 23.3.6.1.1.1 Gain Correction in Normal / High Speed Mode

When the IADC is operated in Normal / High Speed mode, a 1st order filter is employed in the decimation. The nominal gain value in these modes for all OSRHS settings is 1.0, or 0x8000 as expressed in the fixed-point 16-bit format. The IADC gain error is designed to be minimal with the digital gain correction set to 1.0 (GAIN3MSB = 1 and GAIN13LSB = 0). Tighter gain error is achieved by adjusting these values in IADC\_SCALEEx. Using this gain correction mechanism will result in a slight increase to the DNL of the converter, which is reduced by higher OSR settings.

To apply a factory-calibrated gain:

1. Read the appropriate GAINCANA field from the DEVINFO locations for the selected ANALOGGAIN.
2. Write the MSB (bit 15) of GAINCANA to GAIN3MSB in IADC\_SCALEEx.
3. Write the 13 LSBs (bits 12-0) of GAINCANA to GAIN13LSB in IADC\_SCALEEx.

#### 23.3.6.1.1.2 Gain Correction in High Accuracy Mode

When the IADC is operated in High Accuracy mode, a 2nd order filter is employed in the decimation. The nominal gain value of the filter is dependent on the OSRHA setting. The gain value stored in DEVINFO space must be adjusted before applying to the IADC\_SCALEEx register.

To apply a factory-calibrated gain:

1. Read the appropriate GAINCANA field from the DEVINFO locations for the selected ANALOGGAIN.
2. Multiply the value by the OSR gain correction factor (`ha_gain`) found in [Table 23.5 Ideal High Accuracy Gain Correction on page 766](#).
3. Write the MSB (bit 15) of the result to GAIN3MSB in IADC\_SCALEEx.
4. Write the 13 LSBs (bits 12-0) of the result to GAIN13LSB in IADC\_SCALEEx.

**Table 23.5. Ideal High Accuracy Gain Correction**

| OSRHA Setting | OSR   | 16-bit OSR Gain Correction ( <code>ha_gain</code> ) |
|---------------|-------|-----------------------------------------------------|
| HIACC16       | 16 x  | 0x7879                                              |
| HIACC32       | 32 x  | 0x7C1F                                              |
| HIACC64       | 64 x  | 0x7E08                                              |
| HIACC92       | 92 x  | 0x7A8E                                              |
| HIACC128      | 128 x | 0x7F02                                              |
| HIACC256      | 256 x | 0x7F80                                              |

### 23.3.6.1.2 Offset Correction

Offset is impacted by the selected ANALOGGAIN and OSR settings in IADC\_CFGx, the GAIN3MSB and GAIN13LSB values in IADC\_SCALEEx, and the voltage reference. Offset is production calibrated for any combination of possibilities, but the OFFSET register value must be calculated for the given situation before it can be effectively used.

### 23.3.6.1.2.1 Offset Correction in Normal Mode

The production offset calibration consists of four 16-bit terms written to the DEVINFO space: OFFSETANA1NORM, OFFSETANA2NORM, OFFSETANA3NORM, and OFFSETANABASE. The following procedures will determine the setting for the OFFSET register based on production calibration values.

**Step 1:** Determine the offset gain adjustment term (off\_gain) based on ANALOGGAIN.

For ANALOGGAIN set to 0.5x or 1x:

$$\text{off\_gain} = 0$$

For ANALOGGAIN set to 2x, 3x, or 4x, off\_gain is calculated as:

$$\text{off\_gain} = \text{OFFSETANA2NORM} * (\text{gain} - 1)$$

The following table summarizes these equations:

**Table 23.6. Offset Gain Adjustment**

| ANALOGGAIN Setting | Analog front-end gain | Offset Gain Adjustment Term (off_gain) |
|--------------------|-----------------------|----------------------------------------|
| ANAGAIN0P5         | 0.5 x                 | 0                                      |
| ANAGAIN1           | 1 x                   | 0                                      |
| ANAGAIN2           | 2 x                   | OFFSETANA2NORM * 1                     |
| ANAGAIN3           | 3 x                   | OFFSETANA2NORM * 2                     |
| ANAGAIN4           | 4 x                   | OFFSETANA2NORM * 3                     |

**Step 2:** Calculate the analog offset adjustment term (off\_ana) based on OSR and off\_gain.

For an OSR of 2x (OSRHS = 0):

$$\text{off\_ana} = \text{OFFSETANA1NORM} + \text{off\_gain}$$

For all other OSR settings, 4x - 64x:

$$\text{off\_ana} = \text{OFFSETANABASE} + 2 * (\text{OFFSETANA3NORM} - \text{off\_gain}) / \text{OSR}$$

The following table expresses these equations:

**Table 23.7. Analog Offset Adjustment**

| OSRHS Setting | OSR  | Analog Offset Adjustment Term (off_ana)          |
|---------------|------|--------------------------------------------------|
| HISPD2        | 2 x  | OFFSETANA1NORM + off_gain                        |
| HISPD4        | 4 x  | OFFSETANABASE + (OFFSETANA3NORM - off_gain) / 2  |
| HISPD8        | 8 x  | OFFSETANABASE + (OFFSETANA3NORM - off_gain) / 4  |
| HISPD16       | 16 x | OFFSETANABASE + (OFFSETANA3NORM - off_gain) / 8  |
| HISPD32       | 32 x | OFFSETANABASE + (OFFSETANA3NORM - off_gain) / 16 |
| HISPD64       | 64 x | OFFSETANABASE + (OFFSETANA3NORM - off_gain) / 32 |

**Step 3:** Compensate for reference voltage differences.

The off\_ana term represents the offset at the input of the ADC, meaning that the reference voltage will have an impact on the magnitude of the offset at the output. Production calibration values are determined with a 1.25 V reference source. If a voltage significantly different than 1.25 V is used for V<sub>REF</sub>, adjust the off\_ana term by a factor of 1.25 / V<sub>REF</sub>.

$$\text{off\_ana} = \text{off\_ana} * (1.25 / V_{\text{REF}})$$

**Step 4:** Calculate total offset by adding the analog offset to the systematic offset.

Systematic offset is a fixed number dependent on OSR, and calculated according to the following equation:

$$\text{off\_sys} = 640 * (256/\text{OSR})$$

Total uncorrected offset (off\_tot) is calculated by:

$$\text{off\_tot} = (\text{off\_ana} * 4 + \text{off\_sys})$$

**Step 5:** Apply gain error correction, if needed.

Before writing the OFFSET field, the total uncorrected offset must be multiplied by the gain calibration factor. If the gain calibration factor is equal to 1.0 (0x8000 in 16-bit hex, or GAIN3MSB = 1 and GAIN13LSB = 0), this step may be skipped. Otherwise, adjust off\_tot according to the following equation:

$$\text{off\_tot} = \text{GAIN\_FACTOR} * (\text{off\_tot} + 0x80000) - 0x80000$$

where GAIN\_FACTOR = GAINCANAn / 32768.

**Step 6:** Write the offset correction value to the OFFSET field.

The OFFSET field holds an 18-bit 2's complement number, which should be the negation of the total offset, or -(off\_tot). Before writing to the SCALE register, any leading sign bits should be masked off to avoid corrupting the programmed gain settings.

$$\text{OFFSET} = 0x3FFF \& (-\text{off\_tot})$$

### 23.3.6.1.2.2 Offset Correction in High Speed Mode

Offset correction for High Speed mode is identical to the procedure for Normal mode, with the exception of the calibration terms used in the DEVINFO space. The same OFFSETANABASE term is used, but OFFSETANA1HISPD, OFFSETANA2HISPD and OFFSETANA3HISPD are used instead of the OFFSETANAxNORM values. Refer to [23.3.6.1.2.1 Offset Correction in Normal Mode](#) for the procedure, replacing OFFSETANAxNORM with OFFSETANAxHISPD.

### 23.3.6.1.2.3 Offset Correction in High Accuracy Mode

The production offset calibration for High Accuracy mode uses two 16-bit terms written to the DEVINFO space: OFFSETANA1HIACC and OFFSETANABASE. The following procedure will determine the setting for the OFFSET register based on production calibration values.

**Step 1:** Calculate the analog offset adjustment term (off\_ana) based on the OSR setting (OSRHA in IADC\_CFGn).

$$\text{off\_ana} = \text{OFFSETANABASE} + \text{OFFSETANA1HIACC} / (2^{\text{OSRHA}})$$

The following table expresses this relationship:

Table 23.8. Analog Offset Adjustment

| OSRHA Setting | OSR   | Analog Offset Adjustment Term (off_ana) |
|---------------|-------|-----------------------------------------|
| HIACC16       | 16 x  | OFFSETANABASE + OFFSETANA1HIACC         |
| HIACC32       | 32 x  | OFFSETANABASE + (OFFSETANA1HIACC / 2)   |
| HIACC64       | 64 x  | OFFSETANABASE + (OFFSETANA1HIACC / 4)   |
| HIACC92       | 92 x  | OFFSETANABASE + (OFFSETANA1HIACC / 8)   |
| HIACC128      | 128 x | OFFSETANABASE + (OFFSETANA1HIACC / 16)  |
| HIACC256      | 256 x | OFFSETANABASE + (OFFSETANA1HIACC / 32)  |

**Step 2:** Compensate for reference voltage differences.

The off\_ana term represents the offset at the input of the ADC, meaning that the reference voltage will have an impact on the magnitude of the offset at the output. Production calibration values are determined with a 1.25 V reference source. If a voltage significantly different than 1.25 V is used for V<sub>REF</sub>, adjust the off\_ana term by a factor of 1.25 / V<sub>REF</sub>.

$$\text{off\_ana} = \text{off\_ana} * (1.25 / V_{\text{REF}})$$

**Step 3:** Calculate total offset by adding the analog offset to the systematic offset.

Systematic offset is a fixed number dependent on OSR, and calculated according to the following equation:

$$\text{off\_sys} = 0x40000 / (\text{OSR} / (\text{OSR}+1))$$

Total uncorrected offset (off\_tot) is calculated by:

$$\text{off\_tot} = (\text{off\_ana} * 4 + \text{off\_sys})$$

**Step 4:** Apply gain error correction.

Before writing the OFFSET field, the total uncorrected offset must be multiplied by the gain calibration factor according to the following equation:

$$\text{off\_tot} = \text{GAIN\_FACTOR} * (\text{off\_tot} + 0x80000) - 0x80000$$

where GAIN\_FACTOR = GAINCANAn / 32768.

**Step 5:** Write the offset correction value to the OFFSET field.

The OFFSET field holds an 18-bit 2's complement number, which should be the negation of the total offset, or -(off\_tot). Before writing to the SCALE register, any leading sign bits should be masked off to avoid corrupting the programmed gain settings.

$$\text{OFFSET} = 0x3FFF & (-\text{off\_tot})$$

### 23.3.6.2 Calibration

Calibration can be performed in-system to correct for external errors and provide more accurate measurements. The general calibration procedure is as follows:

1. Configure the ADC to the desired mode, OSR, analog gain settings, reference source, etc.
2. Force the IADC to use bipolar output for the conversion: IADC\_CFGx\_TWOSCOMPL = FORCEBIPOLAR.
3. Set the initial offset to the maximum negative value (IADC\_SCALEx\_OFFSET = 0x20000), and the initial gain to 1.0 (GAIN3MSB = 1, GAIN13LSB = 0x0000). This will prevent output saturation when measuring full scale.
4. Apply a full-scale positive input to the IADC and perform a conversion (*result\_fullscale*). Multiple conversions can be performed and averaged together to reduce any system-level noise.
5. Apply a zero input to the IADC and perform a conversion (*result\_zero*). Multiple conversions can be performed and averaged together to reduce any system-level noise.
6. Calculate the gain correction factor: Divide the expected value by the difference in the measured values (*result\_fullscale* - *result\_zero*). Note that the offset adjustment in Step 3 will be canceled out by this calculation.
7. Write the gain correction factor to the IADC using the GAIN3MSB and GAIN13LSB fields in IADC\_SCALEx.
8. Set IADC\_SCALEx\_OFFSET to 0x00000 in preparation for the offset calibration.
9. Apply the desired zero voltage to the IADC input and perform a conversion (*result\_offset*). Multiple conversions can be performed and averaged together to reduce any system-level noise.
10. Multiply *result\_offset* to convert to a 20-bit value (*result\_offset\_20*). For example, a 12-bit result should be multiplied by 256.
11. Negate *result\_offset\_20* and write the value to IADC\_SCALEx\_OFFSET.

Note that the IADC\_SCALEx\_OFFSET field is 18 bits. If the result is greater than  $(2^{17} - 1)$  or less than  $(-2^{17})$ , the offset is too large to be corrected.

### 23.3.7 Output Data FIFOs

The single and scan queues each have a eight-word data FIFO. Conversions results are written to the output data FIFO associated with the queue. Single queue results are written to the single FIFO and scan queue results are written to the scan data FIFO. The two queues are identical in operation, but independent.

Conversion results are read from the single FIFO using IADC\_SINGLEFIFODATA. Reading SINGLEFIFODATA will pop the oldest result from the FIFO. It is also possible to read the most recent valid data word using IADC\_SINGLEDATA. Reading SINGLEDATA does not pop a conversion from the FIFO. Similarly, the scan FIFO results are read with IADC\_SCANFIFODATA, which reads the oldest result and pops the FIFO. The most recent scan result can be read using IADC\_SCANDATA.

When the single FIFO has valid data, the SINGLEFIFODV flag in IADC\_STATUS is set to 1. When the scan FIFO has valid data SCANFIFODV in IADC\_STATUS is set to 1. These data valid status bits are cleared automatically whenever the associated FIFO is empty. For more granular FIFO status, the number of data words present in the FIFO is indicated in IADC\_SINGLEFIFOSTAT (for single FIFO) or IADC\_SCANFIFOSTAT (for scan FIFO).

A programmable data level watermark is also available for the FIFOs, allowing hardware to trigger interrupts or DMA operations when a specified number of conversion results are available. The DVL field in register SINGLEFIFOFCFG or SCANFIFOFCFG sets the watermark level, between 1 and 4 conversions. If the number of valid entries in the FIFO reaches or exceeds the level set in DVL, the SINGLEFIFODVLIF (for single FIFO) or SCANFIFODVLIF (for scan FIFO) flag in the IADC\_IF register will be set to 1. If enabled, an interrupt or DMA request will be triggered when the flag is set.

By default, DMA requests are turned off for operation in EM2 or EM3. However, the DMAWFIFOSINGLE or DMAWFIFOSCAN bits in SINGLEFIFOFCFG or SCANFIFOFCFG may be used to enable DMA operations in these lower energy modes.

Overflow and underflow status flags are also available in IADC\_IF. An overflow condition occurs when an IADC conversion completes, but the associated FIFO is already full. In an overflow case the SINGLEFIFOOFIF or SCANFIFOOFIF flag will be set. The most recent conversion will still be available in the SINGLEDATA or SCANDATA register, but the FIFO will not be updated with the new data. An underflow condition occurs when software or hardware attempts to read from an empty FIFO. In an underflow case the SINGLEFIFOUIFIF or SCANFIFOUIFIF flag will be set.

### 23.3.7.1 Data Alignment and Channel ID

The IADC has data alignment options and the ability to include a channel ID along with the conversion data. For the single queue, alignment and channel ID are configured in the IADC\_SINGLEFIFO CFG register. For the scan queue, alignment and channel ID are configured in the IADC\_SCANFIFO CFG register.

The ALIGNMENT bit field specifies the data justification and the number of data bits as shown in [Figure 23.19 Data Alignment on page 771](#). By default, the converter will produce 12-bit right-justified data, corresponding to ALIGNMENT = RIGHT12.



**Figure 23.19. Data Alignment**

The SHOWID bit controls whether the conversion channel ID is included in the output data word. This option is primarily used with the scan FIFO to help software determine which channel each conversion result came from. If SHOWID is enabled for single conversions, the ID will always be set to 0x20. [Figure 23.20 Data Alignment With ID on page 771](#) shows output data formatting including the ID, when SHOWID = 1.



ID for single queue result is 0x20

**Figure 23.20. Data Alignment With ID**

### 23.3.7.2 Output Polarity

The output polarity of the IADC is controlled by the TWOSCOMPL field in the IADC\_CFGx register. The IADC supports unipolar and bipolar output formatting independent of the input configuration. By default, the TWOSCOMPL field is set to AUTO, meaning that single-ended conversions will produce unipolar output, and differential conversions will produce bipolar output. The polarity can be forced to unipolar or bipolar mode by setting TWOSCOMPL to FORCEUNIPOLAR or FORCEBIPOLAR, respectively.

Unipolar samples are unsigned integers representing zero to positive full-scale. Bipolar samples are two's-complement signed integers, representing negative full-scale to positive full-scale. Using unipolar mode on a differential input signal allows for more dynamic range when the signal is positive, but will saturate to zero when the signal is negative.

**Note:** If bipolar output is used with a single-ended input configuration, it is possible to see negative output values when the input is close to ground. However, the input voltage is still limited by the supply range of the device.

### 23.3.7.3 Digital Accumulation and Averaging

The IADC may optionally accumulate and average several conversion results before posting an output word to the FIFO. Digital averaging is controlled by the DIGAVG field in the IADC\_CFGx register. It can be configured to average 1, 2, 4, 8, or 16 samples. The IADC will collect the number of samples specified by DIGAVG on the selected channel slot back-to-back, and produce only one averaged output word.

### 23.3.7.4 Output Resolution

The usable output resolution of the IADC is a minimum of 12 bits, when the oversampling ratio is set to 2 and no digital averaging is used (DIGAVG = AVG1). An extra bit of output resolution is produced for every power of 2 increase in either of these settings. In other words, the output resolution of the ADC can be determined as:

$$\text{Output Resolution} = 11 + \log_2(\text{OversamplingRatio} \times \text{DigitalAveraging})$$

The MSB is always left-aligned within the DATA field, and the output word will be truncated to 12, 16, or 20 bits, as shown in [Figure 23.19 Data Alignment on page 771](#) and [Figure 23.20 Data Alignment With ID on page 771](#). When using 16 or 20 bit alignment with lower oversampling ratio and digital averaging settings, LSBs of the output can contain residual effects of the offset and gain computation. These residual effects do not represent additional information about the input signal. Any extra LSBs can be masked to 0 by software.

**Table 23.9. Output Resolution Masking Examples**

| Alignment Setting | Oversampling Ratio | Digital Averaging | Number of averaged samples | Output Resolution | Recommended Mask for DATA field |
|-------------------|--------------------|-------------------|----------------------------|-------------------|---------------------------------|
| 16-bit            | 2x                 | 1x                | 2                          | 12 bits           | 0xFFFF0                         |
| 16-bit            | 8x                 | 2x                | 16                         | 15 bits           | 0xFFFE                          |
| 20-bit            | 2x                 | 1x                | 2                          | 12 bits           | 0xFFFF00                        |
| 20-bit            | 16x                | 4x                | 64                         | 17 bits           | 0xFFFF8                         |

### 23.3.7.5 Flushing the FIFOs

Each FIFO has a command bit in the IADC\_CMD register that can be used to trigger a FIFO flush. The FIFO data may be flushed independently for each queue. To flush a FIFO:

1. The IADC must be enabled with the clock running.
2. Disable the queue associated with the FIFO using the SCANSTOP or SINGLESTOP bits in the IADC\_CMD register.
3. Ensure the queue is disabled by reading the associated flag in the IADC\_STATUS register (SINGLEQEN or SCANQEN).
4. Set the command bit to flush the desired FIFO (SINGLEIFOFLUSH or SCANIFOFLUSH) in the IADC\_CMD register.
5. Wait for the corresponding status bit (SINGLEIFOFLUSHING or SCANIFOFLUSHING) in IADC\_STATUS to go low.

### 23.3.8 Window Compare

The IADC has a window comparison unit that can trigger interrupts conditional on the output data of the converter. The window comparison unit has two thresholds - greater than or equal (ADGT), and less than or equal (ADLT), which are programmable through the IADC\_CMPTH register. The ADGT and ADLT thresholds always use a 16 bit, left-justified format, regardless of the format specified by the FIFO. The 12-bit conversion result will be compared against the upper 12 bits of the window comparator.

The window comparison unit is active on the ADC output on a conversion-by-conversion basis, and is shared between the two FIFOs. It is not possible to set different window comparison thresholds for different channels or for each FIFO. However, each channel specified in the IADC has a CMP bit field to enable the window comparison on results from that channel. For example, it is possible to only apply the window comparison and associated interrupt to scan channel #3 by setting the CMP field in IADC\_SCAN3 to 1. When the CMP field associated with a channel is 0, the window comparator will not be active for results from that channel.

The window comparator supports conditional triggering on output results which are inside or outside a specified window. When ADLT is greater than or equal to ADGT, the comparator will trigger on an "inside" condition, or when DATA  $\leq$  ADLT **and** DATA  $\geq$  GT. When ADLT is less than ADGT, the comparator will trigger on an "outside" condition, or when DATA  $\leq$  ADLT **or** DATA  $\geq$  GT.

[Figure 23.21 Window Comparison Examples on page 773](#) shows different configurations of the ADLT and ADGT values and the resulting windows. When the window comparator detects that the appropriate conditions are met (shown by the shaded region in the figure), it will generate an interrupt via the SINGLECMPIF flag for conversions on the single queue, or via the SCANCMPIF flag for conversions on the scan queue.



**Figure 23.21. Window Comparison Examples**

### 23.3.9 Interrupts

Interrupts are enabled in the IADC\_IEN register, allowing interrupts to be generated on several different IADC conditions. Each of the flags in IADC\_IF has a corresponding enable bit in the IADC\_IEN register. A brief overview of the available interrupt sources is shown in the list below; more details can be found in the relevant sections of this chapter.

- SINGLEFIFODVLIF - The single FIFO watermark specified in SINGLEFIFOFCFG\_DVL has been reached or exceeded.
- SCANFIFODVLIF - The scan FIFO watermark specified in SCANFIFOFCFG\_DVL has been reached or exceeded.
- SINGLECMPIF - A conversion result from the single queue tripped the window comparator.
- SCANCMPIF - A conversion result from the scan queue tripped the window comparator.
- SCANENTRYDONEIF - A scan queue conversion has completed.
- SCANTABLEDONEIF - A scan queue operation has completed (all channels specified in the scan mask have been converted once).
- POLARITYERRIF - A channel polarity selection error has occurred (two channels from the EVEN multiplexer or two channels from the ODD multiplexer were selected for positive and negative inputs).
- PORTALLOCERRIF - A port allocation error has occurred (a pin not allocated to the IADC in the GPIO bus allocation registers was requested).
- SINGLEFIFOOFIF - A single FIFO overflow has occurred.
- SCANFIFOOFIF - A scan FIFO overflow has occurred.
- SINGLEFIFOUFFIF - A single FIFO underflow has occurred.
- SCANFIFOUFFIF - A scan FIFO underflow has occurred.
- EM23ABORTERRORIF - The system entered EM2 or EM3 while the IADC was converting and using a clock not supported in EM2 or EM3.

Hardware sets the interrupt flags in IADC\_IF, and the flags remain set (sticky) until cleared by software. The interrupt flags should be cleared before enabling the IADC to remove any previous interrupt history. Clearing or setting interrupt bits can be done by writing to IADC\_IF with a set or clear mask.

### 23.4 IADC Register Map

The offset register address is relative to the registers base address.

| Offset | Name                | Type        | Description                         |
|--------|---------------------|-------------|-------------------------------------|
| 0x000  | IADC_IPVERSION      | R           | IPVERSION                           |
| 0x004  | IADC_EN             | RW ENABLE   | Enable                              |
| 0x008  | IADC_CTRL           | RW CONFIG   | Control                             |
| 0x00C  | IADC_CMD            | W SYNC      | Command                             |
| 0x010  | IADC_TIMER          | RW CONFIG   | Timer                               |
| 0x014  | IADC_STATUS         | RH          | Status                              |
| 0x018  | IADC_MASKREQ        | RW SYNC     | Mask Request                        |
| 0x01C  | IADC_STMASK         | RH SYNC     | Scan Table Mask                     |
| 0x020  | IADC_CMPTHR         | RW CONFIG   | Digital Window Comparator Threshold |
| 0x024  | IADC_IF             | RWH INTFLAG | Interrupt Flags                     |
| 0x028  | IADC_IEN            | RW          | Interrupt Enable                    |
| 0x02C  | IADC_TRIGGER        | RW CONFIG   | Trigger                             |
| 0x048  | IADC_CFGx           | RW CONFIG   | Configuration                       |
| 0x050  | IADC_SCALEx         | RW CONFIG   | Scaling                             |
| 0x054  | IADC_SCHEDx         | RW CONFIG   | Scheduling                          |
| 0x070  | IADC_SINGLEFIFOCFG  | RW CONFIG   | Single FIFO Configuration           |
| 0x074  | IADC_SINGLEFIFODATA | RH(r)       | Single FIFO DATA                    |
| 0x078  | IADC_SINGLEFIFOSTAT | RH          | Single FIFO Status                  |
| 0x07C  | IADC_SINGLEDATA     | RH SYNC     | Single Data                         |
| 0x080  | IADC_SCANFIFO CFG   | RW CONFIG   | Scan FIFO Configuration             |
| 0x084  | IADC_SCANFIFODATA   | RH(r)       | Scan FIFO Read Data                 |
| 0x088  | IADC_SCANFIFOSTAT   | RH          | Scan FIFO Status                    |
| 0x08C  | IADC_SCANDATA       | RH SYNC     | Scan Data                           |
| 0x098  | IADC_SINGLE         | RW SYNC     | Single Queue Port Selection         |
| 0x0A0  | IADC_SCANx          | RW CONFIG   | SCAN Entry                          |
| 0x1000 | IADC_IPVERSION_SET  | R           | IPVERSION                           |
| 0x1004 | IADC_EN_SET         | RW ENABLE   | Enable                              |
| 0x1008 | IADC_CTRL_SET       | RW CONFIG   | Control                             |
| 0x100C | IADC_CMD_SET        | W SYNC      | Command                             |
| 0x1010 | IADC_TIMER_SET      | RW CONFIG   | Timer                               |
| 0x1014 | IADC_STATUS_SET     | RH          | Status                              |
| 0x1018 | IADC_MASKREQ_SET    | RW SYNC     | Mask Request                        |
| 0x101C | IADC_STMASK_SET     | RH SYNC     | Scan Table Mask                     |
| 0x1020 | IADC_CMPTHR_SET     | RW CONFIG   | Digital Window Comparator Threshold |
| 0x1024 | IADC_IF_SET         | RWH INTFLAG | Interrupt Flags                     |

| Offset | Name                    | Type        | Description                         |
|--------|-------------------------|-------------|-------------------------------------|
| 0x1028 | IADC_IEN_SET            | RW          | Interrupt Enable                    |
| 0x102C | IADC_TRIGGER_SET        | RW CONFIG   | Trigger                             |
| 0x1048 | IADC_CFGx_SET           | RW CONFIG   | Configuration                       |
| 0x1050 | IADC_SCALEx_SET         | RW CONFIG   | Scaling                             |
| 0x1054 | IADC_SCHEDx_SET         | RW CONFIG   | Scheduling                          |
| 0x1070 | IADC_SINGLEFIFOCFG_SET  | RW CONFIG   | Single FIFO Configuration           |
| 0x1074 | IADC_SINGLEFIFODATA_SET | RH(r)       | Single FIFO DATA                    |
| 0x1078 | IADC_SINGLEFIFOSTAT_SET | RH          | Single FIFO Status                  |
| 0x107C | IADC_SINGLEDATA_SET     | RH SYNC     | Single Data                         |
| 0x1080 | IADC_SCANFIFOCFG_SET    | RW CONFIG   | Scan FIFO Configuration             |
| 0x1084 | IADC_SCANFIFODATA_SET   | RH(r)       | Scan FIFO Read Data                 |
| 0x1088 | IADC_SCANFIFOSTAT_SET   | RH          | Scan FIFO Status                    |
| 0x108C | IADC_SCANDATA_SET       | RH SYNC     | Scan Data                           |
| 0x1098 | IADC_SINGLE_SET         | RW SYNC     | Single Queue Port Selection         |
| 0x10A0 | IADC_SCANx_SET          | RW CONFIG   | SCAN Entry                          |
| 0x2000 | IADC_IPVERSION_CLR      | R           | IPVERSION                           |
| 0x2004 | IADC_EN_CLR             | RW ENABLE   | Enable                              |
| 0x2008 | IADC_CTRL_CLR           | RW CONFIG   | Control                             |
| 0x200C | IADC_CMD_CLR            | W SYNC      | Command                             |
| 0x2010 | IADC_TIMER_CLR          | RW CONFIG   | Timer                               |
| 0x2014 | IADC_STATUS_CLR         | RH          | Status                              |
| 0x2018 | IADC_MASKREQ_CLR        | RW SYNC     | Mask Request                        |
| 0x201C | IADC_STMASK_CLR         | RH SYNC     | Scan Table Mask                     |
| 0x2020 | IADC_CMPTHR_CLR         | RW CONFIG   | Digital Window Comparator Threshold |
| 0x2024 | IADC_IF_CLR             | RWH INTFLAG | Interrupt Flags                     |
| 0x2028 | IADC_IEN_CLR            | RW          | Interrupt Enable                    |
| 0x202C | IADC_TRIGGER_CLR        | RW CONFIG   | Trigger                             |
| 0x2048 | IADC_CFGx_CLR           | RW CONFIG   | Configuration                       |
| 0x2050 | IADC_SCALEx_CLR         | RW CONFIG   | Scaling                             |
| 0x2054 | IADC_SCHEDx_CLR         | RW CONFIG   | Scheduling                          |
| 0x2070 | IADC_SINGLEFIFOCFG_CLR  | RW CONFIG   | Single FIFO Configuration           |
| 0x2074 | IADC_SINGLEFIFODATA_CLR | RH(r)       | Single FIFO DATA                    |
| 0x2078 | IADC_SINGLEFIFOSTAT_CLR | RH          | Single FIFO Status                  |
| 0x207C | IADC_SINGLEDATA_CLR     | RH SYNC     | Single Data                         |
| 0x2080 | IADC_SCANFIFOCFG_CLR    | RW CONFIG   | Scan FIFO Configuration             |
| 0x2084 | IADC_SCANFIFODATA_CLR   | RH(r)       | Scan FIFO Read Data                 |
| 0x2088 | IADC_SCANFIFOSTAT_CLR   | RH          | Scan FIFO Status                    |

| Offset | Name                     | Type        | Description                         |
|--------|--------------------------|-------------|-------------------------------------|
| 0x208C | IADC_SCANDATA_CLR        | RH SYNC     | Scan Data                           |
| 0x2098 | IADC_SINGLE_CLR          | RW SYNC     | Single Queue Port Selection         |
| 0x20A0 | IADC_SCANx_CLR           | RW CONFIG   | SCAN Entry                          |
| 0x3000 | IADC_IPVERSION_TGL       | R           | IPVERSION                           |
| 0x3004 | IADC_EN_TGL              | RW ENABLE   | Enable                              |
| 0x3008 | IADC_CTRL_TGL            | RW CONFIG   | Control                             |
| 0x300C | IADC_CMD_TGL             | W SYNC      | Command                             |
| 0x3010 | IADC_TIMER_TGL           | RW CONFIG   | Timer                               |
| 0x3014 | IADC_STATUS_TGL          | RH          | Status                              |
| 0x3018 | IADC_MASKREQ_TGL         | RW SYNC     | Mask Request                        |
| 0x301C | IADC_STMASK_TGL          | RH SYNC     | Scan Table Mask                     |
| 0x3020 | IADC_CMPTHR_TGL          | RW CONFIG   | Digital Window Comparator Threshold |
| 0x3024 | IADC_IF_TGL              | RWH INTFLAG | Interrupt Flags                     |
| 0x3028 | IADC_IEN_TGL             | RW          | Interrupt Enable                    |
| 0x302C | IADC_TRIGGER_TGL         | RW CONFIG   | Trigger                             |
| 0x3048 | IADC_CFGx_TGL            | RW CONFIG   | Configuration                       |
| 0x3050 | IADC_SCALEx_TGL          | RW CONFIG   | Scaling                             |
| 0x3054 | IADC_SCHEDx_TGL          | RW CONFIG   | Scheduling                          |
| 0x3070 | IADC_SINGLEFIFO CFG_TGL  | RW CONFIG   | Single FIFO Configuration           |
| 0x3074 | IADC_SINGLEFIFO DATA_TGL | RH(r)       | Single FIFO DATA                    |
| 0x3078 | IADC_SINGLEFIFO STAT_TGL | RH          | Single FIFO Status                  |
| 0x307C | IADC_SINGLEDATA_TGL      | RH SYNC     | Single Data                         |
| 0x3080 | IADC_SCANFIFO CFG_TGL    | RW CONFIG   | Scan FIFO Configuration             |
| 0x3084 | IADC_SCANFIFO DATA_TGL   | RH(r)       | Scan FIFO Read Data                 |
| 0x3088 | IADC_SCANFIFO STAT_TGL   | RH          | Scan FIFO Status                    |
| 0x308C | IADC_SCANDATA_TGL        | RH SYNC     | Scan Data                           |
| 0x3098 | IADC_SINGLE_TGL          | RW SYNC     | Single Queue Port Selection         |
| 0x30A0 | IADC_SCANx_TGL           | RW CONFIG   | SCAN Entry                          |

## 23.5 IADC Register Description

### 23.5.1 IADC\_IPVERSION - IPVERSION

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x000  | 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 |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|----------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x3   | R      | <b>IP version ID</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                      |

### 23.5.2 IADC\_EN - Enable

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |     |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|-----|--|--|
| 0x004  | 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 | 0x0 | 0x0 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |     |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |     |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |     |  |  |

| Bit                                                                                                                                                                                                                     | Name      | Reset                                                                                                                                                                      | Access | Description                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:2                                                                                                                                                                                                                    | Reserved  | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                                                       | DISABLING | 0x0                                                                                                                                                                        | R      | <b>Disablement busy status</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| When EN is cleared, DISABLING status is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS and FIFOs. |           |                                                                                                                                                                            |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                       | EN        | 0x0                                                                                                                                                                        | RW     | <b>Enable IADC Module</b>      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| The EN bit enables the module. Software should write to CONFIG type registers before setting the EN bit. Software should write to SYNC type registers only after setting the EN bit.                                    |           |                                                                                                                                                                            |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Value                                                                                                                                                                                                                   | Mode      | Description                                                                                                                                                                |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                       | DISABLE   | Disable                                                                                                                                                                    |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                                                       | ENABLE    | Enable                                                                                                                                                                     |        |                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 23.5.3 IADC\_CTRL - Control

| Offset | Bit Position |    |     |    |    |    |    |    |    |    |    |          |     |    |    |    |    |    |    |    |    |    |   |   |   |                |                |               |
|--------|--------------|----|-----|----|----|----|----|----|----|----|----|----------|-----|----|----|----|----|----|----|----|----|----|---|---|---|----------------|----------------|---------------|
| 0x008  | 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             |
| Reset  |              |    | 0x0 |    |    |    |    |    |    |    |    | 0x0      |     |    |    |    |    |    |    |    |    |    |   |   |   | 0x0            | 0x0            |               |
| Access |              | RW |     |    |    |    |    |    |    |    |    | RW       | 0x0 |    |    |    |    |    |    |    |    |    |   |   |   | RW             | RW             |               |
| Name   | HSCLKRATE    |    |     |    |    |    |    |    |    |    |    | TIMEBASE |     |    |    |    |    |    |    |    |    |    |   |   |   | WARMUPMODE     | DBGHALT        |               |
|        |              |    |     |    |    |    |    |    |    |    |    |          |     |    |    |    |    |    |    |    |    |    |   |   |   | ADCCLKSUSPEND1 | ADCCLKSUSPEND0 | EM23WUCONVERT |

| Bit   | Name       | Reset         | Access | Description                                                                                                                                                                                                                |
|-------|------------|---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved   |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                          |
| 30:28 | HSCLKRATE  | 0x0           | RW     | <b>High Speed Clock Rate</b><br><br>Ratio to divide incoming CLK_CMU_ADC clock by. The resulting clock (CLK_SRC_ADC) must be 40 MHz or less.                                                                               |
|       | Value      | Mode          |        | Description                                                                                                                                                                                                                |
|       | 0          | DIV1          |        | Use CMU_CLK_ADC directly. The source clock must be 40 MHz or less.                                                                                                                                                         |
|       | 1          | DIV2          |        | Divide CMU_CLK_ADC by 2 before using it. The resulting CLK_SRC_ADC must be 40 MHz or less.                                                                                                                                 |
|       | 2          | DIV3          |        | Divide CMU_CLK_ADC by 3 before using it. The resulting CLK_SRC_ADC must be 40 MHz or less.                                                                                                                                 |
|       | 3          | DIV4          |        | Divide CMU_CLK_ADC by 4 before using it. The resulting CLK_SRC_ADC must be 40 MHz or less.                                                                                                                                 |
| 27:23 | Reserved   |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                          |
| 22:16 | TIMEBASE   | 0x0           | RW     | <b>Time Base</b><br><br>ADC clock cycles (TIMEBASE + 1) needed to generate a 1 us interval for warm up and start up timing. Does not allow less than 2 cycles. A setting of 0x0 (1 cycle) is replaced with 0x1 (2 cycles). |
| 15:6  | Reserved   |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                          |
| 5:4   | WARMUPMODE | 0x0           | RW     | <b>Warmup Mode</b><br><br>Select the warmup mode for the ADC.                                                                                                                                                              |
|       | Value      | Mode          |        | Description                                                                                                                                                                                                                |
|       | 0          | NORMAL        |        | Shut down the IADC after conversions have completed.                                                                                                                                                                       |
|       | 1          | KEEPINSTANDBY |        | Switch to standby mode after conversions have completed. The next warmup time will require 1us.                                                                                                                            |
|       | 2          | KEEPWARM      |        | Keep IADC fully powered after conversions have completed.                                                                                                                                                                  |
| 3     | DBGHALT    | 0x0           | RW     | <b>Debug Halt</b>                                                                                                                                                                                                          |

| Bit                                                                                                                                                                                                                                                                                                            | Name           | Reset     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADC behavior when halted by debugger.                                                                                                                                                                                                                                                                          |                |           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                | Value          | Mode      |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                | 0              | NORMAL    |        | Continue operation as normal during debug mode                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                | 1              | HALT      |        | Complete the current conversion and then halt during debug mode                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2                                                                                                                                                                                                                                                                                                              | ADCCLKSUSPEND1 | 0x0       | RW     | <b>ADC_CLK Suspend - PRS1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| This only functions with single trigger select set to PRSPOS or PRSNEG. In EM0 and EM1, this gates the local clock while clock source remains running. In EM2 and EM3, this disables the clock source until the PRSPOS or PRSNEG event is detected. This bit has no effect if the local IADC timer is running. |                |           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                | Value          | Mode      |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                | 0              | PRSWUDIS  |        | Normal mode which does not disable the ADC_CLK.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                | 1              | PRSWUEN   |        | ADCCLKWUEN will gate off ADC_CLK until the trigger is detected provided the internal timer is not selected as the trigger. Once the trigger is detected the ADC_CLK will be started, the band gap will be started, the ADC will be warmed up, and the SCAN Table and the Single entry will be converted. Once the conversions are done, the ADC_CLK will be gated off.                                                                                                                       |
| 1                                                                                                                                                                                                                                                                                                              | ADCCLKSUSPEND0 | 0x0       | RW     | <b>ADC_CLK Suspend - PRS0</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| This only functions with scan trigger select set to PRSPOS or PRSNEG. In EM0 and EM1, this gates the local clock while clock source remains running. In EM2 and EM3, this disables the clock source until the PRSPOS or PRSNEG event is detected. This bit has no effect if the local IADC timer is running.   |                |           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                | Value          | Mode      |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                | 0              | PRSWUDIS  |        | Normal mode which does not disable the ADC_CLK.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                | 1              | PRSWUEN   |        | ADCCLKWUEN will gate off ADC_CLK until the trigger is detected provided the internal timer is not selected as the trigger. Once the trigger is detected the ADC_CLK will be started, the band gap will be started, the ADC will be warmed up, and the SCAN Table and the Single entry will be converted. Once the conversions are done, the ADC_CLK will be gated off.                                                                                                                       |
| 0                                                                                                                                                                                                                                                                                                              | EM23WUCONVERT  | 0x0       | RW     | <b>EM23 Wakeup on Conversion</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| EM23 wake up on conversion                                                                                                                                                                                                                                                                                     |                |           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                | Value          | Mode      |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                | 0              | WUDVL     |        | When using suspend mode, conversions performed in EM2 or EM3 should not wake up the DMA until the FIFO's DVL setting is reached. This saves more power for large OSR settings or infrequent sampling.                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                | 1              | WUCONVERT |        | When using suspend mode, conversions performed in EM2 or EM3 will wake up the DMA and keep it awake until the conversions are done, regardless of the DVL setting. This mode burns more power, but it is useful when the conversion rate is faster than the time for the DMA to cycle through wake up and going back to sleep as it converts more than 4 scan table entries. Without using the wake up on conversion mode, the FIFO may overflow while the DMA is going in and out of sleep. |

#### **23.5.4 IADC CMD - Command**

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                                                                                                                                                                            |
|-------|-----------------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                      |
| 25    | SCANIFOFLUSH    | 0x0   | W(nB)  | <b>Flush the Scan FIFO</b><br><br>Flush the Scan FIFO. The IADC must be enabled, not suspended, and the IADC clock must be running. Operation has completed when STATUS.SCANIFOFLUSHING has gone low. The scan queue should be disabled. Any incoming scan queue data will be discarded during the flush.                              |
| 24    | SINGLEFIFOFLUSH | 0x0   | W(nB)  | <b>Flush the Single FIFO</b><br><br>Flush the Single FIFO. The IADC must be enabled, not suspended, and the IADC clock must be running. Operation has completed when STATUS.SINGLEFIFOFLUSHING has gone low. The Single queue should be disabled. Any incoming single queue data will be discarded during the flush.                   |
| 23:18 | Reserved        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                      |
| 17    | TIMERDIS        | 0x0   | W(nB)  | <b>Timer Disable</b><br><br>Disable the local timer and reset the counter to timer reload value.                                                                                                                                                                                                                                       |
| 16    | TIMEREN         | 0x0   | W(nB)  | <b>Timer Enable</b><br><br>Enable the local timer.                                                                                                                                                                                                                                                                                     |
| 15:5  | Reserved        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                      |
| 4     | SCANSTOP        | 0x0   | W(nB)  | <b>Scan Queue Stop</b><br><br>Stop the Scan queue. Disables Scan triggers and clears pending conversions in the Scan queue. Any conversion that has already started will continue until it is complete. If the scan queue is stopped before all entries of the scan table have completed, the remaining entries will not be converted. |
| 3     | SCANSTART       | 0x0   | W(nB)  | <b>Scan Queue Start</b><br><br>Start the Scan queue. Enables triggering of the Scan queue.                                                                                                                                                                                                                                             |
| 2     | Reserved        |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                      |
| 1     | SINGLESTOP      | 0x0   | W(nB)  | <b>Single Queue Stop</b><br><br>Stop the Single queue. Disables Single queue triggers and clears pending conversions in the Single queue. Any conversion that has already started will continue until it is complete.                                                                                                                  |
| 0     | SINGLESTART     | 0x0   | W(nB)  | <b>Single Queue Start</b>                                                                                                                                                                                                                                                                                                              |

| Bit                                                             | Name | Reset | Access | Description |
|-----------------------------------------------------------------|------|-------|--------|-------------|
| Start the Single queue. Enables triggering of the Single queue. |      |       |        |             |

**23.5.5 IADC\_TIMER - Timer**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |       |     |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-------|-----|---|---|---|---|---|---|---|
| 0x010  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |       | 0x0 |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |       | RW  |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | TIMER |     |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | TIMER    | 0x0   | RW     | <b>Timer Period</b><br><br>Number of CLK_SRC_ADC cycles per timer event.                                                                                                          |

## 23.5.6 IADC\_STATUS - Status

| Offset | Bit Position |          |                     |                    |             |                    |                      |              |                |            |                    |          |                      |            |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----------|---------------------|--------------------|-------------|--------------------|----------------------|--------------|----------------|------------|--------------------|----------|----------------------|------------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset  | 31           | 29       | 28                  | 27                 | 26          | 25                 | 23                   | 22           | 20             | 19         | 18                 | 17       | 16                   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |
| Access | R            | R        | 0x0                 | 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 |
| Name   | ADCWARM      | SYNCBUSY | MASKREQWRITEPENDING | SINGLEWRITEPENDING | TIMERACTIVE | SCAN FIFO FLUSHING | SINGLE FIFO FLUSHING | SCAN FIFO DV | SINGLE FIFO DV | CONVERTING | SCAN QUEUE PENDING | SCAN QEN | SINGLE QUEUE PENDING | SINGLE QEN |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name                 | Reset                                                                                                                                                                             | Access | Description                                                                                                                                                                                                                                         |
|-------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                                                                                     |
| 30    | ADCWARM              | 0x0                                                                                                                                                                               | R      | <b>ADCWARM</b><br><br>The ADC analog front end and reference require a delay before converting when coming from a powered down or stand-by state. This status bit indicates that the analog front end and reference are ready.                      |
| 29:25 | Reserved             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                                                                                     |
| 24    | SYNCBUSY             | 0x0                                                                                                                                                                               | R      | <b>SYNCBUSY</b><br><br>Indicates synchronization ongoing                                                                                                                                                                                            |
| 23:22 | Reserved             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                                                                                     |
| 21    | MASKREQWRITE-PENDING | 0x0                                                                                                                                                                               | R      | <b>MASKREQ write pending</b><br><br>A write to MASKREQ is pending. The ADC converts using a local working mask register, and only transfers MASKREQ to the local working version when the SCAN queue is not converting.                             |
| 20    | SINGLEWRITEPEND-ING  | 0x0                                                                                                                                                                               | R      | <b>SINGLE write pending</b><br><br>The SINGLE register write is pending. The ADC converts using a local working version of the SINGLE register, and only transfer SINGLE to the local working version when the SINGLE queue is not being converted. |
| 19:17 | Reserved             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                                                                                     |
| 16    | TIMERACTIVE          | 0x0                                                                                                                                                                               | R      | <b>Timer Active</b><br><br>The local timer is running.                                                                                                                                                                                              |
| 15    | SCAN FIFO FLUSHING   | 0x0                                                                                                                                                                               | R      | <b>The Scan FIFO is flushing</b><br><br>A scan data FIFO flush operation is in progress.                                                                                                                                                            |
| 14    | SINGLE FIFO FLUSHING | 0x0                                                                                                                                                                               | R      | <b>The Single FIFO is flushing</b><br><br>A single data FIFO flush operation is in progress.                                                                                                                                                        |

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                                                   |
|-------|-------------------------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:10 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                             |
| 9     | SCANFIFODV              | 0x0   | R      | <b>SCANFIFO Data Valid</b><br>At least one result in the scan FIFO is ready to read.                                                                                                                          |
| 8     | SINGLEFIFODV            | 0x0   | R      | <b>SINGLEFIFO Data Valid</b><br>At least one result in the single FIFO is ready to read.                                                                                                                      |
| 7     | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                             |
| 6     | CONVERTING              | 0x0   | R      | <b>Converting</b><br>The ADC is warmed up and in the process of performing a conversion.                                                                                                                      |
| 5     | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                             |
| 4     | SCANQUEUEPENDING        | 0x0   | R      | <b>Scan Queue Pending</b><br>The Scan queue has been triggered and is waiting to start conversion.                                                                                                            |
| 3     | SCANQEN                 | 0x0   | R      | <b>Scan Queued Enabled</b><br>The Scan queue is enabled.                                                                                                                                                      |
| 2     | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                             |
| 1     | SINGLEQUEUEPEND-<br>ING | 0x0   | R      | <b>Single Queue Pending</b><br>The Single queue has been triggered and is waiting to start conversion. When tailgating is used, SINGLEQUEUEPENDING will remain high until the a scan operation has completed. |
| 0     | SINGLEQEN               | 0x0   | R      | <b>Single Queue Enabled</b><br>The Single queue is enabled.                                                                                                                                                   |

### **23.5.7 IADC\_MASKREQ - Mask Request**

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                               |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                         |
| 15:0  | MASKREQ  | 0x0   | RW     | <b>Scan Queue Mask Request</b><br><br>Allows software to specify which entries in the Scan table should be converted. For example MASKREQ = 0x8014 means that scan table entries 15, 4, and 2 will be converted. The other entries will not be converted. |

**23.5.8 IADC\_STMASK - Scan Table Mask**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| 0x01C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0    |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R      |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | STMASK |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                      |
|-------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                |
| 15:0  | STMASK   | 0x0   | R      | <b>Scan Table Mask</b><br><br>This is the active / working copy of the MASKREQ register that the ADC uses. It will only be updated at the end of a scan sequence or when no scan is in progress. |

**23.5.9 IADC\_CMPTH.R - Digital Window Comparator Threshold**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 0x020         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0  |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | ADLT |   |   |   |   |   |   |   |

| Bit   | Name | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | ADGT | 0x0   | RW     | <b>ADC Greater Than or Equal to Threshold</b><br><br>Compare threshold value for greater-than or equal to comparison. ADGT should be specified in a left-justified, 16-bit format regardless of the FIFO ALIGNMENT setting. Comparisons with 12-bit formats will ignore the 4 LSBs of the ADGT value. Comparisons with 20-bit formats will ignore the 4 LSBs of the 20-bit result. Unipolar or bipolar mode is considered in the comparison. When ADGT is greater than ADLT, the comparison is true if the result is either greater than ADGT or less than ADLT, but false if the result falls between the values. |
| 15:0  | ADLT | 0x0   | RW     | <b>ADC Less Than or Equal to Threshold</b><br><br>Compare threshold value for less-than or equal to comparison. ADLT should be specified in a left-justified, 16-bit format regardless of the FIFO ALIGNMENT setting. Comparisons with 12-bit formats will ignore the 4 LSBs of the ADLT value. Comparisons with 20-bit formats will ignore the 4 LSBs of the 20-bit result. Unipolar or bipolar mode is considered in the comparison. When ADGT is greater than ADLT, the comparison is true if the result is either greater than ADGT or less than ADLT, but false if the result falls between the values.       |

## 23.5.10 IADC\_IF - Interrupt Flags

| Offset | Bit Position   |    |    |    |    |    |    |    |    |    |    |    |            |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |
|--------|----------------|----|----|----|----|----|----|----|----|----|----|----|------------|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|--|--|
| Reset  | 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 |  |  |
| Access | RW             |    |    |    |    |    |    |    |    |    |    |    |            |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |
| Name   | EM23ABORTERROR |    |    |    |    |    |    |    |    |    |    |    | SCANFIFOUF | RW | 0x0 | 19 |    |    |    |    |    |    |   |   |   |   |   |   |  |  |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | EM23ABORTERROR | 0x0   | RW     | <b>EM2/3 Abort Error</b><br><br>The system entered EM2 or EM3 during a conversion with an unsupported clock. Conversion results may be corrupted.                                 |
| 30:20 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19    | SCANFIFOUF     | 0x0   | RW     | <b>Scan FIFO Underflow</b><br><br>A scan FIFO underflow has occurred.                                                                                                             |
| 18    | SINGLEFIFOUF   | 0x0   | RW     | <b>Single FIFO Underflow</b><br><br>A single FIFO underflow has occurred.                                                                                                         |
| 17    | SCANFIFOOF     | 0x0   | RW     | <b>Scan FIFO Overflow</b><br><br>A scan FIFO overflow has occurred.                                                                                                               |
| 16    | SINGLEFIFOOF   | 0x0   | RW     | <b>Single FIFO Overflow</b><br><br>A single FIFO overflow has occurred.                                                                                                           |
| 15:14 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13    | PORTALLOCERR   | 0x0   | RW     | <b>Port Allocation Error</b><br><br>A pin was selected on a port which has not been allocated to the IADC in GPIO control.                                                        |
| 12    | POLARITYERR    | 0x0   | RW     | <b>Polarity Error</b><br><br>Either two even channels or two odd channels were programmed into the channel mux selection. The ADC result will be set to 0xFFFF.                   |
| 11:10 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9     | SINGLEDONE     | 0x0   | RW     | <b>Single Conversion Done</b><br><br>A single conversion has completed.                                                                                                           |
| 8     | SCANTABLEDONE  | 0x0   | RW     | <b>Scan Table Done</b><br><br>A scan sequence completed. Set at the end of a scan sequence after all valid entries of the scan table have completed.                              |
| 7     | SCANENTRYDONE  | 0x0   | RW     | <b>Scan Entry Done</b><br><br>A scan table conversion completed. Set at the completion of each valid entry of the scan table.                                                     |

| Bit | Name            | Reset | Access | Description                                                                                                                                                                       |
|-----|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3   | SCANCMP         | 0x0   | RW     | <b>Scan Result Window Compare</b><br>Scan digital compare window tripped.                                                                                                         |
| 2   | SINGLECMP       | 0x0   | RW     | <b>Single Result Window Compare</b><br>Single digital compare window tripped.                                                                                                     |
| 1   | SCANFIFODVL     | 0x0   | RW     | <b>Scan FIFO Data Valid Level</b><br>A minimum of (DVL+1) entries are ready to be read from the Scan FIFO.                                                                        |
| 0   | SINGLEFIFODVL   | 0x0   | RW     | <b>Single FIFO Data Valid Level</b><br>A minimum of (DVL+1) entries are ready to be read from the Single FIFO.                                                                    |

## 23.5.11 IADC\_IEN - Interrupt Enable

| Offset | Bit Position   |    |    |    |    |    |    |    |    |    |    |    |            |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |
|--------|----------------|----|----|----|----|----|----|----|----|----|----|----|------------|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|--|--|
| Reset  | 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 |  |  |
| Access | RW             |    |    |    |    |    |    |    |    |    |    |    |            |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |  |  |
| Name   | EM23ABORTERROR |    |    |    |    |    |    |    |    |    |    |    | SCANFIFOUF | RW | 0x0 | 19 |    |    |    |    |    |    |   |   |   |   |   |   |  |  |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | EM23ABORTERROR | 0x0   | RW     | <b>EM2/3 Abort Error Enable</b><br><br>EM2/3 Abort Error Enable                                                                                                                   |
| 30:20 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19    | SCANFIFOUF     | 0x0   | RW     | <b>Scan FIFO Underflow Enable</b><br><br>Scan FIFO underflow interrupt enable                                                                                                     |
| 18    | SINGLEFIFOUF   | 0x0   | RW     | <b>Single FIFO Underflow Enable</b><br><br>Single FIFO underflow interrupt enable                                                                                                 |
| 17    | SCANFIFOOF     | 0x0   | RW     | <b>Scan FIFO Overflow Enable</b><br><br>Scan FIFO overflow interrupt enable                                                                                                       |
| 16    | SINGLEFIFOOF   | 0x0   | RW     | <b>Single FIFO Overflow Enable</b><br><br>Single FIFO overflow interrupt enable                                                                                                   |
| 15:14 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13    | PORTALLOCERR   | 0x0   | RW     | <b>Port Allocation Error Enable</b><br><br>Port Allocation Error Enable                                                                                                           |
| 12    | POLARITYERR    | 0x0   | RW     | <b>Polarity Error Enable</b><br><br>Polarity Error Enable                                                                                                                         |
| 11:10 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9     | SINGLEDONE     | 0x0   | RW     | <b>Single Conversion Done Enable</b><br><br>Single Conversion Done interrupt enable                                                                                               |
| 8     | SCANTABLEDONE  | 0x0   | RW     | <b>Scan Table Done Enable</b><br><br>Scan Table Done interrupt enable                                                                                                             |
| 7     | SCANENTRYDONE  | 0x0   | RW     | <b>Scan Entry Done Enable</b><br><br>Scan Entry Done interrupt enable                                                                                                             |

| Bit | Name            | Reset | Access | Description                                                                                                                                                                       |
|-----|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3   | SCANCMP         | 0x0   | RW     | <b>Scan Result Window Compare Enable</b>                                                                                                                                          |
|     |                 |       |        | Scan Result Window Compare Enable                                                                                                                                                 |
| 2   | SINGLECMP       | 0x0   | RW     | <b>Single Result Window Compare Enable</b>                                                                                                                                        |
|     |                 |       |        | Single Result Window Compare Enable                                                                                                                                               |
| 1   | SCANFIFODVL     | 0x0   | RW     | <b>Scan FIFO Data Valid Level Enable</b>                                                                                                                                          |
|     |                 |       |        | Scan FIFO Data Valid Level interrupt enable                                                                                                                                       |
| 0   | SINGLEFIFODVL   | 0x0   | RW     | <b>Single FIFO Data Valid Level Enable</b>                                                                                                                                        |
|     |                 |       |        | Single FIFO Data Valid Level interrupt enable                                                                                                                                     |

### 23.5.12 IADC\_TRIGGER - Trigger

| Bit   | Name             | Reset                                                                                                                                                                                                                          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
|-------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved         |                                                                                                                                                                                                                                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 16    | SINGLETAILGATE   | 0x0                                                                                                                                                                                                                            | RW     | <b>Single Tailgate Enable</b><br>Enables tailgating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
|       |                  |                                                                                                                                                                                                                                |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>TAILGATEOFF</td><td>The single queue is ready to start warming up and converting once the trigger had been detected.</td></tr> <tr> <td>1</td><td>TAILGATEON</td><td>After the single queue's trigger is detected, it must wait until the end of a scan operation before the Single queue can be converted.</td></tr> </tbody> </table>                                                                                                                                                       | Value | Mode | Description | 0 | TAILGATEOFF | The single queue is ready to start warming up and converting once the trigger had been detected.                                                                      | 1 | TAILGATEON | After the single queue's trigger is detected, it must wait until the end of a scan operation before the Single queue can be converted.                                                                                         |
| Value | Mode             | Description                                                                                                                                                                                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 0     | TAILGATEOFF      | The single queue is ready to start warming up and converting once the trigger had been detected.                                                                                                                               |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 1     | TAILGATEON       | After the single queue's trigger is detected, it must wait until the end of a scan operation before the Single queue can be converted.                                                                                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 15:13 | Reserved         |                                                                                                                                                                                                                                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 12    | SINGLETRIGACTION | 0x0                                                                                                                                                                                                                            | RW     | <b>Single Trigger Action</b><br>Selects the trigger action for the single queue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
|       |                  |                                                                                                                                                                                                                                |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>ONCE</td><td>For TRIGSEL=IMMEDIATE, converts the single queue once and disables queue. For TRIGSEL = TIMER, PRSCLKGRP, PRSPOS, PRSNEG, converts the single queue once per trigger.</td></tr> <tr> <td>1</td><td>CONTINUOUS</td><td>Converts the single queue, then checks for a pending scan queue before converting the single queue again continuously. The queues are first come first serve. If both queues are continuous, the IADC alternates between them.</td></tr> </tbody> </table> | Value | Mode | Description | 0 | ONCE        | For TRIGSEL=IMMEDIATE, converts the single queue once and disables queue. For TRIGSEL = TIMER, PRSCLKGRP, PRSPOS, PRSNEG, converts the single queue once per trigger. | 1 | CONTINUOUS | Converts the single queue, then checks for a pending scan queue before converting the single queue again continuously. The queues are first come first serve. If both queues are continuous, the IADC alternates between them. |
| Value | Mode             | Description                                                                                                                                                                                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 0     | ONCE             | For TRIGSEL=IMMEDIATE, converts the single queue once and disables queue. For TRIGSEL = TIMER, PRSCLKGRP, PRSPOS, PRSNEG, converts the single queue once per trigger.                                                          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 1     | CONTINUOUS       | Converts the single queue, then checks for a pending scan queue before converting the single queue again continuously. The queues are first come first serve. If both queues are continuous, the IADC alternates between them. |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 11    | Reserved         |                                                                                                                                                                                                                                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| 10:8  | SINGLETRIGSEL    | 0x0                                                                                                                                                                                                                            | RW     | <b>Single Trigger Select</b><br>Selects the trigger source for the single queue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
|       |                  |                                                                                                                                                                                                                                |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Value | Mode | Description |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |
| Value | Mode             | Description                                                                                                                                                                                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |             |                                                                                                                                                                       |   |            |                                                                                                                                                                                                                                |

| Bit   | Name           | Reset                                                                                                                                                                                                                                                                                                                                                          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|---|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     |                | IMMEDIATE                                                                                                                                                                                                                                                                                                                                                      |        | Immediate triggering. The single queue will be disabled once the conversion is complete, unless TRIGGERACTION is set to continuous.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 1     |                | TIMER                                                                                                                                                                                                                                                                                                                                                          |        | Triggers when the local timer count reaches zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 2     |                | PRSCLKGRP                                                                                                                                                                                                                                                                                                                                                      |        | Triggers on PRS1 from a timer module that is using the same clock group as the ADC and has been programmed to use the same clock source as the ADC. The prescale may be different between the ADC and the timer module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 3     |                | PRSPOS                                                                                                                                                                                                                                                                                                                                                         |        | Triggers on asynchronous PRS1 positive edge. Requires PRS1 to go low for 3 ADC_CLKs before another positive edge can be detected. Generates an additional delay of 1 to 2 CLK_SRC_ADC cycles for synchronization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 4     |                | PRSNEG                                                                                                                                                                                                                                                                                                                                                         |        | Triggers on asynchronous PRS1 negative edge. Requires PRS1 to go high for 3 ADC_CLKs before another negative edge can be detected. Generates an additional delay of 1 to 2 CLK_SRC_ADC cycles for synchronization. PRSNEG should only be used when the trigger source is from a module that remains powered during EM23. For modules (ie: TIMER) that power down during EM23, PRSPOS should be used for an asynchronous trigger, and PRSCLKGRP should be used for a synchronous trigger.                                                                                                                                                                                                                                                                   |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 7:5   | Reserved       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 4     | SCANTRIGACTION | 0x0                                                                                                                                                                                                                                                                                                                                                            | RW     | <b>Scan Trigger Action</b><br><br>Selects the trigger action for the scan queue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
|       |                |                                                                                                                                                                                                                                                                                                                                                                |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>ONCE</td><td>For TRIGSEL=IMMEDIATE, goes through the scan table once and disables queue. For TRIGSEL = TIMER, PRSCLKGRP, PRSPOS, PRSNEG, goes through the scan table once per trigger.</td></tr> <tr> <td>1</td><td>CONTINUOUS</td><td>Goes through the scan table, converts each entry with a mask bit set, and puts it back into the scan queue to repeat again continuously. The queues are first come first serve. If both queues are triggered, the single queue will get to convert after each scan table completes. The scan queue will get to convert after each single conversion completes.</td></tr> </tbody> </table> | Value | Mode | Description | 0 | ONCE      | For TRIGSEL=IMMEDIATE, goes through the scan table once and disables queue. For TRIGSEL = TIMER, PRSCLKGRP, PRSPOS, PRSNEG, goes through the scan table once per trigger. | 1 | CONTINUOUS | Goes through the scan table, converts each entry with a mask bit set, and puts it back into the scan queue to repeat again continuously. The queues are first come first serve. If both queues are triggered, the single queue will get to convert after each scan table completes. The scan queue will get to convert after each single conversion completes. |   |           |                                                                                                                                                                                                                         |
| Value | Mode           | Description                                                                                                                                                                                                                                                                                                                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 0     | ONCE           | For TRIGSEL=IMMEDIATE, goes through the scan table once and disables queue. For TRIGSEL = TIMER, PRSCLKGRP, PRSPOS, PRSNEG, goes through the scan table once per trigger.                                                                                                                                                                                      |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 1     | CONTINUOUS     | Goes through the scan table, converts each entry with a mask bit set, and puts it back into the scan queue to repeat again continuously. The queues are first come first serve. If both queues are triggered, the single queue will get to convert after each scan table completes. The scan queue will get to convert after each single conversion completes. |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 3     | Reserved       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 2:0   | SCANTRIGSEL    | 0x0                                                                                                                                                                                                                                                                                                                                                            | RW     | <b>Scan Trigger Select</b><br><br>Selects the trigger source for the scan queue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
|       |                |                                                                                                                                                                                                                                                                                                                                                                |        | <table border="1"> <thead> <tr> <th>Value</th><th>Mode</th><th>Description</th></tr> </thead> <tbody> <tr> <td>0</td><td>IMMEDIATE</td><td>Immediate triggering. The scan queue will be disabled once all conversions in the scan table are complete, unless TRIGGERACTION is set to continuous.</td></tr> <tr> <td>1</td><td>TIMER</td><td>Triggers when the local timer count reaches zero.</td></tr> <tr> <td>2</td><td>PRSCLKGRP</td><td>Triggers on PRS0 from a timer module that is using the same clock group as the ADC and has been programmed to use the same clock source as the ADC. The prescale may be different between the ADC and the timer module.</td></tr> </tbody> </table>                                                           | Value | Mode | Description | 0 | IMMEDIATE | Immediate triggering. The scan queue will be disabled once all conversions in the scan table are complete, unless TRIGGERACTION is set to continuous.                     | 1 | TIMER      | Triggers when the local timer count reaches zero.                                                                                                                                                                                                                                                                                                              | 2 | PRSCLKGRP | Triggers on PRS0 from a timer module that is using the same clock group as the ADC and has been programmed to use the same clock source as the ADC. The prescale may be different between the ADC and the timer module. |
| Value | Mode           | Description                                                                                                                                                                                                                                                                                                                                                    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 0     | IMMEDIATE      | Immediate triggering. The scan queue will be disabled once all conversions in the scan table are complete, unless TRIGGERACTION is set to continuous.                                                                                                                                                                                                          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 1     | TIMER          | Triggers when the local timer count reaches zero.                                                                                                                                                                                                                                                                                                              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |
| 2     | PRSCLKGRP      | Triggers on PRS0 from a timer module that is using the same clock group as the ADC and has been programmed to use the same clock source as the ADC. The prescale may be different between the ADC and the timer module.                                                                                                                                        |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      |             |   |           |                                                                                                                                                                           |   |            |                                                                                                                                                                                                                                                                                                                                                                |   |           |                                                                                                                                                                                                                         |

| Bit | Name | Reset  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   |      | PRSPOS |        | Triggers on asynchronous PRS0 positive edge. Requires PRS0 to go low for 3 ADC_CLKs before another positive edge can be detected. Generates an additional delay of 1 to 2 CLK_SRC_ADC cycles for synchronization.                                                                                                                                                                                                                                                                        |
| 4   |      | PRSNEG |        | Triggers on asynchronous PRS0 negative edge. Requires PRS0 to go high for 3 ADC_CLKs before another negative edge can be detected. Generates an additional delay of 1 to 2 CLK_SRC_ADC cycles for synchronization. PRSNEG should only be used when the trigger source is from a module that remains powered during EM23. For modules (ie: TIMER) that power down during EM23, PRSPOS should be used for an asynchronous trigger, and PRSCLKGRP should be used for a synchronous trigger. |

## 23.5.13 IADC\_CFGx - Configuration

| Offset | Bit Position |    |    |     |        |    |    |    |        |     |    |    |    |           |    |    |    |    |    |    |   |   |       |     |   |       |    |     |         |   |  |  |
|--------|--------------|----|----|-----|--------|----|----|----|--------|-----|----|----|----|-----------|----|----|----|----|----|----|---|---|-------|-----|---|-------|----|-----|---------|---|--|--|
| 0x048  | 31           | 30 | 29 | 28  | 27     | 26 | 25 | 24 | 23     | 20  | 19 | 18 | 17 | 16        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6   | 5 | 4     | 3  | 2   | 1       | 0 |  |  |
| Reset  |              |    |    |     |        |    |    |    |        |     |    |    |    |           |    |    |    |    |    |    |   |   |       |     |   |       |    |     |         |   |  |  |
| Access |              |    | RW | 0x0 |        |    |    |    | RW     | 0x0 |    |    |    | RW        |    |    |    |    |    |    |   |   | RW    | 0x3 |   |       | RW | 0x0 |         |   |  |  |
| Name   | TWOSCOMPL    |    |    |     | DIGAVG |    |    |    | REFSEL |     |    |    |    | ANALOGAIN |    |    |    |    |    |    |   |   | OSRHA |     |   | OSRHS |    |     | ADCMODE |   |  |  |

| Bit   | Name      | Reset         | Access | Description                                                                                                                                                                       |
|-------|-----------|---------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved  |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 29:28 | TWOSCOMPL | 0x0           | RW     | <b>Two's Complement</b><br><br>Selects output word polarity.                                                                                                                      |
|       | Value     | Mode          |        | Description                                                                                                                                                                       |
|       | 0         | AUTO          |        | Automatic: Single ended measurements are reported as unipolar and differential measurements are reported as bipolar.                                                              |
|       | 1         | FORCEUNIPOLAR |        | Force all measurements to result in unipolar output. Negative differential numbers will saturate to 0.                                                                            |
|       | 2         | FORCEBIPOLAR  |        | Force all measurements to result in bipolar output. Single ended measurements are half the range, but allow for small negative measurements.                                      |
| 27:24 | Reserved  |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:21 | DIGAVG    | 0x0           | RW     | <b>Digital Averaging</b><br><br>Number of output words to convert and average.                                                                                                    |
|       | Value     | Mode          |        | Description                                                                                                                                                                       |
|       | 0         | AVG1          |        | Collect one output word (no digital averaging).                                                                                                                                   |
|       | 1         | AVG2          |        | Collect and average 2 digital output words.                                                                                                                                       |
|       | 2         | AVG4          |        | Collect and average 4 digital output words.                                                                                                                                       |
|       | 3         | AVG8          |        | Collect and average 8 digital output words.                                                                                                                                       |
|       | 4         | AVG16         |        | Collect and average 16 digital output words.                                                                                                                                      |
| 20:19 | Reserved  |               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 18:16 | REFSEL    | 0x0           | RW     | <b>Reference Select</b><br><br>Selects voltage reference.                                                                                                                         |
|       | Value     | Mode          |        | Description                                                                                                                                                                       |
|       | 0         | VBGR          |        | Internal 1.21 V reference.                                                                                                                                                        |

| Bit   | Name       | Reset      | Access | Description                                                                                                                                                                       |
|-------|------------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | VREF       |            |        | External Reference. (Calibrated for 1.25V nominal.)                                                                                                                               |
| 2     | VREF2P5    |            |        | External Reference. Supports 2.5V in high accuracy mode.                                                                                                                          |
| 3     | VDDX       |            |        | AVDD (unbuffered)                                                                                                                                                                 |
| 4     | VDDX0P8BUF |            |        | AVDD (buffered) * 0.8                                                                                                                                                             |
| 15    | Reserved   |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 14:12 | ANALOGGAIN | 0x2        | RW     | <b>Analog Gain</b>                                                                                                                                                                |
|       |            |            |        | Sets analog front end gain.                                                                                                                                                       |
|       | Value      | Mode       |        | Description                                                                                                                                                                       |
|       | 1          | ANAGAIN0P5 |        | Analog gain of 0.5x.                                                                                                                                                              |
|       | 2          | ANAGAIN1   |        | Analog gain of 1x.                                                                                                                                                                |
|       | 3          | ANAGAIN2   |        | Analog gain of 2x.                                                                                                                                                                |
|       | 4          | ANAGAIN3   |        | Analog gain of 3x.                                                                                                                                                                |
|       | 5          | ANAGAIN4   |        | Analog gain of 4x.                                                                                                                                                                |
| 11:8  | Reserved   |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:5   | OSRHA      | 0x3        | RW     | <b>High Accuracy OSR</b>                                                                                                                                                          |
|       |            |            |        | Over sampling ratio for high accuracy conversions.                                                                                                                                |
|       | Value      | Mode       |        | Description                                                                                                                                                                       |
|       | 0          | HIACC16    |        | High accuracy over sampling of 16x.                                                                                                                                               |
|       | 1          | HIACC32    |        | High accuracy over sampling of 32x.                                                                                                                                               |
|       | 2          | HIACC64    |        | High accuracy over sampling of 64x.                                                                                                                                               |
|       | 3          | HIACC92    |        | High accuracy over sampling of 92x.                                                                                                                                               |
|       | 4          | HIACC128   |        | High accuracy over sampling of 128x.                                                                                                                                              |
|       | 5          | HIACC256   |        | High accuracy over sampling of 256x.                                                                                                                                              |
| 4:2   | OSRHS      | 0x0        | RW     | <b>High Speed OSR</b>                                                                                                                                                             |
|       |            |            |        | Over sampling ratio for high speed conversions.                                                                                                                                   |
|       | Value      | Mode       |        | Description                                                                                                                                                                       |
|       | 0          | HISPD2     |        | High speed over sampling of 2x.                                                                                                                                                   |
|       | 1          | HISPD4     |        | High speed over sampling of 4x.                                                                                                                                                   |
|       | 2          | HISPD8     |        | High speed over sampling of 8x.                                                                                                                                                   |
|       | 3          | HISPD16    |        | High speed over sampling of 16x.                                                                                                                                                  |
|       | 4          | HISPD32    |        | High speed over sampling of 32x.                                                                                                                                                  |
|       | 5          | HISPD64    |        | High speed over sampling of 64x.                                                                                                                                                  |
| 1:0   | ADCMODE    | 0x0        | RW     | <b>ADC Mode</b>                                                                                                                                                                   |
|       |            |            |        | Selects ADC conversion mode.                                                                                                                                                      |

| Bit | Name         | Reset | Access | Description                                                                                                        |
|-----|--------------|-------|--------|--------------------------------------------------------------------------------------------------------------------|
|     | Value        | Mode  |        | Description                                                                                                        |
| 0   | NORMAL       |       |        | High speed mode with a maximum ADC_CLK of 10 MHz.                                                                  |
| 1   | HIGHSPEED    |       |        | Double high speed mode with a maximum ADC_CLK of 20 MHz. Power consumption is boosted to allow faster conversions. |
| 2   | HIGHACCURACY |       |        | High accuracy mode with maximum ADC_CLK of 5 MHz.                                                                  |

### **23.5.14 IADC\_SCALEx - Scaling**

| Bit                                                                                                                                                                                                     | Name      | Reset   | Access | Description                        |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|--------|------------------------------------|
| 31                                                                                                                                                                                                      | GAIN3MSB  | 0x1     | RW     | <b>Gain 3 MSBs</b>                 |
| 3 MSBs of the 16-bit gain value (0=011 or 0.75; 1=1xx or 1.00). Example {GAIN3MSB, GAIN13LSB} = {100, 0_1001_0000_0000} = 1.07031x. Example {GAIN3MSB, GAIN13LSB} = {011, 0_0000_1010_0010} = 0.75494x. |           |         |        |                                    |
|                                                                                                                                                                                                         | Value     | Mode    |        | Description                        |
|                                                                                                                                                                                                         | 0         | GAIN011 |        | Upper 3 bits of gain = 011 (0.75x) |
|                                                                                                                                                                                                         | 1         | GAIN100 |        | Upper 3 bits of gain = 100 (1.00x) |
| 30:18                                                                                                                                                                                                   | GAIN13LSB | 0x0     | RW     | <b>Gain 13 LSBs</b>                |
| 13 LSBs of the 16-bit gain value.                                                                                                                                                                       |           |         |        |                                    |
| 17:0                                                                                                                                                                                                    | OFFSET    | 0x2C000 | RW     | <b>Offset</b>                      |
|                                                                                                                                                                                                         | Offset    |         |        |                                    |

## 23.5.15 IADC\_SCHEDx - Scheduling

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| 0x054         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0      |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW       |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | PRESCALE |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:0   | PRESCALE | 0x0   | RW     | <b>Prescale</b><br><br>Second level prescaler - divides the CLK_SRC_ADC by (PRESCALE + 1) to generate ADC_CLK. PRESCALE=0 should only be used with HSCLKRATE=0. (See text.)       |

## 23.5.16 IADC\_SINGLEFIFO CFG - Single FIFO Configuration

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |        |           |     |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|--------|-----------|-----|---|---|---|---|
| 0x070  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0x3    | 0x0       | 0x0 |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW  | RW     | RW        | RW  |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DVL | SHOWID | ALIGNMENT |     |   |   |   |   |

| Bit  | Name            | Reset    | Access | Description                                                                                                                                                                       |
|------|-----------------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8    | DMAWUFIFOSINGLE | 0x0      | RW     | <b>Single FIFO DMA wakeup.</b><br><br>Enables single FIFO to wake DMA in EM2 or EM3.                                                                                              |
|      | Value           | Mode     |        | Description                                                                                                                                                                       |
|      | 0               | DISABLED |        | While in EM2 or EM3, the DMA controller will not be requested.                                                                                                                    |
|      | 1               | ENABLED  |        | While in EM2 or EM3, the DMA controller will be requested when the single FIFO reaches its Data Valid Level. [DVL must be set to 0 (VALID1).]                                     |
| 7    | Reserved        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 6:4  | DVL             | 0x3      | RW     | <b>Data Valid Level</b><br><br>Data valid level before requesting DMA transfer. If the number of words in the FIFO reaches or exceeds DVL+1, DMA requests will be generated.      |
|      | Value           | Mode     |        | Description                                                                                                                                                                       |
|      | 0               | VALID1   |        | When 1 entry in the single FIFO is valid, set the SINGLEFI-FODVL interrupt and request DMA.                                                                                       |
|      | 1               | VALID2   |        | When 2 entries in the single FIFO are valid, set the SINGLEFI-FODVL interrupt and request DMA.                                                                                    |
|      | 2               | VALID3   |        | When 3 entries in the single FIFO are valid, set the SINGLEFI-FODVL interrupt and request DMA.                                                                                    |
|      | 3               | VALID4   |        | When 4 entries in the single FIFO are valid, set the SINGLEFI-FODVL interrupt and request DMA.                                                                                    |
|      | 4               | VALID5   |        | When 5 entries in the single FIFO are valid, set the SINGLEFI-FODVL interrupt and request DMA.                                                                                    |
|      | 5               | VALID6   |        | When 6 entries in the single FIFO are valid, set the SINGLEFI-FODVL interrupt and request DMA.                                                                                    |
|      | 6               | VALID7   |        | When 7 entries in the single FIFO are valid, set the SINGLEFI-FODVL interrupt and request DMA.                                                                                    |

| Bit | Name      | Reset   | Access | Description                                                                                   |
|-----|-----------|---------|--------|-----------------------------------------------------------------------------------------------|
| 7   |           | VALID8  |        | When 8 entries in the single FIFO are valid, set the SINGLEFIFOVLD interrupt and request DMA. |
| 3   | SHOWID    | 0x0     | RW     | <b>Show ID</b><br><br>ID of 0x20 will be applied in the output words.                         |
| 2:0 | ALIGNMENT | 0x0     | RW     | <b>Alignment</b><br><br>Alignment of output data written into FIFO.                           |
|     | Value     | Mode    |        | Description                                                                                   |
|     | 0         | RIGHT12 |        | ID[7:0], SIGN_EXT, DATA[11:0]                                                                 |
|     | 1         | RIGHT16 |        | ID[7:0], SIGN_EXT, DATA[15:0]                                                                 |
|     | 2         | RIGHT20 |        | ID[7:0], SIGN_EXT, DATA[19:0]                                                                 |
|     | 3         | LEFT12  |        | DATA[11:0], 000000000000, ID[7:0]                                                             |
|     | 4         | LEFT16  |        | DATA[15:0], 00000000, ID[7:0]                                                                 |
|     | 5         | LEFT20  |        | DATA[19:0], 0000, ID[7:0]                                                                     |

### 23.5.17 IADC\_SINGLEFIFODATA - Single FIFO DATA

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x074  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | R(r) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | DATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name | Reset | Access | Description                                           |
|------|------|-------|--------|-------------------------------------------------------|
| 31:0 | DATA | 0x0   | R(r)   | <b>Single FIFO Read Data</b>                          |
|      |      |       |        | Reads and pops the oldest value from the single FIFO. |

**23.5.18 IADC\_SINGLEFIFOSTAT - Single FIFO Status**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|---|---|---|---|---|---|
| 0x078         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0         |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | R           |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | FIFOREADCNT | R |   |   |   |   |   |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                       |
|------|-------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0  | FIFOREADCNT | 0x0   | R      | <b>FIFO Read Count</b><br><br>Number of valid entries available to read.                                                                                          |

**23.5.19 IADC\_SINGLEDATA - Single Data**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x07C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | R    |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DATA |   |   |   |   |   |   |

| Bit  | Name | Reset | Access | Description                                                                                                                                                                                                                |
|------|------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DATA | 0x0   | R      | <b>Data</b><br><br>Reads the most recent data word from the single FIFO, but does not pop a value. Even if the FIFO has overflowed and stopped updating, the most recent conversion will continue to overwrite SINGLEDATA. |

## 23.5.20 IADC\_SCANFIFO CFG - Scan FIFO Configuration

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |        |           |     |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|--------|-----------|-----|---|
| 0x080  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0 | 0x3    | 0x0       | 0x0 |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW  | RW     | RW        | RW  |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | DVL | SHOWID | ALIGNMENT |     |   |

| Bit   | Name         | Reset                                                                                                                                         | Access | Description                                                                                                                                                                       |
|-------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9  | Reserved     |                                                                                                                                               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 8     | DMAWFIFOSCAN | 0x0                                                                                                                                           | RW     | <b>Scan FIFO DMA Wakeup</b>                                                                                                                                                       |
|       |              | Enables scan FIFO to wake DMA in EM2 or EM3.                                                                                                  |        |                                                                                                                                                                                   |
| Value | Mode         | Description                                                                                                                                   |        |                                                                                                                                                                                   |
| 0     | DISABLED     | While in EM2 or EM3, the DMA controller will not be requested.                                                                                |        |                                                                                                                                                                                   |
| 1     | ENABLED      | While in EM2 or EM3, the DMA controller will be requested when the scan FIFO reaches its Data Valid Level. [DVL must be set to 0 (VALID1).]   |        |                                                                                                                                                                                   |
| 7     | Reserved     |                                                                                                                                               |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 6:4   | DVL          | 0x3                                                                                                                                           | RW     | <b>Data Valid Level</b>                                                                                                                                                           |
|       |              | Data valid level before requesting DMA transfer. If the number of words in the FIFO reaches or exceeds DVL+1, DMA requests will be generated. |        |                                                                                                                                                                                   |
| Value | Mode         | Description                                                                                                                                   |        |                                                                                                                                                                                   |
| 0     | VALID1       | When 1 entry in the scan FIFO is valid, set the SCANFIFODVL interrupt and request DMA.                                                        |        |                                                                                                                                                                                   |
| 1     | VALID2       | When 2 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA.                                                     |        |                                                                                                                                                                                   |
| 2     | VALID3       | When 3 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA.                                                     |        |                                                                                                                                                                                   |
| 3     | VALID4       | When 4 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA.                                                     |        |                                                                                                                                                                                   |
| 4     | VALID5       | When 5 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA.                                                     |        |                                                                                                                                                                                   |
| 5     | VALID6       | When 6 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA.                                                     |        |                                                                                                                                                                                   |
| 6     | VALID7       | When 7 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA.                                                     |        |                                                                                                                                                                                   |

| Bit | Name      | Reset  | Access             | Description                                                                              |
|-----|-----------|--------|--------------------|------------------------------------------------------------------------------------------|
| 7   |           | VALID8 |                    | When 8 entries in the scan FIFO are valid, set the SCANFIFOVL interrupt and request DMA. |
| 3   | SHOWID    | 0x0    | RW                 | <b>Show ID</b><br>Enable ID in output words.                                             |
| 2:0 | ALIGNMENT | 0x0    | RW                 | <b>Alignment</b><br>Alignment of output data written into FIFO.                          |
|     |           |        | <b>Description</b> |                                                                                          |
|     |           |        | <b>Value</b>       |                                                                                          |
|     |           |        | <b>Mode</b>        |                                                                                          |
| 0   |           |        | RIGHT12            |                                                                                          |
| 1   |           |        | RIGHT16            |                                                                                          |
| 2   |           |        | RIGHT20            |                                                                                          |
| 3   |           |        | LEFT12             |                                                                                          |
| 4   |           |        | LEFT16             |                                                                                          |
| 5   |           |        | LEFT20             |                                                                                          |

### 23.5.21 IADC\_SCANFIFODATA - Scan FIFO Read Data

| Offset | Bit Position |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Reset  | 0x0          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Access | R(r)         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | DATA         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit  | Name | Reset | Access | Description                                                        |
|------|------|-------|--------|--------------------------------------------------------------------|
| 31:0 | DATA | 0x0   | R(r)   | <b>Data</b><br>Reads and pops the oldest value from the scan FIFO. |
|      |      |       |        |                                                                    |

**23.5.22 IADC\_SCANFIFOSTAT - Scan FIFO Status**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------|---|---|---|---|---|---|
| 0x088         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0         |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | R           |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | FIFOREADCNT |   |   |   |   |   |   |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                       |
|------|-------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 3:0  | FIFOREADCNT | 0x0   | R      | <b>FIFO Read Count</b><br><br>Number of valid entries available to read.                                                                                          |

**23.5.23 IADC\_SCANDATA - Scan Data**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x08C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | R    |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DATA |   |   |   |   |   |   |

| Bit  | Name | Reset | Access | Description                                                                                                                                                                                                            |
|------|------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DATA | 0x0   | R      | <b>Data</b><br><br>Reads the most recent data word from the scan FIFO, but does not pop a value. Even if the FIFO has overflowed and stopped updating, the most recent conversion will continue to overwrite SCANDATA. |

## 23.5.24 IADC\_SINGLE - Single Queue Port Selection

| Offset | Bit Position |    |    |    |    |    |    |    |     |     |         |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |     |     |     |
|--------|--------------|----|----|----|----|----|----|----|-----|-----|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-----|-----|-----|
| 0x098  | 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      |        |     |     |     |
| Reset  |              |    |    |    |    |    |    |    | 0x0 | 0x0 | 0x0     | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0 | 0x0 | 0x0 |
| Access |              |    |    |    |    |    |    |    | RW  | RW  | RW      | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     |     |     |     |
| Name   |              |    |    |    |    |    |    |    | CMP | CFG | PORTPOS | PINPOS | PINNEG |     |     |     |

| Bit   | Name     | Reset   | Access | Description                                                                                                                                                                       |
|-------|----------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17    | CMP      | 0x0     | RW     | <b>Comparison Enable</b><br><br>Enable digital window comparison for this entry.                                                                                                  |
| 16    | CFG      | 0x0     | RW     | <b>Configuration Group Select</b><br><br>Select which configuration group (CFGx, SCALEx, SCHEx registers) is used with this entry.                                                |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | CONFIG0 |        | Use configuration group 0                                                                                                                                                         |
|       | 1        | CONFIG1 |        | Use configuration group 1                                                                                                                                                         |
| 15:12 | PORTPOS  | 0x0     | RW     | <b>Positive Port Select</b><br><br>Port (A, B, C, D) or special signal assigned to the positive input of the ADC                                                                  |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | GND     |        | Ground                                                                                                                                                                            |
|       | 1        | SUPPLY  |        | Supply Pin - Select specific supply using PINPOS                                                                                                                                  |
|       | 2        | DAC0    |        | Direct connection to DAC0_CH0                                                                                                                                                     |
|       | 4        | PADANA0 |        | Direct connection to AIN0 input pin                                                                                                                                               |
|       | 5        | PADANA2 |        | Direct connection to AIN2 input pin                                                                                                                                               |
|       | 8        | PORTA   |        | Port A - Select pin number using PINPOS                                                                                                                                           |
|       | 9        | PORTB   |        | Port B - Select pin number using PINPOS                                                                                                                                           |
|       | 10       | PORTC   |        | Port C - Select pin number using PINPOS                                                                                                                                           |
|       | 11       | PORTD   |        | Port D - Select pin number using PINPOS                                                                                                                                           |
| 11:8  | PINPOS   | 0x0     | RW     | <b>Positive Pin Select</b><br><br>Pin number for the positive input of the ADC.                                                                                                   |
| 7:4   | PORPNEG  | 0x0     | RW     | <b>Negative Port Select</b><br><br>Port (A, B, C, D) or special signal assigned to the negative input of the ADC                                                                  |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | GND     |        | Ground (single-ended)                                                                                                                                                             |

| Bit | Name    | Reset | Access | Description                                   |
|-----|---------|-------|--------|-----------------------------------------------|
| 2   | DAC1    |       |        | Direct connection to DAC0_CH1                 |
| 4   | PADANA1 |       |        | Direct connection to AIN1 input pin           |
| 5   | PADANA3 |       |        | Direct connection to AIN3 input pin           |
| 8   | PORTA   |       |        | Port A - Select pin number using PINNEG       |
| 9   | PORTB   |       |        | Port B - Select pin number using PINNEG       |
| 10  | PORTC   |       |        | Port C - Select pin number using PINNEG       |
| 11  | PORTD   |       |        | Port D - Select pin number using PINNEG       |
| 3:0 | PINNEG  | 0x0   | RW     | <b>Negative Pin Select</b>                    |
|     |         |       |        | Pin number for the negative input of the ADC. |

## 23.5.25 IADC\_SCANx - SCAN Entry

| Offset | Bit Position |    |    |    |    |    |    |    |     |     |         |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |     |     |     |
|--------|--------------|----|----|----|----|----|----|----|-----|-----|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-----|-----|-----|
| 0x0A0  | 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      |     |     |     |
| Reset  |              |    |    |    |    |    |    |    | 0x0 | 0x0 | 0x0     | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0    | 0x0 | 0x0 | 0x0 |
| Access |              |    |    |    |    |    |    |    | RW  | RW  | RW      | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     | RW     |     |     |     |
| Name   |              |    |    |    |    |    |    |    | CMP | CFG | PORTPOS | PINPOS | PINNEG |     |     |     |

| Bit   | Name     | Reset   | Access | Description                                                                                                                                                                       |
|-------|----------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17    | CMP      | 0x0     | RW     | <b>Comparison Enable</b><br><br>Enable digital window comparison for this entry.                                                                                                  |
| 16    | CFG      | 0x0     | RW     | <b>Configuration Group Select</b><br><br>Select which configuration group (CFGx, SCALEx, SCHEx registers) is used with this entry.                                                |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | CONFIG0 |        | Use configuration group 0                                                                                                                                                         |
|       | 1        | CONFIG1 |        | Use configuration group 1                                                                                                                                                         |
| 15:12 | PORTPOS  | 0x0     | RW     | <b>Positive Port Select</b><br><br>Port (A, B, C, D) or special signal assigned to the positive input of the ADC                                                                  |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | GND     |        | Ground                                                                                                                                                                            |
|       | 1        | SUPPLY  |        | Supply Pin - Select specific supply using PINPOS                                                                                                                                  |
|       | 2        | DAC0    |        | Direct connection to DAC0_CH0                                                                                                                                                     |
|       | 4        | PADANA0 |        | Direct connection to AIN0 input pin                                                                                                                                               |
|       | 5        | PADANA2 |        | Direct connection to AIN2 input pin                                                                                                                                               |
|       | 8        | PORTA   |        | Port A - Select pin number using PINPOS                                                                                                                                           |
|       | 9        | PORTB   |        | Port B - Select pin number using PINPOS                                                                                                                                           |
|       | 10       | PORTC   |        | Port C - Select pin number using PINPOS                                                                                                                                           |
|       | 11       | PORTD   |        | Port D - Select pin number using PINPOS                                                                                                                                           |
| 11:8  | PINPOS   | 0x0     | RW     | <b>Positive Pin Select</b><br><br>Pin number for the positive input of the ADC.                                                                                                   |
| 7:4   | PORPNEG  | 0x0     | RW     | <b>Negative Port Select</b><br><br>Port (A, B, C, D) or special signal assigned to the negative input of the ADC                                                                  |
|       | Value    | Mode    |        | Description                                                                                                                                                                       |
|       | 0        | GND     |        | Ground (single-ended)                                                                                                                                                             |

| Bit | Name    | Reset | Access | Description                                   |
|-----|---------|-------|--------|-----------------------------------------------|
| 2   | DAC1    |       |        | Direct connection to DAC0_CH1                 |
| 4   | PADANA1 |       |        | Direct connection to AIN1 input pin           |
| 5   | PADANA3 |       |        | Direct connection to AIN3 input pin           |
| 8   | PORTA   |       |        | Port A - Select pin number using PINNEG       |
| 9   | PORTB   |       |        | Port B - Select pin number using PINNEG       |
| 10  | PORTC   |       |        | Port C - Select pin number using PINNEG       |
| 11  | PORTD   |       |        | Port D - Select pin number using PINNEG       |
| 3:0 | PINNEG  | 0x0   | RW     | <b>Negative Pin Select</b>                    |
|     |         |       |        | Pin number for the negative input of the ADC. |

## 24. GPIO - General Purpose Input/Output



### Quick Facts

#### What?

The General Purpose Input/Output (GPIO) is used for pin configurations as well as routing for peripheral pin connections.

#### Why?

Easy to use and highly configurable input/output pins are important to fit many communication protocols as well as minimizing software control overhead. Flexible routing of peripheral functions helps to ease PCB layout.

#### How?

Each pin on the device can be individually configured as either an input or an output with several different drive modes. Also, individual bit manipulation registers minimizes control overhead. Peripheral connections to pins can be routed to pins as desired solving congestion and contention issues that may arise with limited routing flexibility. Fully asynchronous interrupts can also be generated from any pin.

### 24.1 Introduction

In the EFR32xG24 devices the General Purpose Input/Output (GPIO) pins are organized into ports with up to 16 pins each. These GPIO pins can be individually configured as either an output or input. More advanced configurations like open-drain, open-source, and glitch filtering can be configured for each individual GPIO pin. Peripheral resources, like Timer PWM outputs or USART RX/TX can be routed to the GPIO pins as desired by the user. Finally, the input value of a pin can be routed through the Peripheral Reflex System to other peripherals or used to trigger an external interrupt.

## 24.2 Features

- Individual configuration for each pin
  - Tristate (reset state)
  - Push-pull
  - Open-drain
  - Pull-up resistor
  - Pull-down resistor
  - Programable Slewrate Control
- EM4 IO pin retention
  - Output enable
  - Output value
  - Pull enable
  - Pull direction
- EM4 wake-up on selected GPIO pins
- Glitch suppression input filter
- Extremely flexible analog and digital resource routing
- Toggle register for output data
- Dedicated data input register (read-only)
- Interrupts
  - Two independent interrupt vectors
  - All GPIO pins are selectable as interrupts in EM0 and EM1
  - All PA and PB GPIO pins are also selectable as interrupts down to EM2 and EM3
  - All EM4 wake-up pins are also available as interrupts in EM0/1/2/3
  - Separate enable, status, set and clear registers
  - Asynchronous sensing
    - Rising, falling or both edges
- Peripheral Reflex System producer
  - All GPIO pins are selectable

## 24.3 Functional Description

An overview of the GPIO module is shown in [Figure 24.1 Pin Configuration on page 809](#). The GPIO pins are grouped into 16-pin ports. Each individual GPIO pin is called Pxn where x indicates the port (A, B, C ...) and n indicates the pin number (0,1,...,15). Fewer than 16 pins may be available on some ports depending on the total number of I/O pins on the package. After a reset, both input and output are disabled for all pins on the device, except for the Serial Wire Debug pins.

To use a pin, the Mode Register (GPIO\_Px\_MODEL/GPIO\_Px\_MODEH) must be configured for the pin to make it an input or output. These registers can also do more advanced configuration, which is covered in [24.3.1 Pin Configuration](#). When the port is configured as an input or an output, the Data In Register (GPIO\_Px\_DIN) can be used to read the level of each pin in the port (bit n in the register is connected to pin n on the port). When configured as an output, the value of the Data Out Register (GPIO\_Px\_DOUT) will be driven to the pin.

The DOUT value can be changed in 4 different ways:

- Writing to the GPIO\_Px\_DOUT register
- Writing the SET address of the GPIO\_Px\_DOUT register sets the DOUT bits
- Writing the CLEAR address of the GPIO\_Px\_DOUT register clears the DOUT bits
- Writing the GPIO\_Px\_DOUTTGL register toggles the corresponding DOUT bits

Reading the GPIO\_Px\_DOUT register will return its contents. Reading the GPIO\_Px\_DOUTTGL register will return 0.



**Figure 24.1. Pin Configuration**

### 24.3.1 Pin Configuration

In addition to setting the pins as either outputs or inputs, the GPIO\_Px\_MODEL and GPIO\_Px\_MODEH registers can be used for more advanced configurations. GPIO\_Px\_MODEL contains 8 bit fields named MODEn ( $n=0,1,\dots,7$ ) which control pins 0-7, while GPIO\_Px\_MODEH contains 8 bit fields named MODEn ( $n=8,9,\dots,15$ ) which control pins 8-15. In some modes GPIO\_Px\_DOUT is also used for extra configurations like pull-up/down and glitch suppression filter enable. [Table 24.1 Pin Configuration on page 810](#) shows the available configurations.

**Table 24.1. Pin Configuration**

| MODEn                   | Input                  | Output                 | DOUT | Pull-down | Pull-up | Alt Port Ctrl | Input Filter | Description                                                       |
|-------------------------|------------------------|------------------------|------|-----------|---------|---------------|--------------|-------------------------------------------------------------------|
| DISABLED                | Disabled if not DINDIS | Disabled               | 0    |           |         |               |              | Input disabled                                                    |
|                         |                        |                        | 1    |           | On      |               |              | Input disabled with pull-up                                       |
| INPUT                   |                        |                        | 0    |           |         |               |              | Input enabled                                                     |
|                         |                        |                        | 1    |           |         | On            |              | Input enabled with filter                                         |
| INPUTPULL               |                        |                        | 0    | On        |         |               |              | Input enabled with pull-down                                      |
|                         |                        |                        | 1    |           | On      |               |              | Input enabled with pull-up                                        |
| INPUTPULLFILTER         |                        |                        | 0    | On        |         | On            |              | Input enabled with pull-down and filter                           |
|                         |                        |                        | 1    |           | On      | On            |              | Input enabled with pull-up and filter                             |
| PUSHPULL                |                        | Push-pull              | x    |           |         |               |              | Push-pull                                                         |
| PUSHPULLALT             |                        |                        | x    |           |         | On            |              | Push-pull with alternate port control values                      |
| WIREDOR                 |                        | Open Source (Wired-OR) | x    |           |         |               |              | Open-source                                                       |
| WIREDORPULLDOWN         |                        |                        | x    | On        |         |               |              | Open-source with pull-down                                        |
| WIREDAND                |                        | Open Drain (Wired-AND) | x    |           |         |               |              | Open-drain                                                        |
| WIREDANDFILTER          |                        |                        | x    |           |         | On            |              | Open-drain with filter                                            |
| WIREDANDPULLUP          |                        |                        | x    |           | On      |               |              | Open-drain with pull-up                                           |
| WIREDANDPULLUPFILTER    |                        |                        | x    |           | On      | On            |              | Open-drain with pull-up and filter                                |
| WIREDANDALT             |                        |                        | x    |           |         | On            |              | Open-drain with alternate port control values                     |
| WIREDANDALTFILTER       |                        |                        | x    |           |         | On            | On           | Open-drain with alternate port control values and filter          |
| WIREDANDALTPULLUP       |                        |                        | x    |           | On      | On            |              | Open-drain with alternate port control values and pull-up         |
| WIREDANDALTPULLUPFILTER |                        |                        | x    |           | On      | On            | On           | Open-drain with alternate port control values, pull-up and filter |

MODEn determines which mode the pin is in at a given time. Setting MODEn to DISABLED disables the pin, reducing power consumption to a minimum. When the output driver and input driver are disabled, the pin can be used as a connection for an analog module. An input is enabled by setting MODEn to any value other than DISABLED while DINDIS for the given port is cleared. Set DINDIS to disable

the input of a GPIO port. The pull-up, pull-down and glitch filter function can optionally be applied to the input, see [Figure 24.2 Tristated Output with Optional Pull-up or Pull-down on page 811](#).



**Figure 24.2. Tristated Output with Optional Pull-up or Pull-down**

When MODEn is PUSH\_PULL or PUSH\_PULLALT, the pin operates in push-pull mode. In this mode, the pin can have alternate port control values and can be driven either high or low, dependent on the value of GPIO\_Px\_DOUT. The push-pull configuration is shown in [Figure 24.3 Push-Pull Configuration on page 811](#).



**Figure 24.3. Push-Pull Configuration**

When MODEn is WIRED\_OR or WIRED\_OR\_PULLDOWN, the pin operates in open-source mode (with a pull-down resistor for WIRED\_OR\_PULLDOWN). When driving a high value in open-source mode, the pull-down is disconnected to save power.

When the mode is prefixed with WIRED\_AND, the pin operates in open-drain mode as shown in [Figure 24.4 Open-drain on page 811](#). In open-drain mode, the pin can have an input filter, a pull-up, alternate port control values or any combination of these. When driving a low value in open-drain mode, the pull-up is disconnected to save power.



**Figure 24.4. Open-drain**

### 24.3.2 Alternate Port Control

The Alternate Port Control allows for additional flexibility of port level settings. A user may setup two different port configurations (normal and alternate modes) and select which is applied on a pin by pin bases. For example you may configure half of port A to use the slowest slew rate while the other half uses a faster slew rate.

Alternate port control is enabled when MODEn is set to any of the ALT enumerated modes (i.e.. PUSHPULLALT). When MODEn is an alternate mode, the pin uses the alternate port control values specified in the DINDISALT and SLEWRATEALT fields in GPIO\_Px\_CTRL. In all other modes, the port control values are used from the DINDIS and SLEWRATE fields in GPIO\_Px\_CTRL.

### 24.3.3 Slew Rate

The slewrate can be applied to pins on a port-by-port basis. The slew rate applied to pins configured using normal MODEn settings can be controlled using the SLEWRATE fields in GPIO\_Px\_CTRL. The slewrate applied to pins configured using the alternate MODEn settings can be controlled using the SLEWRATEALT field.

The lowest slew rate setting has limited drive strength. That is the current is limited to about 1 mA. This setting provides slow switching and limited drive. A slew rate setting of 1 provides the slowest switching with full drive capability. The maximum recommended setting for most digital I/O is 6. A slew rate setting of 7 should only be used for high-speed clock signals, above 10 MHz. A setting of 7 should not be used on more than one pin per port. Please refer to the datasheet for GPIO rise and fall times.

### 24.3.4 Input Disable

The pin inputs can be disabled on a port-by-port basis. The input of pins configured using the normal MODEn settings can be disabled by setting DINDIS in GPIO\_Px\_CTRL. The input of pins configured using the alternate MODEn settings can be disabled by setting DIN- DISALT.

### 24.3.5 Configuration Lock

The GPIO configuration registers (GPIO\_Px\_CTRL, PIO\_Px\_MODEL, GPIO\_xBUSALLOC, GPIO\_EXTIPSELL, GPIO\_EXTIPINSEL, GPIO\_x\_yROUTE, and GPIO\_xROUTEEN) can be locked by writing any value other than 0xA534 to GPIO\_LOCK. Writing the value 0xA534 to the GPIOx\_LOCK register unlocks the configuration registers.

### 24.3.6 EM2 Functionality

While all GPIO pins retain their state in EM2, only pins on port A and B remain fully functional in EM2. Digital peripherals which are active in EM2 must have their resources routed to pins on port A or B to function correctly in EM2. Analog peripherals may use any GPIO pin while in EM2 provided that the ABUS was configured prior to entering EM2. However, analog peripherals that are configured to scan multiple pins while in EM2 (such as the ADC) dynamically reconfigure the ABUS while in EM2 and thus must use only pins on port A and B.

### 24.3.7 EM4 Functionality

By default GPIO pins revert back to their reset state when EM4 is entered. The GPIO pins can be configured to retain the settings for output enable, output value, pull enable, and pull direction while in EM4.

EM4 GPIO retention is controlled with the EM4IORETMODE field in the EMU\_EM4CTRL register:

- Setting EM4IORETMODE to EM4EXIT will cause GPIO retention to persist while in EM4. GPIO state will be reset during wakeup.
- Setting EM4IORETMODE to SWUNLATCH will cause the GPIO retention to persist through EM4 and wakeup, until the EM4UNLATCH bit is written by software. When using SWUNLATCH, the GPIO register values are still reset on wakeup. To ensure the GPIO state does not change, software must re-write the GPIO registers before setting EM4UNLATCH and ending EM4 GPIO retention. Note that the GPIO state cannot be retained through an EM4 wakeup due to a reset (e.g., pin reset or POR reset) - only non-reset methods of EM4 wakeup are supported (e.g., EM4WU IRQ or BURTC IRQ).

See the EMU chapter for additional documentation on EM4IORETMODE and the EM4UNLATCH bit.

### 24.3.8 EM4 Wakeup

It is possible to trigger a wake-up from EM4 using any of the selectable EM4WU GPIO pins. The wake-up request can be triggered through the pins by enabling the corresponding bit in the GPIO\_EM4WUEN register. When EM4 wake-up is enabled for the pin, the input filter is enabled during EM4. This is done to avoid false wake-up caused by glitches. In addition, the polarity of the EM4 wake-up request can be selected using the GPIO\_EM4WUPOL register.



**Figure 24.5. EM4 Wake-up Logic**

The pins used for EM4 wake-up must be configured as inputs with glitch filters using the GPIO\_Px\_MODEL register. If the input is disabled and the wakeup polarity is low, a false wakeup will occur when entering EM4. If the input is enabled, the glitch filtered is disabled, and the polarity is set low, a glitch will occur when going into EM4 that will cause an immediate wake-up. Before going down to EM4, it is important to clear the wake-up logic by setting the GPIO\_IF\_CLR bits, which clear the wake-up logic, including the GPIO\_IF register. It is possible to determine which pin caused the EM4WU by reading the GPIO\_IF register.

Each EM4WU signal is connected to a fixed pin. Refer to the Alternate Function Table in the device Datasheet for the location of each EM4 wakeup signal.

### 24.3.9 Debug Connections

#### 24.3.9.1 JTAG Debug Connection

The JTAG Debug Port is a fixed location resource connected directly to specific GPIO pins. Refer to the Alternate Function Table in the device Datasheet for the location of the JTAG signals. By default TMS, TCK, TDO, and TDI pin connections are enabled with internal pull up, pull down, no pull, and pull up resistors, respectively. It is possible to disable these pin connections (and disable the pull resistors) by setting the SWDIOTMSPEN, SWCLKTCKPEN, TDOPEN, and TDIPEN bits in GPIO\_DEBUGROUTEOPEN to 0.

#### 24.3.9.2 Serial Wire Debug Connection

The SW Debug Port is a fixed location resource connected directly to specific GPIO pins. Refer to the Alternate Function Table in the device Datasheet for the location of the SW Debug port signals. The SWDIO and SWCLK pin connections are enabled by default with internal pull up and pull down resistors, respectively. It is possible to disable these pin connections (and disable the pull resistors) by setting the SWDIOTMSPEN and SWCLKTCKPEN bits in GPIO\_DEBUGROUTEOPEN to 0.

The Serial Wire Viewer pin, SWV, can be enabled by setting the SWVPEN bit in GPIO\_TRACEROUTEOPEN.

**Note:** The SWV pin is not affected by debug lock, so the SWV pin should not be enabled for production devices.

#### 24.3.9.3 Disabling Debug Connections

When the debug pins are disabled, the device can no longer be accessed by a debugger. A reset will set the debug pins back to their enabled default state. The GPIO\_DBGRROUTEPEN register can only be updated when the debugger is disconnected from the system. Any attempts to modify GPIO\_DBGRROUTEPEN when the debugger is connected will not occur. If you do disable the debug pins, make sure you have at least a 3 second timeout at the start of your program code before you disable the debug pins. This way the debugger will have time to connect to the device after a reset and before the pins are disabled.

#### 24.3.9.4 ETM Trace Connections

The device includes ETM trace pins. The trace clock can be enabled by setting the TRACECLKPEN bit-field in GPIO\_TRACEROUTEPEN. The data pin(s) can be enabled individually by setting TRACEDATAxPEN in GPIO\_TRACEROUTEPEN. The trace pins are fixed location resources connected to specific pins. Refer to the Alternate Function Table in the device Datasheet for the location of the ETM trace port signals.

#### 24.3.10 Interrupt Generation

##### 24.3.10.1 Standard Interrupt Generation

The GPIO can generate an interrupt from any edge of the input of any GPIO pin on the device. The standard interrupts have asynchronous sense capability, enabling wake-up from energy modes as low as EM3, see [Figure 24.6 Pin n Interrupt Generation on page 814](#).

**Note:** In EM2 and EM3, only signals on Port A and Port B are available as standard interrupts. Standard interrupts are available to all pins in EM0 and EM1.



**Figure 24.6. Pin n Interrupt Generation**

The standard external pin interrupts are numbered starting with 0. Each interrupt has a corresponding enable bit in the GPIO\_IEN register and an interrupt flag bit in the GPIO\_IF register. Each interrupt may be used with one of four possible pins on any available port. First select the desired port for each interrupt using the corresponding EXTIPSELx field in the GPIO\_EXTIPSELL register. (Some devices with many pins may also have a GPIO\_EXTIPSELH register.)

Each interrupt can be mapped to one of four possible pins on the selected port. External interrupts EXTI0 through EXTI3 may be mapped to pins 0,1,2, or 3 on any available port. External interrupts EXTI4 through EXTI7 may be mapped to pins 4,5,6 or 7 on any available port.

**Note:** Note that while the EXTIEN field in the GPIO\_IEN register has 15 bits, the number of useful bits is limited by the number of pins available in the widest port. If the widest port is 8 bits wide, only the first 8 external interrupts are useful.

The selected pin for each interrupt is the base plus the offset. The base for EXTI0 through EXTI3 is 0, while the base for interrupts EXTI4 through EXTI7 is 4. The base may be calculated by taking the interrupt number, dividing by four, then using only the integer portion of the quotient. (BASE = Integer(N/4))

The offset is selected using the corresponding field in the GPIO\_EXTIPINSELL register. (Some devices with many pins may also have a GPIO\_EXTIPINSELH register.) Subtract the base from the desired pin number to get the offset. For example, to map EXTI5 to pin 7 of PORTA, the base is 4 and the offset will be 3.

The GPIO\_EXTIRISE[n] and GPIO\_EXTIFALL[n] registers enable sensing of rising and falling edges. By setting the EXT[n] bit in GPIO\_IEN, a high interrupt flag n, will trigger one of two interrupt lines. The even interrupt line is triggered by any enabled even numbered interrupt flag index, while the odd interrupt line is triggered by odd flag indexes. The interrupt flags can be set and cleared by software when writing the GPIO\_IF\_SET and GPIO\_IF\_CLR register locations. Since the external interrupts are asynchronous, they are sensitive to noise. To increase noise tolerance, the MODEx field(s) in the GPIO\_Px\_MODEL register, should be set to include glitch filtering for pins that have external interrupts enabled.

### 24.3.10.2 Interrupt Generation on EM4WU Pins

In addition to being an EM4 wake source, any of the dedicated EM4WU (EM4 wake-up) signals on PA, PB, PC or PD may be used to generate edge-sensitive interrupts in EM0, EM1, EM2, and EM3.

In order to enable an EM4WU pin as an interrupt, set the EM4WUIENn field in the GPIO\_IEN register and the EM4WUEEn field in the EM4WUEN register. The EM4WUPOLn field in the GPIO\_EM4WUPOL register is used to set the desired polarity for the interrupt (0 for a falling edge, and 1 for a rising edge).

Upon an interrupt occurring, the corresponding EM4WU index in the GPIO\_IF register will be set along with the odd or even interrupt line depending on the index inside of GPIO\_IF. For example, by setting the EM4WU8 in GPIO\_EM4WUPOL and EM4WU[8] in GPIO\_IEN, the interrupt flag EM4WU[8] in GPIO\_IF will be triggered by a rising edge on pin EM4WU8 and a interrupt request will be sent on IRQ\_GPIO EVEN.

The wake-up granularity of the EM4WU interrupts is based on the settings of the EM4WU field in the GPIO\_IEN register and the EM4WUEN field in the GPIO\_EM4WUEN register (see [Table 24.2 EM4WU Interrupt Energy Mode Wakeup on page 815](#)).

**Table 24.2. EM4WU Interrupt Energy Mode Wakeup**

| EM4WUIENn in GPIO_IEN | EM4WUEEn in GPIO_EM4WUEN | Energy Mode Wakeup              | Interrupt                            |
|-----------------------|--------------------------|---------------------------------|--------------------------------------|
| x                     | 0                        | No Wake                         | No Interrupt                         |
| 0                     | 1                        | Wake from EM4                   | No Interrupt                         |
| 1                     | 1                        | Wake from EM1, EM2, EM3, or EM4 | Interrupt from EM0, EM1, EM2, or EM3 |

For example, to configure the device to wake up and generate an interrupt when PD02 (EM4WU9) sees a falling edge:

1. Set bit 9 of EM4WUEN in the GPIO\_EM4WUEN register to '1'. This enables the asynchronous wake logic.
2. Set bit 9 of EM4WUIEN in the GPIO\_IEN register to '1'. This enables routing of the wake signal to the GPIO\_ODD IRQ.
3. Clear bit 9 of EM4WUPOL in the GPIO\_EM4WUPOL register to '0'. This indicates that the interrupt should occur when a falling edge is detected at the pin.
4. Enable the GPIO.ODD IRQ. The ODD interrupt is used because the bit index of EM4WUIF in GPIO\_IF is odd.

### 24.3.11 Output to PRS

All pins within a group of four(0-3,4-7,8-11,12-15) from all ports are grouped together to form one PRS producer which outputs to the PRS. The pin from which the output should be taken is selected in the same fashion as the edge interrupts.

PRS output is not affected by the interrupt edge detection logic or gated by the IEN bits. See [24.3.10 Interrupt Generation](#) for an illustration of where the PRS output signal is generated.

### 24.3.12 Peripheral Resource Routing

Most peripherals have resources that need to be connected to GPIO pins to function. For example, the I2C has SDA and SCL which need to be connected to pins for the I2C to communicate with other ICs. Resources come in three types. Fixed resources are hard-wired to a pin and can only be accessed in that location. For example the LFXO\_LFXTAL\_I and LFXTAL\_O resources are only available on one pin each. Digital route-able resources are connected to pins through the [24.3.12.1 Digital Bus \(DBUS\)](#) which allows for extremely flexible resource placement. Analog route-able resources are connected to pins though the [24.3.12.2 Analog Bus \(ABUS\)](#) which provides extremely flexible resource placement.

The locations of fixed resources and the limitations of ABUS and DBUS on each device can be found in the device data sheet.

#### 24.3.12.1 Digital Bus (DBUS)

The Digital Bus (DBUS) is an any-to-any switch matrix between peripheral resources and GPIO pins as shown in [Figure 24.7 Digital Bus Interconnect on page 816](#). There are two DBUSES on the EFR32xG24 - DBUSAB serves ports A and B, while DBUSCD serves ports C and D. Not all peripherals have access to both DBUSES.

To connect a resource to a pin, first select the desired PORT and PIN in the `GPIO_x_yROUTE` register, where x is the peripheral name and y is the resource name. The PORT field is encoded as PA = 0, PB = 1, PC = 2, etc. Once the pin is selected, the resource must be enabled by setting its enable bit in the appropriate `GPIO_x_ROUTEEN` register. For example, to route the SDA resource of I2C0 to PB03, set PORT to 0x1 and PIN to 0x3 in `GPIO_I2C0_SDAROUTE`. Then set the `GPIO_I2C0_ROUTEN.SDAPEN` bit.

Any pin connected to a digital resource should be properly configured for that resource (refer to [24.3.1 Pin Configuration](#)). For example, an I2C SDA should be configured as open-drain, a USART (or EUUSART) TX should be configured as push-pull, and a USART (or EUUSART) RX should be configured as an input.



**Figure 24.7. Digital Bus Interconnect**

#### 24.3.12.2 Analog Bus (ABUS)

Analog peripherals may be connected to any pins on port A, B, C, or D via the Analog Bus. There are three analog buses on the EFR32xG24: one dedicated to Port A (ABUSA), one dedicated to port B (ABUSB), and one that serves both ports C and D (ABUSCD). The specific pin and port selection for analog resources are configured in the analog peripherals. Refer to the respective analog peripheral chapter for this information. However, the GPIO block must be configured to grant the peripheral access to an ABUS before any connection can be made.

**Note:** The analog signals on ABUSes will be voltage limited by the lowest supply voltage of IOVDD and AVDD.

Up to two analog peripherals may be given access to an ABUS at any one time and the even/odd pins of each bus are configured independently. This means that a single bus may have up to four different analog peripherals connected to it: two on the even pins and two on the odd pins. The GPIO\_ABUSxALLOC register, where x is the port, determines which peripherals have access to the bus. To grant a peripheral access to the bus even pins select it in either the EVEN0 or EVEN1 field. To grant a peripheral access to the bus odd pins select it in either the ODD0 or ODD1 fields.

When a differential connection is being used, positive inputs are restricted to the EVEN pins and negative inputs are restricted to the ODD pins. When a single ended connection is being used, the positive input is available on all pins.

Peripherals may be given access to as many buses as desired. For example the ADC may be given access to ABUSA, ABUSB, and ABUSCD allowing it to select any pin on ports A-D. If two peripherals select the same port and pin the ABUS will make both connections simultaneously, effectively connecting the two peripherals together.

Any pin connected to an analog resource should be configured to input DISABLED as described in [24.3.1 Pin Configuration](#)

The process for configuring an analog peripheral to access a pin through the ABUS is as follows:

- Configure the desired analog port pins to input DISABLED mode in the corresponding GPIO\_PORTx\_MODEL/H register.
- Configure the corresponding GPIO\_xBUSALLOC field to grant access to the desired peripheral on the desired ABUS.
- Configure the analog peripheral to select the desired port and channel as described in the peripheral chapter.

### 24.3.12.3 Pin Function Tables

This section details the functions and GPIO pins available on the most fully-featured devices in the EFR32xG24 family. Availability of GPIO and signals varies. Refer to the device datasheet for specific peripheral and GPIO availability. Fixed-pin peripheral resources are shown in [Table 24.3 GPIO Alternate Function Table on page 818](#), ABUS routing options are listed in [Table 24.4 ABUS Routing Table on page 819](#), and DBUS routing options are listed in [Table 24.5 DBUS Routing Table on page 820](#).

**Table 24.3. GPIO Alternate Function Table**

| GPIO | Alternate Functions   | QFN48 / Standard Package | QFN48 / ADC Package | WLCSP42 Package | QFN40 / Standard Package | QFN40 / HFCLKOUT Package |
|------|-----------------------|--------------------------|---------------------|-----------------|--------------------------|--------------------------|
| PA00 | IADC0.VREFP           |                          |                     |                 | Yes                      | Yes                      |
| PA01 | GPIO.SWCLK            | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PA02 | GPIO.SWDIO            | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PA03 | GPIO.SWV              | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | GPIO.TDO              | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | GPIO.TRACEDATA0       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PA04 | GPIO.TDI              | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | GPIO.TRACECLK         | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PA05 | GPIO.TRACEDATA1       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | GPIO.EM4WU0           | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PA06 | GPIO.TRACEDATA2       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PA07 | GPIO.TRACEDATA3       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PB00 | VDAC0.CH0_MAIN_OUT    | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PB01 | GPIO.EM4WU3           | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | VDAC0.CH1_MAIN_OUT    | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PB02 | VDAC1.CH0_MAIN_OUT    | Yes                      | Yes                 |                 | Yes                      | Yes                      |
| PB03 | GPIO.EM4WU4           | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | VDAC1.CH1_MAIN_OUT    | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PC00 | GPIO.EM4WU6           | Yes                      | Yes                 |                 | Yes                      | Yes                      |
| PC01 | GPIO.EFP_TX_SDA       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PC02 | GPIO.EFP_TX_SCL       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PC05 | GPIO.EFP_INT          | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | GPIO.EM4WU7           | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PC06 | GPIO.THMSW_EN         |                          |                     |                 |                          | Yes                      |
|      | GPIO.THMSW_HALFSWITCH |                          |                     |                 |                          | Yes                      |
| PC07 | GPIO.EM4WU8           | Yes                      | Yes                 |                 | Yes                      |                          |
|      | GPIO.THMSW_EN         |                          |                     |                 | Yes                      |                          |
|      | GPIO.THMSW_HALFSWITCH |                          |                     |                 | Yes                      |                          |
| PC09 | GPIO.THMSW_EN         | Yes                      | Yes                 | Yes             |                          |                          |
|      | GPIO.THMSW_HALFSWITCH | Yes                      | Yes                 | Yes             |                          |                          |

| GPIO | Alternate Functions | QFN48 / Standard Package | QFN48 / ADC Package | WLCSP42 Package | QFN40 / Standard Package | QFN40 / HFCLKOUT Package |
|------|---------------------|--------------------------|---------------------|-----------------|--------------------------|--------------------------|
| PD00 | LFXO.LFXTAL_O       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PD01 | LFXO.LFXTAL_I       | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
|      | LFXO.LF_EXTCLK      | Yes                      | Yes                 | Yes             | Yes                      | Yes                      |
| PD02 | GPIO.EM4WU9         | Yes                      | Yes                 |                 | Yes                      | Yes                      |
| PD05 | GPIO.EM4WU10        | Yes                      | Yes                 | Yes             |                          |                          |

**Table 24.4. ABUS Routing Table**

| Peripheral | Signal       | PA   |     | PB   |     | PC   |     | PD   |     |
|------------|--------------|------|-----|------|-----|------|-----|------|-----|
|            |              | EVEN | ODD | EVEN | ODD | EVEN | ODD | EVEN | ODD |
| ACMP0      | ana_neg      | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
|            | ana_pos      | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
| ACMP1      | ana_neg      | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
|            | ana_pos      | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
| IADC0      | ana_neg      | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
|            | ana_pos      | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
| VDAC0      | ch0_abus_out | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
|            | ch1_abus_out | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
| VDAC1      | ch0_abus_out | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |
|            | ch1_abus_out | Yes  | Yes | Yes  | Yes | Yes  | Yes | Yes  | Yes |

**Table 24.5. DBUS Routing Table**

| Peripheral.Resource       | PORT      |           |           |           |
|---------------------------|-----------|-----------|-----------|-----------|
|                           | PA        | PB        | PC        | PD        |
| ACMP0.DIGOUT              | Available | Available | Available | Available |
| ACMP1.DIGOUT              | Available | Available | Available | Available |
| CMU.CLKIN0                |           |           | Available | Available |
| CMU.CLKOUT0               |           |           | Available | Available |
| CMU.CLKOUT1               |           |           | Available | Available |
| CMU.CLKOUT2               | Available | Available |           |           |
| EUSART0.CS                | Available | Available |           |           |
| EUSART0.CTS               | Available | Available |           |           |
| EUSART0.RTS               | Available | Available |           |           |
| EUSART0.RX                | Available | Available |           |           |
| EUSART0.SCLK              | Available | Available |           |           |
| EUSART0.TX                | Available | Available |           |           |
| EUSART1.CS                | Available | Available | Available | Available |
| EUSART1.CTS               | Available | Available | Available | Available |
| EUSART1.RTS               | Available | Available | Available | Available |
| EUSART1.RX                | Available | Available | Available | Available |
| EUSART1.SCLK              | Available | Available | Available | Available |
| EUSART1.TX                | Available | Available | Available | Available |
| FRC.DCLK                  |           |           | Available | Available |
| FRC.DFRAME                |           |           | Available | Available |
| FRC.DOUT                  |           |           | Available | Available |
| HFXO0.BUFOUT_REQ_IN_ASYNC | Available | Available |           |           |
| I2C0.SCL                  | Available | Available | Available | Available |
| I2C0.SDA                  | Available | Available | Available | Available |
| I2C1.SCL                  |           |           | Available | Available |
| I2C1.SDA                  |           |           | Available | Available |
| KEYSCAN.COL_OUT_0         | Available | Available | Available | Available |
| KEYSCAN.COL_OUT_1         | Available | Available | Available | Available |
| KEYSCAN.COL_OUT_2         | Available | Available | Available | Available |
| KEYSCAN.COL_OUT_3         | Available | Available | Available | Available |
| KEYSCAN.COL_OUT_4         | Available | Available | Available | Available |
| KEYSCAN.COL_OUT_5         | Available | Available | Available | Available |
| KEYSCAN.COL_OUT_6         | Available | Available | Available | Available |
| KEYSCAN.COL_OUT_7         | Available | Available | Available | Available |

| Peripheral.Resource | PORT      |           |           |           |
|---------------------|-----------|-----------|-----------|-----------|
|                     | PA        | PB        | PC        | PD        |
| KEYSCAN.ROW_SENSE_0 | Available | Available |           |           |
| KEYSCAN.ROW_SENSE_1 | Available | Available |           |           |
| KEYSCAN.ROW_SENSE_2 | Available | Available |           |           |
| KEYSCAN.ROW_SENSE_3 | Available | Available |           |           |
| KEYSCAN.ROW_SENSE_4 | Available | Available |           |           |
| KEYSCAN.ROW_SENSE_5 | Available | Available |           |           |
| LETIMER0.OUT0       | Available | Available |           |           |
| LETIMER0.OUT1       | Available | Available |           |           |
| MODEM.ANT0          | Available | Available | Available | Available |
| MODEM.ANT1          | Available | Available | Available | Available |
| MODEM.ANT_ROLL_OVER |           |           | Available | Available |
| MODEM.ANT_RR0       |           |           | Available | Available |
| MODEM.ANT_RR1       |           |           | Available | Available |
| MODEM.ANT_RR2       |           |           | Available | Available |
| MODEM.ANT_RR3       |           |           | Available | Available |
| MODEM.ANT_RR4       |           |           | Available | Available |
| MODEM.ANT_RR5       |           |           | Available | Available |
| MODEM.ANT_SW_EN     |           |           | Available | Available |
| MODEM.ANT_SW_US     |           |           | Available | Available |
| MODEM.ANT_TRIG      |           |           | Available | Available |
| MODEM.ANT_TRIG_STOP |           |           | Available | Available |
| MODEM.DCLK          | Available | Available |           |           |
| MODEM.DIN           | Available | Available |           |           |
| MODEM.DOUT          | Available | Available |           |           |
| PCNT0.S0IN          | Available | Available |           |           |
| PCNT0.S1IN          | Available | Available |           |           |
| PRS.ASYNCH0         | Available | Available |           |           |
| PRS.ASYNCH1         | Available | Available |           |           |
| PRS.ASYNCH10        |           |           | Available | Available |
| PRS.ASYNCH11        |           |           | Available | Available |
| PRS.ASYNCH12        | Available | Available |           |           |
| PRS.ASYNCH13        | Available | Available |           |           |
| PRS.ASYNCH14        | Available | Available |           |           |
| PRS.ASYNCH15        | Available | Available |           |           |
| PRS.ASYNCH2         | Available | Available |           |           |
| PRS.ASYNCH3         | Available | Available |           |           |

| Peripheral.Resource | PORT      |           |           |           |
|---------------------|-----------|-----------|-----------|-----------|
|                     | PA        | PB        | PC        | PD        |
| PRS.ASYNCH4         | Available | Available |           |           |
| PRS.ASYNCH5         | Available | Available |           |           |
| PRS.ASYNCH6         |           |           | Available | Available |
| PRS.ASYNCH7         |           |           | Available | Available |
| PRS.ASYNCH8         |           |           | Available | Available |
| PRS.ASYNCH9         |           |           | Available | Available |
| PRS.SYNCH0          | Available | Available | Available | Available |
| PRS.SYNCH1          | Available | Available | Available | Available |
| PRS.SYNCH2          | Available | Available | Available | Available |
| PRS.SYNCH3          | Available | Available | Available | Available |
| RAC.LNAEN           | Available | Available | Available | Available |
| RAC.PAEN            | Available | Available | Available | Available |
| TIMER0.CC0          | Available | Available | Available | Available |
| TIMER0.CC1          | Available | Available | Available | Available |
| TIMER0.CC2          | Available | Available | Available | Available |
| TIMER0.CDTI0        | Available | Available | Available | Available |
| TIMER0.CDTI1        | Available | Available | Available | Available |
| TIMER0.CDTI2        | Available | Available | Available | Available |
| TIMER1.CC0          | Available | Available | Available | Available |
| TIMER1.CC1          | Available | Available | Available | Available |
| TIMER1.CC2          | Available | Available | Available | Available |
| TIMER1.CDTI0        | Available | Available | Available | Available |
| TIMER1.CDTI1        | Available | Available | Available | Available |
| TIMER1.CDTI2        | Available | Available | Available | Available |
| TIMER2.CC0          | Available | Available |           |           |
| TIMER2.CC1          | Available | Available |           |           |
| TIMER2.CC2          | Available | Available |           |           |
| TIMER2.CDTI0        | Available | Available |           |           |
| TIMER2.CDTI1        | Available | Available |           |           |
| TIMER2.CDTI2        | Available | Available |           |           |
| TIMER3.CC0          |           |           | Available | Available |
| TIMER3.CC1          |           |           | Available | Available |
| TIMER3.CC2          |           |           | Available | Available |
| TIMER3.CDTI0        |           |           | Available | Available |
| TIMER3.CDTI1        |           |           | Available | Available |
| TIMER3.CDTI2        |           |           | Available | Available |

| Peripheral.Resource | PORT      |           |           |           |
|---------------------|-----------|-----------|-----------|-----------|
|                     | PA        | PB        | PC        | PD        |
| TIMER4.CC0          | Available | Available |           |           |
| TIMER4.CC1          | Available | Available |           |           |
| TIMER4.CC2          | Available | Available |           |           |
| TIMER4.CDTI0        | Available | Available |           |           |
| TIMER4.CDTI1        | Available | Available |           |           |
| TIMER4.CDTI2        | Available | Available |           |           |
| USART0.CLK          | Available | Available | Available | Available |
| USART0.CS           | Available | Available | Available | Available |
| USART0.CTS          | Available | Available | Available | Available |
| USART0.RTS          | Available | Available | Available | Available |
| USART0.RX           | Available | Available | Available | Available |
| USART0.TX           | Available | Available | Available | Available |

#### 24.4 Synchronization

To avoid metastability in synchronous logic connected to the pins, all inputs are synchronized with double flip-flops. The flip-flops for the input data run on the selected APB clock for the GPIO module (PCLK). Consequently, when a pin changes state, the change will propagate to GPIO\_Px\_DIN after two PCLK cycles. Synchronization (also running on the PCLK) is also added for interrupt input. To save power when the external interrupts are not used, the synchronization flip-flops for these can be turned off by clearing the EXTINT field in the GPIO\_IEN register.

## 24.5 GPIO Register Map

The offset register address is relative to the registers base address.

| Offset | Name                                | Type        | Description                             |
|--------|-------------------------------------|-------------|-----------------------------------------|
| 0x000  | <a href="#">GPIO_IPVERSION</a>      | R           | Main                                    |
| 0x030  | <a href="#">GPIO_PORTA_CTRL</a>     | RW          | Port Control                            |
| 0x034  | <a href="#">GPIO_PORTA_MODEL</a>    | RW          | Mode Low                                |
| 0x03C  | <a href="#">GPIO_PORTA_MODEH</a>    | RW          | Mode High                               |
| 0x040  | <a href="#">GPIO_PORTA_DOUT</a>     | RW          | Data Out                                |
| 0x044  | <a href="#">GPIO_PORTA_DIN</a>      | RH          | Data in                                 |
| 0x060  | <a href="#">GPIO_PORTB_CTRL</a>     | RW          | Port Control                            |
| 0x064  | <a href="#">GPIO_PORTB_MODEL</a>    | RW          | Mode Low                                |
| 0x070  | <a href="#">GPIO_PORTB_DOUT</a>     | RW          | Data Out                                |
| 0x074  | <a href="#">GPIO_PORTB_DIN</a>      | RH          | Data in                                 |
| 0x090  | <a href="#">GPIO_PORTC_CTRL</a>     | RW          | Port Control                            |
| 0x094  | <a href="#">GPIO_PORTC_MODEL</a>    | RW          | Mode Low                                |
| 0x09C  | <a href="#">GPIO_PORTC_MODEH</a>    | RW          | Mode High                               |
| 0x0A0  | <a href="#">GPIO_PORTC_DOUT</a>     | RW          | Data Out                                |
| 0x0A4  | <a href="#">GPIO_PORTC_DIN</a>      | RH          | Data in                                 |
| 0x0C0  | <a href="#">GPIO_PORTD_CTRL</a>     | RW          | Port Control                            |
| 0x0C4  | <a href="#">GPIO_PORTD_MODEL</a>    | RW          | Mode Low                                |
| 0x0D0  | <a href="#">GPIO_PORTD_DOUT</a>     | RW          | Data Out                                |
| 0x0D4  | <a href="#">GPIO_PORTD_DIN</a>      | RH          | Data in                                 |
| 0x300  | <a href="#">GPIO_LOCK</a>           | W           | Lock Register                           |
| 0x310  | <a href="#">GPIO_GPIOLOCKSTATUS</a> | RH          | Lock Status                             |
| 0x320  | <a href="#">GPIO_ABUSALLOC</a>      | RW          | A Bus Allocation                        |
| 0x324  | <a href="#">GPIO_BBUSALLOC</a>      | RW          | B Bus Allocation                        |
| 0x328  | <a href="#">GPIO_CDBUSALLOC</a>     | RW          | CD Bus Allocation                       |
| 0x400  | <a href="#">GPIO_EXTIPSELL</a>      | RW          | External Interrupt Port Select Low      |
| 0x404  | <a href="#">GPIO_EXTIPSELH</a>      | RW          | External Interrupt Port Select High     |
| 0x408  | <a href="#">GPIO_EXTIPINSELL</a>    | RW          | External Interrupt Pin Select Low       |
| 0x40C  | <a href="#">GPIO_EXTIPINSELH</a>    | RW          | External Interrupt Pin Select High      |
| 0x410  | <a href="#">GPIO_EXTIRISE</a>       | RW          | External Interrupt Rising Edge Trigger  |
| 0x414  | <a href="#">GPIO_EXTI_FALL</a>      | RW          | External Interrupt Falling Edge Trigger |
| 0x420  | <a href="#">GPIO_IF</a>             | RWH INTFLAG | Interrupt Flag                          |
| 0x424  | <a href="#">GPIO_IEN</a>            | RW          | Interrupt Enable                        |
| 0x42C  | <a href="#">GPIO_EM4WUEN</a>        | RW          | EM4 Wakeup Enable                       |
| 0x430  | <a href="#">GPIO_EM4WUPOL</a>       | RW          | EM4 Wakeup Polarity                     |
| 0x440  | <a href="#">GPIO_DBGROUTEPEN</a>    | RW          | Debugger Route Pin Enable               |

| Offset | Name                                     | Type | Description             |
|--------|------------------------------------------|------|-------------------------|
| 0x444  | <a href="#">GPIO_TRACEROUTEPEN</a>       | RW   | Trace Route Pin Enable  |
| 0x450  | <a href="#">GPIO_ACMP0_ROUTEEN</a>       | RW   | ACMP0 Pin Enable        |
| 0x454  | <a href="#">GPIO_ACMP0_ACMPOUT-ROUTE</a> | RW   | ACMPOUT Port/Pin Select |
| 0x45C  | <a href="#">GPIO_ACMP1_ROUTEEN</a>       | RW   | ACMP1 Pin Enable        |
| 0x460  | <a href="#">GPIO_ACMP1_ACMPOUT-ROUTE</a> | RW   | ACMPOUT Port/Pin Select |
| 0x468  | <a href="#">GPIO_CMU_ROUTEEN</a>         | RW   | CMU Pin Enable          |
| 0x46C  | <a href="#">GPIO_CMU_CLKIN0ROUTE</a>     | RW   | CLKIN0 Port/Pin Select  |
| 0x470  | <a href="#">GPIO_CMU_CLKOUT0ROUTE</a>    | RW   | CLKOUT0 Port/Pin Select |
| 0x474  | <a href="#">GPIO_CMU_CLKOUT1ROUTE</a>    | RW   | CLKOUT1 Port/Pin Select |
| 0x478  | <a href="#">GPIO_CMU_CLKOUT2ROUTE</a>    | RW   | CLKOUT2 Port/Pin Select |
| 0x494  | <a href="#">GPIO_EUSART0_ROUTEEN</a>     | RW   | EUSART0 Pin Enable      |
| 0x498  | <a href="#">GPIO_EUSART0_CSROUTE</a>     | RW   | CS Port/Pin Select      |
| 0x49C  | <a href="#">GPIO_EUSART0_CTSROUTE</a>    | RW   | CTS Port/Pin Select     |
| 0x4A0  | <a href="#">GPIO_EUSART0_RTSROUTE</a>    | RW   | RTS Port/Pin Select     |
| 0x4A4  | <a href="#">GPIO_EUSART0_RXROUTE</a>     | RW   | RX Port/Pin Select      |
| 0x4A8  | <a href="#">GPIO_EUSART0_SCLKROUTE</a>   | RW   | SCLK Port/Pin Select    |
| 0x4AC  | <a href="#">GPIO_EUSART0_TXROUTE</a>     | RW   | TX Port/Pin Select      |
| 0x4B4  | <a href="#">GPIO_EUSART1_ROUTEEN</a>     | RW   | EUSART1 Pin Enable      |
| 0x4B8  | <a href="#">GPIO_EUSART1_CSROUTE</a>     | RW   | CS Port/Pin Select      |
| 0x4BC  | <a href="#">GPIO_EUSART1_CTSROUTE</a>    | RW   | CTS Port/Pin Select     |
| 0x4C0  | <a href="#">GPIO_EUSART1_RTSROUTE</a>    | RW   | RTS Port/Pin Select     |
| 0x4C4  | <a href="#">GPIO_EUSART1_RXROUTE</a>     | RW   | RX Port/Pin Select      |
| 0x4C8  | <a href="#">GPIO_EUSART1_SCLKROUTE</a>   | RW   | SCLK Port/Pin Select    |
| 0x4CC  | <a href="#">GPIO_EUSART1_TXROUTE</a>     | RW   | TX Port/Pin Select      |
| 0x4D4  | <a href="#">GPIO_FRC_ROUTEEN</a>         | RW   | FRC Pin Enable          |
| 0x4D8  | <a href="#">GPIO_FRC_DCLKROUTE</a>       | RW   | DCLK Port/Pin Select    |
| 0x4DC  | <a href="#">GPIO_FRC_DFRAMEROUTE</a>     | RW   | DFRAME Port/Pin Select  |
| 0x4E0  | <a href="#">GPIO_FRC_DOUTROUTE</a>       | RW   | DOUT Port/Pin Select    |
| 0x4E8  | <a href="#">GPIO_I2C0_ROUTEEN</a>        | RW   | I2C0 Pin Enable         |
| 0x4EC  | <a href="#">GPIO_I2C0_SCLROUTE</a>       | RW   | SCL Port/Pin Select     |
| 0x4F0  | <a href="#">GPIO_I2C0_SDAROUTE</a>       | RW   | SDA Port/Pin Select     |
| 0x4F8  | <a href="#">GPIO_I2C1_ROUTEEN</a>        | RW   | I2C1 Pin Enable         |
| 0x4FC  | <a href="#">GPIO_I2C1_SCLROUTE</a>       | RW   | SCL Port/Pin Select     |
| 0x500  | <a href="#">GPIO_I2C1_SDAROUTE</a>       | RW   | SDA Port/Pin Select     |
| 0x508  | <a href="#">GPIO_KEYSCAN_ROUTEEN</a>     | RW   | KEYSCAN Pin Enable      |

| Offset | Name                         | Type | Description                 |
|--------|------------------------------|------|-----------------------------|
| 0x50C  | GPIO_KEYSCAN_COL-OUT0ROUTE   | RW   | COLOUT0 Port/Pin Select     |
| 0x510  | GPIO_KEYSCAN_COL-OUT1ROUTE   | RW   | COLOUT1 Port/Pin Select     |
| 0x514  | GPIO_KEYSCAN_COL-OUT2ROUTE   | RW   | COLOUT2 Port/Pin Select     |
| 0x518  | GPIO_KEYSCAN_COL-OUT3ROUTE   | RW   | COLOUT3 Port/Pin Select     |
| 0x51C  | GPIO_KEYSCAN_COL-OUT4ROUTE   | RW   | COLOUT4 Port/Pin Select     |
| 0x520  | GPIO_KEYSCAN_COL-OUT5ROUTE   | RW   | COLOUT5 Port/Pin Select     |
| 0x524  | GPIO_KEYSCAN_COL-OUT6ROUTE   | RW   | COLOUT6 Port/Pin Select     |
| 0x528  | GPIO_KEYSCAN_COL-OUT7ROUTE   | RW   | COLOUT7 Port/Pin Select     |
| 0x52C  | GPIO_KEYSCAN_ROW-SENSE0ROUTE | RW   | ROWSENSE0 Port/Pin Select   |
| 0x530  | GPIO_KEYSCAN_ROW-SENSE1ROUTE | RW   | ROWSENSE1 Port/Pin Select   |
| 0x534  | GPIO_KEYSCAN_ROW-SENSE2ROUTE | RW   | ROWSENSE2 Port/Pin Select   |
| 0x538  | GPIO_KEYSCAN_ROW-SENSE3ROUTE | RW   | ROWSENSE3 Port/Pin Select   |
| 0x53C  | GPIO_KEYSCAN_ROW-SENSE4ROUTE | RW   | ROWSENSE4 Port/Pin Select   |
| 0x540  | GPIO_KEYSCAN_ROW-SENSE5ROUTE | RW   | ROWSENSE5 Port/Pin Select   |
| 0x548  | GPIO_LETIMER_ROUTEEN         | RW   | LETIMER Pin Enable          |
| 0x54C  | GPIO_LETIMER_OUT0ROUTE       | RW   | OUT0 Port/Pin Select        |
| 0x550  | GPIO_LETIMER_OUT1ROUTE       | RW   | OUT1 Port/Pin Select        |
| 0x558  | GPIO_MODEM_ROUTEEN           | RW   | MODEM Pin Enable            |
| 0x55C  | GPIO_MODEM_ANT0ROUTE         | RW   | ANT0 Port/Pin Select        |
| 0x560  | GPIO_MODEM_ANT1ROUTE         | RW   | ANT1 Port/Pin Select        |
| 0x564  | GPIO_MODEM_ANTROLLO-VERROUTE | RW   | ANTROLLOVER Port/Pin Select |
| 0x568  | GPIO_MO-DEM_ANTRR0ROUTE      | RW   | ANTRR0 Port/Pin Select      |
| 0x56C  | GPIO_MO-DEM_ANTRR1ROUTE      | RW   | ANTRR1 Port/Pin Select      |
| 0x570  | GPIO_MO-DEM_ANTRR2ROUTE      | RW   | ANTRR2 Port/Pin Select      |
| 0x574  | GPIO_MO-DEM_ANTRR3ROUTE      | RW   | ANTRR3 Port/Pin Select      |

| Offset | Name                         | Type | Description                 |
|--------|------------------------------|------|-----------------------------|
| 0x578  | GPIO_MO-DEM_ANTRR4ROUTE      | RW   | ANTRR4 Port/Pin Select      |
| 0x57C  | GPIO_MO-DEM_ANTRR5ROUTE      | RW   | ANTRR5 Port/Pin Select      |
| 0x580  | GPIO_MODEM_ANTSWEN-ROUTE     | RW   | ANTSWEN Port/Pin Select     |
| 0x584  | GPIO_MODEM_ANTSWUS-ROUTE     | RW   | ANTSWUS Port/Pin Select     |
| 0x588  | GPIO_MODEM_ANTTRIG-ROUTE     | RW   | ANTTRIG Port/Pin Select     |
| 0x58C  | GPIO_MODEM_ANTTRIGSTOP-ROUTE | RW   | ANTTRIGSTOP Port/Pin Select |
| 0x590  | GPIO_MODEM_DCLKROUTE         | RW   | DCLK Port/Pin Select        |
| 0x594  | GPIO_MODEM_DINROUTE          | RW   | DIN Port/Pin Select         |
| 0x598  | GPIO_MODEM_DOUTROUTE         | RW   | DOUT Port/Pin Select        |
| 0x5A4  | GPIO_PCNT0_S0INROUTE         | RW   | S0IN Port/Pin Select        |
| 0x5A8  | GPIO_PCNT0_S1INROUTE         | RW   | S1IN Port/Pin Select        |
| 0x5B0  | GPIO_PRS0_ROUTEEN            | RW   | PRS0 Pin Enable             |
| 0x5B4  | GPIO_PRS0_ASYNCH0ROUTE       | RW   | ASYNCH0 Port/Pin Select     |
| 0x5B8  | GPIO_PRS0_ASYNCH1ROUTE       | RW   | ASYNCH1 Port/Pin Select     |
| 0x5BC  | GPIO_PRS0_ASYNCH2ROUTE       | RW   | ASYNCH2 Port/Pin Select     |
| 0x5C0  | GPIO_PRS0_ASYNCH3ROUTE       | RW   | ASYNCH3 Port/Pin Select     |
| 0x5C4  | GPIO_PRS0_ASYNCH4ROUTE       | RW   | ASYNCH4 Port/Pin Select     |
| 0x5C8  | GPIO_PRS0_ASYNCH5ROUTE       | RW   | ASYNCH5 Port/Pin Select     |
| 0x5CC  | GPIO_PRS0_ASYNCH6ROUTE       | RW   | ASYNCH6 Port/Pin Select     |
| 0x5D0  | GPIO_PRS0_ASYNCH7ROUTE       | RW   | ASYNCH7 Port/Pin Select     |
| 0x5D4  | GPIO_PRS0_ASYNCH8ROUTE       | RW   | ASYNCH8 Port/Pin Select     |
| 0x5D8  | GPIO_PRS0_ASYNCH9ROUTE       | RW   | ASYNCH9 Port/Pin Select     |
| 0x5DC  | GPIO_PRS0_ASYNCH10ROUTE      | RW   | ASYNCH10 Port/Pin Select    |
| 0x5E0  | GPIO_PRS0_ASYNCH11ROUTE      | RW   | ASYNCH11 Port/Pin Select    |
| 0x5E4  | GPIO_PRS0_ASYNCH12ROUTE      | RW   | ASYNCH12 Port/Pin Select    |
| 0x5E8  | GPIO_PRS0_ASYNCH13ROUTE      | RW   | ASYNCH13 Port/Pin Select    |
| 0x5EC  | GPIO_PRS0_ASYNCH14ROUTE      | RW   | ASYNCH14 Port/Pin Select    |
| 0x5F0  | GPIO_PRS0_ASYNCH15ROUTE      | RW   | ASYNCH15 Port/Pin Select    |
| 0x5F4  | GPIO_PRS0_SYNCH0ROUTE        | RW   | SYNCH0 Port/Pin Select      |
| 0x5F8  | GPIO_PRS0_SYNCH1ROUTE        | RW   | SYNCH1 Port/Pin Select      |

| Offset | Name                                              | Type | Description                      |
|--------|---------------------------------------------------|------|----------------------------------|
| 0x5FC  | <a href="#">GPIO_PRS0_SYNCH2ROUTE</a>             | RW   | SYNCH2 Port/Pin Select           |
| 0x600  | <a href="#">GPIO_PRS0_SYNCH3ROUTE</a>             | RW   | SYNCH3 Port/Pin Select           |
| 0x608  | <a href="#">GPIO_RAC_ROUTEEN</a>                  | RW   | RAC Pin Enable                   |
| 0x60C  | <a href="#">GPIO_RAC_LNAENROUTE</a>               | RW   | LNAEN Port/Pin Select            |
| 0x610  | <a href="#">GPIO_RAC_PAENROUTE</a>                | RW   | PAEN Port/Pin Select             |
| 0x678  | <a href="#">GPIO_SYX00_BUFOUTREQINASYNCRROUTE</a> | RW   | BUFOUTREQINASYNC Port/Pin Select |
| 0x680  | <a href="#">GPIO_TIMER0_ROUTEEN</a>               | RW   | TIMER0 Pin Enable                |
| 0x684  | <a href="#">GPIO_TIMER0_CC0ROUTE</a>              | RW   | CC0 Port/Pin Select              |
| 0x688  | <a href="#">GPIO_TIMER0_CC1ROUTE</a>              | RW   | CC1 Port/Pin Select              |
| 0x68C  | <a href="#">GPIO_TIMER0_CC2ROUTE</a>              | RW   | CC2 Port/Pin Select              |
| 0x690  | <a href="#">GPIO_TIMER0_CDTI0ROUTE</a>            | RW   | CDTI0 Port/Pin Select            |
| 0x694  | <a href="#">GPIO_TIMER0_CDTI1ROUTE</a>            | RW   | CDTI1 Port/Pin Select            |
| 0x698  | <a href="#">GPIO_TIMER0_CDTI2ROUTE</a>            | RW   | CDTI2 Port/Pin Select            |
| 0x6A0  | <a href="#">GPIO_TIMER1_ROUTEEN</a>               | RW   | TIMER1 Pin Enable                |
| 0x6A4  | <a href="#">GPIO_TIMER1_CC0ROUTE</a>              | RW   | CC0 Port/Pin Select              |
| 0x6A8  | <a href="#">GPIO_TIMER1_CC1ROUTE</a>              | RW   | CC1 Port/Pin Select              |
| 0x6AC  | <a href="#">GPIO_TIMER1_CC2ROUTE</a>              | RW   | CC2 Port/Pin Select              |
| 0x6B0  | <a href="#">GPIO_TIMER1_CDTI0ROUTE</a>            | RW   | CDTI0 Port/Pin Select            |
| 0x6B4  | <a href="#">GPIO_TIMER1_CDTI1ROUTE</a>            | RW   | CDTI1 Port/Pin Select            |
| 0x6B8  | <a href="#">GPIO_TIMER1_CDTI2ROUTE</a>            | RW   | CDTI2 Port/Pin Select            |
| 0x6C0  | <a href="#">GPIO_TIMER2_ROUTEEN</a>               | RW   | TIMER2 Pin Enable                |
| 0x6C4  | <a href="#">GPIO_TIMER2_CC0ROUTE</a>              | RW   | CC0 Port/Pin Select              |
| 0x6C8  | <a href="#">GPIO_TIMER2_CC1ROUTE</a>              | RW   | CC1 Port/Pin Select              |
| 0x6CC  | <a href="#">GPIO_TIMER2_CC2ROUTE</a>              | RW   | CC2 Port/Pin Select              |
| 0x6D0  | <a href="#">GPIO_TIMER2_CDTI0ROUTE</a>            | RW   | CDTI0 Port/Pin Select            |
| 0x6D4  | <a href="#">GPIO_TIMER2_CDTI1ROUTE</a>            | RW   | CDTI1 Port/Pin Select            |
| 0x6D8  | <a href="#">GPIO_TIMER2_CDTI2ROUTE</a>            | RW   | CDTI2 Port/Pin Select            |
| 0x6E0  | <a href="#">GPIO_TIMER3_ROUTEEN</a>               | RW   | TIMER3 Pin Enable                |
| 0x6E4  | <a href="#">GPIO_TIMER3_CC0ROUTE</a>              | RW   | CC0 Port/Pin Select              |
| 0x6E8  | <a href="#">GPIO_TIMER3_CC1ROUTE</a>              | RW   | CC1 Port/Pin Select              |
| 0x6EC  | <a href="#">GPIO_TIMER3_CC2ROUTE</a>              | RW   | CC2 Port/Pin Select              |
| 0x6F0  | <a href="#">GPIO_TIMER3_CDTI0ROUTE</a>            | RW   | CDTI0 Port/Pin Select            |
| 0x6F4  | <a href="#">GPIO_TIMER3_CDTI1ROUTE</a>            | RW   | CDTI1 Port/Pin Select            |
| 0x6F8  | <a href="#">GPIO_TIMER3_CDTI2ROUTE</a>            | RW   | CDTI2 Port/Pin Select            |
| 0x700  | <a href="#">GPIO_TIMER4_ROUTEEN</a>               | RW   | TIMER4 Pin Enable                |
| 0x704  | <a href="#">GPIO_TIMER4_CC0ROUTE</a>              | RW   | CC0 Port/Pin Select              |

| Offset | Name                                    | Type | Description                        |
|--------|-----------------------------------------|------|------------------------------------|
| 0x708  | <a href="#">GPIO_TIMER4_CC1ROUTE</a>    | RW   | CC1 Port/Pin Select                |
| 0x70C  | <a href="#">GPIO_TIMER4_CC2ROUTE</a>    | RW   | CC2 Port/Pin Select                |
| 0x710  | <a href="#">GPIO_TIMER4_CDTI0ROUTE</a>  | RW   | CDTI0 Port/Pin Select              |
| 0x714  | <a href="#">GPIO_TIMER4_CDTI1ROUTE</a>  | RW   | CDTI1 Port/Pin Select              |
| 0x718  | <a href="#">GPIO_TIMER4_CDTI2ROUTE</a>  | RW   | CDTI2 Port/Pin Select              |
| 0x720  | <a href="#">GPIO_USART0_ROUTEEN</a>     | RW   | USART0 Pin Enable                  |
| 0x724  | <a href="#">GPIO_USART0_CSROUTE</a>     | RW   | CS Port/Pin Select                 |
| 0x728  | <a href="#">GPIO_USART0_CTSROUTE</a>    | RW   | CTS Port/Pin Select                |
| 0x72C  | <a href="#">GPIO_USART0_RTSROUTE</a>    | RW   | RTS Port/Pin Select                |
| 0x730  | <a href="#">GPIO_USART0_RXROUTE</a>     | RW   | RX Port/Pin Select                 |
| 0x734  | <a href="#">GPIO_USART0_CLKROUTE</a>    | RW   | SCLK Port/Pin Select               |
| 0x738  | <a href="#">GPIO_USART0_TXROUTE</a>     | RW   | TX Port/Pin Select                 |
| 0x1000 | <a href="#">GPIO_IPVERSION_SET</a>      | R    | Main                               |
| 0x1030 | <a href="#">GPIO_PORTA_CTRL_SET</a>     | RW   | Port Control                       |
| 0x1034 | <a href="#">GPIO_PORTA_MODEL_SET</a>    | RW   | Mode Low                           |
| 0x103C | <a href="#">GPIO_PORTA_MODEH_SET</a>    | RW   | Mode High                          |
| 0x1040 | <a href="#">GPIO_PORTA_DOUT_SET</a>     | RW   | Data Out                           |
| 0x1044 | <a href="#">GPIO_PORTA_DIN_SET</a>      | RH   | Data in                            |
| 0x1060 | <a href="#">GPIO_PORTB_CTRL_SET</a>     | RW   | Port Control                       |
| 0x1064 | <a href="#">GPIO_PORTB_MODEL_SET</a>    | RW   | Mode Low                           |
| 0x1070 | <a href="#">GPIO_PORTB_DOUT_SET</a>     | RW   | Data Out                           |
| 0x1074 | <a href="#">GPIO_PORTB_DIN_SET</a>      | RH   | Data in                            |
| 0x1090 | <a href="#">GPIO_PORTC_CTRL_SET</a>     | RW   | Port Control                       |
| 0x1094 | <a href="#">GPIO_PORTC_MODEL_SET</a>    | RW   | Mode Low                           |
| 0x109C | <a href="#">GPIO_PORTC_MODEH_SET</a>    | RW   | Mode High                          |
| 0x10A0 | <a href="#">GPIO_PORTC_DOUT_SET</a>     | RW   | Data Out                           |
| 0x10A4 | <a href="#">GPIO_PORTC_DIN_SET</a>      | RH   | Data in                            |
| 0x10C0 | <a href="#">GPIO_PORTD_CTRL_SET</a>     | RW   | Port Control                       |
| 0x10C4 | <a href="#">GPIO_PORTD_MODEL_SET</a>    | RW   | Mode Low                           |
| 0x10D0 | <a href="#">GPIO_PORTD_DOUT_SET</a>     | RW   | Data Out                           |
| 0x10D4 | <a href="#">GPIO_PORTD_DIN_SET</a>      | RH   | Data in                            |
| 0x1300 | <a href="#">GPIO_LOCK_SET</a>           | W    | Lock Register                      |
| 0x1310 | <a href="#">GPIO_GPIOLOCKSTATUS_SET</a> | RH   | Lock Status                        |
| 0x1320 | <a href="#">GPIO_ABUSALLOC_SET</a>      | RW   | A Bus Allocation                   |
| 0x1324 | <a href="#">GPIO_BBUSALLOC_SET</a>      | RW   | B Bus Allocation                   |
| 0x1328 | <a href="#">GPIO_CDBUSALLOC_SET</a>     | RW   | CD Bus Allocation                  |
| 0x1400 | <a href="#">GPIO_EXTIPSELL_SET</a>      | RW   | External Interrupt Port Select Low |

| Offset | Name                         | Type        | Description                             |
|--------|------------------------------|-------------|-----------------------------------------|
| 0x1404 | GPIO_EXTIPSELH_SET           | RW          | External Interrupt Port Select High     |
| 0x1408 | GPIO_EXTIPINSELL_SET         | RW          | External Interrupt Pin Select Low       |
| 0x140C | GPIO_EXTIPINSELH_SET         | RW          | External Interrupt Pin Select High      |
| 0x1410 | GPIO_EXTIRISE_SET            | RW          | External Interrupt Rising Edge Trigger  |
| 0x1414 | GPIO_EXTIALL_SET             | RW          | External Interrupt Falling Edge Trigger |
| 0x1420 | GPIO_IF_SET                  | RWH INTFLAG | Interrupt Flag                          |
| 0x1424 | GPIO_IEN_SET                 | RW          | Interrupt Enable                        |
| 0x142C | GPIO_EM4WUEN_SET             | RW          | EM4 Wakeup Enable                       |
| 0x1430 | GPIO_EM4WUPOL_SET            | RW          | EM4 Wakeup Polarity                     |
| 0x1440 | GPIO_DBGROUTEPEN_SET         | RW          | Debugger Route Pin Enable               |
| 0x1444 | GPIO_TRACEROUTEPEN_SET       | RW          | Trace Route Pin Enable                  |
| 0x1450 | GPIO_ACMP0_ROUTEEN_SET       | RW          | ACMP0 Pin Enable                        |
| 0x1454 | GPIO_ACMP0_ACMPOUT-ROUTE_SET | RW          | ACMPOUT Port/Pin Select                 |
| 0x145C | GPIO_ACMP1_ROUTEEN_SET       | RW          | ACMP1 Pin Enable                        |
| 0x1460 | GPIO_ACMP1_ACMPOUT-ROUTE_SET | RW          | ACMPOUT Port/Pin Select                 |
| 0x1468 | GPIO_CMU_ROUTEEN_SET         | RW          | CMU Pin Enable                          |
| 0x146C | GPIO_CMU_CLKIN0ROUTE_SET     | RW          | CLKIN0 Port/Pin Select                  |
| 0x1470 | GPIO_CMU_CLKOUT0ROUTE_SET    | RW          | CLKOUT0 Port/Pin Select                 |
| 0x1474 | GPIO_CMU_CLKOUT1ROUTE_SET    | RW          | CLKOUT1 Port/Pin Select                 |
| 0x1478 | GPIO_CMU_CLKOUT2ROUTE_SET    | RW          | CLKOUT2 Port/Pin Select                 |
| 0x1494 | GPIO_EUSART0_ROUTEEN_SET     | RW          | EUSART0 Pin Enable                      |
| 0x1498 | GPIO_EUSART0_CSROUTE_SET     | RW          | CS Port/Pin Select                      |
| 0x149C | GPIO_EUSART0_CTSROUTE_SET    | RW          | CTS Port/Pin Select                     |
| 0x14A0 | GPIO_EUSART0_RTSROUTE_SET    | RW          | RTS Port/Pin Select                     |
| 0x14A4 | GPIO_EUSART0_RXROUTE_SET     | RW          | RX Port/Pin Select                      |
| 0x14A8 | GPIO_EUSART0_SCLKROUTE_SET   | RW          | SCLK Port/Pin Select                    |
| 0x14AC | GPIO_EUSART0_TXROUTE_SET     | RW          | TX Port/Pin Select                      |
| 0x14B4 | GPIO_EUSART1_ROUTEEN_SET     | RW          | EUSART1 Pin Enable                      |

| Offset | Name                             | Type | Description               |
|--------|----------------------------------|------|---------------------------|
| 0x14B8 | GPIO_EU-SART1_CSROUTE_SET        | RW   | CS Port/Pin Select        |
| 0x14BC | GPIO_EU-SART1_CTSROUTE_SET       | RW   | CTS Port/Pin Select       |
| 0x14C0 | GPIO_EU-SART1_RTSPROUTE_SET      | RW   | RTS Port/Pin Select       |
| 0x14C4 | GPIO_EU-SART1_RXROUTE_SET        | RW   | RX Port/Pin Select        |
| 0x14C8 | GPIO_EU-SART1_SCLKROUTE_SET      | RW   | SCLK Port/Pin Select      |
| 0x14CC | GPIO_EU-SART1_TXROUTE_SET        | RW   | TX Port/Pin Select        |
| 0x14D4 | GPIO_FRC_ROUTEEN_SET             | RW   | FRC Pin Enable            |
| 0x14D8 | GPIO_FRC_DCLKROUTE_SET           | RW   | DCLK Port/Pin Select      |
| 0x14DC | GPIO_FRC_DFRAME-ROUTE_SET        | RW   | DFRAME Port/Pin Select    |
| 0x14E0 | GPIO_FRC_DOUTROUTE_SET           | RW   | DOUT Port/Pin Select      |
| 0x14E8 | GPIO_I2C0_ROUTEEN_SET            | RW   | I2C0 Pin Enable           |
| 0x14EC | GPIO_I2C0_SCLROUTE_SET           | RW   | SCL Port/Pin Select       |
| 0x14F0 | GPIO_I2C0_SDAROUTE_SET           | RW   | SDA Port/Pin Select       |
| 0x14F8 | GPIO_I2C1_ROUTEEN_SET            | RW   | I2C1 Pin Enable           |
| 0x14FC | GPIO_I2C1_SCLROUTE_SET           | RW   | SCL Port/Pin Select       |
| 0x1500 | GPIO_I2C1_SDAROUTE_SET           | RW   | SDA Port/Pin Select       |
| 0x1508 | GPIO_KEYSCAN_ROUTEEEN_SET        | RW   | KEYSCAN Pin Enable        |
| 0x150C | GPIO_KEYSCAN_COL-OUT0ROUTE_SET   | RW   | COLOUT0 Port/Pin Select   |
| 0x1510 | GPIO_KEYSCAN_COL-OUT1ROUTE_SET   | RW   | COLOUT1 Port/Pin Select   |
| 0x1514 | GPIO_KEYSCAN_COL-OUT2ROUTE_SET   | RW   | COLOUT2 Port/Pin Select   |
| 0x1518 | GPIO_KEYSCAN_COL-OUT3ROUTE_SET   | RW   | COLOUT3 Port/Pin Select   |
| 0x151C | GPIO_KEYSCAN_COL-OUT4ROUTE_SET   | RW   | COLOUT4 Port/Pin Select   |
| 0x1520 | GPIO_KEYSCAN_COL-OUT5ROUTE_SET   | RW   | COLOUT5 Port/Pin Select   |
| 0x1524 | GPIO_KEYSCAN_COL-OUT6ROUTE_SET   | RW   | COLOUT6 Port/Pin Select   |
| 0x1528 | GPIO_KEYSCAN_COL-OUT7ROUTE_SET   | RW   | COLOUT7 Port/Pin Select   |
| 0x152C | GPIO_KEYSCAN_ROW-SENSE0ROUTE_SET | RW   | ROWSENSE0 Port/Pin Select |

| Offset | Name                             | Type | Description                 |
|--------|----------------------------------|------|-----------------------------|
| 0x1530 | GPIO_KEYSCAN_ROW-SENSE1ROUTE_SET | RW   | ROWSENSE1 Port/Pin Select   |
| 0x1534 | GPIO_KEYSCAN_ROW-SENSE2ROUTE_SET | RW   | ROWSENSE2 Port/Pin Select   |
| 0x1538 | GPIO_KEYSCAN_ROW-SENSE3ROUTE_SET | RW   | ROWSENSE3 Port/Pin Select   |
| 0x153C | GPIO_KEYSCAN_ROW-SENSE4ROUTE_SET | RW   | ROWSENSE4 Port/Pin Select   |
| 0x1540 | GPIO_KEYSCAN_ROW-SENSE5ROUTE_SET | RW   | ROWSENSE5 Port/Pin Select   |
| 0x1548 | GPIO_LETIMER_ROU-TEEN_SET        | RW   | LETIMER Pin Enable          |
| 0x154C | GPIO_LETIM-ER_OUT0ROUTE_SET      | RW   | OUT0 Port/Pin Select        |
| 0x1550 | GPIO_LETIM-ER_OUT1ROUTE_SET      | RW   | OUT1 Port/Pin Select        |
| 0x1558 | GPIO_MODEM_ROUTEEN_SET           | RW   | MODEM Pin Enable            |
| 0x155C | GPIO_MO-DEM_ANT0ROUTE_SET        | RW   | ANT0 Port/Pin Select        |
| 0x1560 | GPIO_MO-DEM_ANT1ROUTE_SET        | RW   | ANT1 Port/Pin Select        |
| 0x1564 | GPIO_MODEM_ANTROLLO-VERROUTE_SET | RW   | ANTROLLOVER Port/Pin Select |
| 0x1568 | GPIO_MO-DEM_ANTRR0ROUTE_SET      | RW   | ANTRR0 Port/Pin Select      |
| 0x156C | GPIO_MO-DEM_ANTRR1ROUTE_SET      | RW   | ANTRR1 Port/Pin Select      |
| 0x1570 | GPIO_MO-DEM_ANTRR2ROUTE_SET      | RW   | ANTRR2 Port/Pin Select      |
| 0x1574 | GPIO_MO-DEM_ANTRR3ROUTE_SET      | RW   | ANTRR3 Port/Pin Select      |
| 0x1578 | GPIO_MO-DEM_ANTRR4ROUTE_SET      | RW   | ANTRR4 Port/Pin Select      |
| 0x157C | GPIO_MO-DEM_ANTRR5ROUTE_SET      | RW   | ANTRR5 Port/Pin Select      |
| 0x1580 | GPIO_MODEM_ANTSWEN-ROUTE_SET     | RW   | ANTSWEN Port/Pin Select     |
| 0x1584 | GPIO_MODEM_ANTSWUS-ROUTE_SET     | RW   | ANTSWUS Port/Pin Select     |
| 0x1588 | GPIO_MODEM_ANTTRIG-ROUTE_SET     | RW   | ANTTRIG Port/Pin Select     |
| 0x158C | GPIO_MODEM_ANTRIGSTOP-ROUTE_SET  | RW   | ANTTRIGSTOP Port/Pin Select |
| 0x1590 | GPIO_MO-DEM_DCLKROUTE_SET        | RW   | DCLK Port/Pin Select        |
| 0x1594 | GPIO_MODEM_DIN-ROUTE_SET         | RW   | DIN Port/Pin Select         |

| Offset | Name                        | Type | Description              |
|--------|-----------------------------|------|--------------------------|
| 0x1598 | GPIO_MODEM_DOUT_ROUTE_SET   | RW   | DOUT Port/Pin Select     |
| 0x15A4 | GPIO_PCNT0_S0IN_ROUTE_SET   | RW   | S0IN Port/Pin Select     |
| 0x15A8 | GPIO_PCNT0_S1IN_ROUTE_SET   | RW   | S1IN Port/Pin Select     |
| 0x15B0 | GPIO_PRS0_ROUTEEN_SET       | RW   | PRS0 Pin Enable          |
| 0x15B4 | GPIO_PRS0_ASYNCH0ROUTE_SET  | RW   | ASYNCH0 Port/Pin Select  |
| 0x15B8 | GPIO_PRS0_ASYNCH1ROUTE_SET  | RW   | ASYNCH1 Port/Pin Select  |
| 0x15BC | GPIO_PRS0_ASYNCH2ROUTE_SET  | RW   | ASYNCH2 Port/Pin Select  |
| 0x15C0 | GPIO_PRS0_ASYNCH3ROUTE_SET  | RW   | ASYNCH3 Port/Pin Select  |
| 0x15C4 | GPIO_PRS0_ASYNCH4ROUTE_SET  | RW   | ASYNCH4 Port/Pin Select  |
| 0x15C8 | GPIO_PRS0_ASYNCH5ROUTE_SET  | RW   | ASYNCH5 Port/Pin Select  |
| 0x15CC | GPIO_PRS0_ASYNCH6ROUTE_SET  | RW   | ASYNCH6 Port/Pin Select  |
| 0x15D0 | GPIO_PRS0_ASYNCH7ROUTE_SET  | RW   | ASYNCH7 Port/Pin Select  |
| 0x15D4 | GPIO_PRS0_ASYNCH8ROUTE_SET  | RW   | ASYNCH8 Port/Pin Select  |
| 0x15D8 | GPIO_PRS0_ASYNCH9ROUTE_SET  | RW   | ASYNCH9 Port/Pin Select  |
| 0x15DC | GPIO_PRS0_ASYNCH10ROUTE_SET | RW   | ASYNCH10 Port/Pin Select |
| 0x15E0 | GPIO_PRS0_ASYNCH11ROUTE_SET | RW   | ASYNCH11 Port/Pin Select |
| 0x15E4 | GPIO_PRS0_ASYNCH12ROUTE_SET | RW   | ASYNCH12 Port/Pin Select |
| 0x15E8 | GPIO_PRS0_ASYNCH13ROUTE_SET | RW   | ASYNCH13 Port/Pin Select |
| 0x15EC | GPIO_PRS0_ASYNCH14ROUTE_SET | RW   | ASYNCH14 Port/Pin Select |
| 0x15F0 | GPIO_PRS0_ASYNCH15ROUTE_SET | RW   | ASYNCH15 Port/Pin Select |
| 0x15F4 | GPIO_PRS0_SYNCH0ROUTE_SET   | RW   | SYNCH0 Port/Pin Select   |
| 0x15F8 | GPIO_PRS0_SYNCH1ROUTE_SET   | RW   | SYNCH1 Port/Pin Select   |
| 0x15FC | GPIO_PRS0_SYNCH2ROUTE_SET   | RW   | SYNCH2 Port/Pin Select   |
| 0x1600 | GPIO_PRS0_SYNCH3ROUTE_SET   | RW   | SYNCH3 Port/Pin Select   |

| Offset | Name                                  | Type | Description                      |
|--------|---------------------------------------|------|----------------------------------|
| 0x1608 | GPIO_RAC_ROUTEEN_SET                  | RW   | RAC Pin Enable                   |
| 0x160C | GPIO_RAC_LNAEN-ROUTE_SET              | RW   | LNAEN Port/Pin Select            |
| 0x1610 | GPIO_RAC_PAENROUTE_SET                | RW   | PAEN Port/Pin Select             |
| 0x1678 | GPIO_SYX00_BUFOUTREQINASYNCRROUTE_SET | RW   | BUFOUTREQINASYNC Port/Pin Select |
| 0x1680 | GPIO_TIMER0_ROUTEEN_SET               | RW   | TIMER0 Pin Enable                |
| 0x1684 | GPIO_TIM-ER0_CC0ROUTE_SET             | RW   | CC0 Port/Pin Select              |
| 0x1688 | GPIO_TIM-ER0_CC1ROUTE_SET             | RW   | CC1 Port/Pin Select              |
| 0x168C | GPIO_TIM-ER0_CC2ROUTE_SET             | RW   | CC2 Port/Pin Select              |
| 0x1690 | GPIO_TIM-ER0_CDTI0ROUTE_SET           | RW   | CDTI0 Port/Pin Select            |
| 0x1694 | GPIO_TIM-ER0_CDTI1ROUTE_SET           | RW   | CDTI1 Port/Pin Select            |
| 0x1698 | GPIO_TIM-ER0_CDTI2ROUTE_SET           | RW   | CDTI2 Port/Pin Select            |
| 0x16A0 | GPIO_TIMER1_ROUTEEN_SET               | RW   | TIMER1 Pin Enable                |
| 0x16A4 | GPIO_TIM-ER1_CC0ROUTE_SET             | RW   | CC0 Port/Pin Select              |
| 0x16A8 | GPIO_TIM-ER1_CC1ROUTE_SET             | RW   | CC1 Port/Pin Select              |
| 0x16AC | GPIO_TIM-ER1_CC2ROUTE_SET             | RW   | CC2 Port/Pin Select              |
| 0x16B0 | GPIO_TIM-ER1_CDTI0ROUTE_SET           | RW   | CDTI0 Port/Pin Select            |
| 0x16B4 | GPIO_TIM-ER1_CDTI1ROUTE_SET           | RW   | CDTI1 Port/Pin Select            |
| 0x16B8 | GPIO_TIM-ER1_CDTI2ROUTE_SET           | RW   | CDTI2 Port/Pin Select            |
| 0x16C0 | GPIO_TIMER2_ROUTEEN_SET               | RW   | TIMER2 Pin Enable                |
| 0x16C4 | GPIO_TIM-ER2_CC0ROUTE_SET             | RW   | CC0 Port/Pin Select              |
| 0x16C8 | GPIO_TIM-ER2_CC1ROUTE_SET             | RW   | CC1 Port/Pin Select              |
| 0x16CC | GPIO_TIM-ER2_CC2ROUTE_SET             | RW   | CC2 Port/Pin Select              |
| 0x16D0 | GPIO_TIM-ER2_CDTI0ROUTE_SET           | RW   | CDTI0 Port/Pin Select            |
| 0x16D4 | GPIO_TIM-ER2_CDTI1ROUTE_SET           | RW   | CDTI1 Port/Pin Select            |
| 0x16D8 | GPIO_TIM-ER2_CDTI2ROUTE_SET           | RW   | CDTI2 Port/Pin Select            |

| Offset | Name                        | Type | Description           |
|--------|-----------------------------|------|-----------------------|
| 0x16E0 | GPIO_TIMER3_ROUTEEN_SET     | RW   | TIMER3 Pin Enable     |
| 0x16E4 | GPIO_TIM-ER3_CC0ROUTE_SET   | RW   | CC0 Port/Pin Select   |
| 0x16E8 | GPIO_TIM-ER3_CC1ROUTE_SET   | RW   | CC1 Port/Pin Select   |
| 0x16EC | GPIO_TIM-ER3_CC2ROUTE_SET   | RW   | CC2 Port/Pin Select   |
| 0x16F0 | GPIO_TIM-ER3_CDTI0ROUTE_SET | RW   | CDTI0 Port/Pin Select |
| 0x16F4 | GPIO_TIM-ER3_CDTI1ROUTE_SET | RW   | CDTI1 Port/Pin Select |
| 0x16F8 | GPIO_TIM-ER3_CDTI2ROUTE_SET | RW   | CDTI2 Port/Pin Select |
| 0x1700 | GPIO_TIMER4_ROUTEEN_SET     | RW   | TIMER4 Pin Enable     |
| 0x1704 | GPIO_TIM-ER4_CC0ROUTE_SET   | RW   | CC0 Port/Pin Select   |
| 0x1708 | GPIO_TIM-ER4_CC1ROUTE_SET   | RW   | CC1 Port/Pin Select   |
| 0x170C | GPIO_TIM-ER4_CC2ROUTE_SET   | RW   | CC2 Port/Pin Select   |
| 0x1710 | GPIO_TIM-ER4_CDTI0ROUTE_SET | RW   | CDTI0 Port/Pin Select |
| 0x1714 | GPIO_TIM-ER4_CDTI1ROUTE_SET | RW   | CDTI1 Port/Pin Select |
| 0x1718 | GPIO_TIM-ER4_CDTI2ROUTE_SET | RW   | CDTI2 Port/Pin Select |
| 0x1720 | GPIO_USART0_ROU-TEEN_SET    | RW   | USART0 Pin Enable     |
| 0x1724 | GPIO_USART0_CSROUTE_SE-T    | RW   | CS Port/Pin Select    |
| 0x1728 | GPIO_USART0_CTSROUTE_SE-T   | RW   | CTS Port/Pin Select   |
| 0x172C | GPIO_USART0_RTSROUTE_SE-T   | RW   | RTS Port/Pin Select   |
| 0x1730 | GPIO_USART0_RXROUTE_SE-T    | RW   | RX Port/Pin Select    |
| 0x1734 | GPIO_USART0_CLKROUTE_SE-T   | RW   | SCLK Port/Pin Select  |
| 0x1738 | GPIO_USART0_TXROUTE_SET     | RW   | TX Port/Pin Select    |
| 0x2000 | GPIO_IPVERSION_CLR          | R    | Main                  |
| 0x2030 | GPIO_PORTA_CTRL_CLR         | RW   | Port Control          |
| 0x2034 | GPIO_PORTA_MODEL_CLR        | RW   | Mode Low              |
| 0x203C | GPIO_PORTA_MODEH_CLR        | RW   | Mode High             |
| 0x2040 | GPIO_PORTA_DOUT_CLR         | RW   | Data Out              |

| Offset | Name                                         | Type        | Description                             |
|--------|----------------------------------------------|-------------|-----------------------------------------|
| 0x2044 | <a href="#">GPIO_PORTA_DIN_CLR</a>           | RH          | Data in                                 |
| 0x2060 | <a href="#">GPIO_PORTB_CTRL_CLR</a>          | RW          | Port Control                            |
| 0x2064 | <a href="#">GPIO_PORTB_MODEL_CLR</a>         | RW          | Mode Low                                |
| 0x2070 | <a href="#">GPIO_PORTB_DOUT_CLR</a>          | RW          | Data Out                                |
| 0x2074 | <a href="#">GPIO_PORTB_DIN_CLR</a>           | RH          | Data in                                 |
| 0x2090 | <a href="#">GPIO_PORTC_CTRL_CLR</a>          | RW          | Port Control                            |
| 0x2094 | <a href="#">GPIO_PORTC_MODEL_CLR</a>         | RW          | Mode Low                                |
| 0x209C | <a href="#">GPIO_PORTC_MODEH_CLR</a>         | RW          | Mode High                               |
| 0x20A0 | <a href="#">GPIO_PORTC_DOUT_CLR</a>          | RW          | Data Out                                |
| 0x20A4 | <a href="#">GPIO_PORTC_DIN_CLR</a>           | RH          | Data in                                 |
| 0x20C0 | <a href="#">GPIO_PORTD_CTRL_CLR</a>          | RW          | Port Control                            |
| 0x20C4 | <a href="#">GPIO_PORTD_MODEL_CLR</a>         | RW          | Mode Low                                |
| 0x20D0 | <a href="#">GPIO_PORTD_DOUT_CLR</a>          | RW          | Data Out                                |
| 0x20D4 | <a href="#">GPIO_PORTD_DIN_CLR</a>           | RH          | Data in                                 |
| 0x2300 | <a href="#">GPIO_LOCK_CLR</a>                | W           | Lock Register                           |
| 0x2310 | <a href="#">GPIO_GPIOLOCKSTATUS_CLR</a>      | RH          | Lock Status                             |
| 0x2320 | <a href="#">GPIO_ABUSALLOC_CLR</a>           | RW          | A Bus Allocation                        |
| 0x2324 | <a href="#">GPIO_BBUSALLOC_CLR</a>           | RW          | B Bus Allocation                        |
| 0x2328 | <a href="#">GPIO_CDBUSALLOC_CLR</a>          | RW          | CD Bus Allocation                       |
| 0x2400 | <a href="#">GPIO_EXTIPSELL_CLR</a>           | RW          | External Interrupt Port Select Low      |
| 0x2404 | <a href="#">GPIO_EXTIPSELH_CLR</a>           | RW          | External Interrupt Port Select High     |
| 0x2408 | <a href="#">GPIO_EXTIPINSELL_CLR</a>         | RW          | External Interrupt Pin Select Low       |
| 0x240C | <a href="#">GPIO_EXTIPINSELH_CLR</a>         | RW          | External Interrupt Pin Select High      |
| 0x2410 | <a href="#">GPIO_EXTRIRISE_CLR</a>           | RW          | External Interrupt Rising Edge Trigger  |
| 0x2414 | <a href="#">GPIO_EXTIFFALL_CLR</a>           | RW          | External Interrupt Falling Edge Trigger |
| 0x2420 | <a href="#">GPIO_IF_CLR</a>                  | RWH INTFLAG | Interrupt Flag                          |
| 0x2424 | <a href="#">GPIO_IEN_CLR</a>                 | RW          | Interrupt Enable                        |
| 0x242C | <a href="#">GPIO_EM4WUEN_CLR</a>             | RW          | EM4 Wakeup Enable                       |
| 0x2430 | <a href="#">GPIO_EM4WUPOL_CLR</a>            | RW          | EM4 Wakeup Polarity                     |
| 0x2440 | <a href="#">GPIO_DBGROUTEPEN_CLR</a>         | RW          | Debugger Route Pin Enable               |
| 0x2444 | <a href="#">GPIO_TRACEROUTEPEN_CLR</a>       | RW          | Trace Route Pin Enable                  |
| 0x2450 | <a href="#">GPIO_ACMP0_ROUTEEN_CLR</a>       | RW          | ACMP0 Pin Enable                        |
| 0x2454 | <a href="#">GPIO_ACMP0_ACMPOUT-ROUTE_CLR</a> | RW          | ACMPOUT Port/Pin Select                 |
| 0x245C | <a href="#">GPIO_ACMP1_ROUTEEN_CLR</a>       | RW          | ACMP1 Pin Enable                        |
| 0x2460 | <a href="#">GPIO_ACMP1_ACMPOUT-ROUTE_CLR</a> | RW          | ACMPOUT Port/Pin Select                 |
| 0x2468 | <a href="#">GPIO_CMU_ROUTEEN_CLR</a>         | RW          | CMU Pin Enable                          |

| Offset | Name                        | Type | Description             |
|--------|-----------------------------|------|-------------------------|
| 0x246C | GPIO_CMU_CLKIN0ROUTE_CLR    | RW   | CLKIN0 Port/Pin Select  |
| 0x2470 | GPIO_CMU_CLKOUT0ROUTE_CLR   | RW   | CLKOUT0 Port/Pin Select |
| 0x2474 | GPIO_CMU_CLKOUT1ROUTE_CLR   | RW   | CLKOUT1 Port/Pin Select |
| 0x2478 | GPIO_CMU_CLKOUT2ROUTE_CLR   | RW   | CLKOUT2 Port/Pin Select |
| 0x2494 | GPIO_EUSART0_ROUTEEEN_CLR   | RW   | EUSART0 Pin Enable      |
| 0x2498 | GPIO_EU-SART0_CSROUTE_CLR   | RW   | CS Port/Pin Select      |
| 0x249C | GPIO_EU-SART0_CTSROUTE_CLR  | RW   | CTS Port/Pin Select     |
| 0x24A0 | GPIO_EU-SART0_RTSPROUTE_CLR | RW   | RTS Port/Pin Select     |
| 0x24A4 | GPIO_EU-SART0_RXROUTE_CLR   | RW   | RX Port/Pin Select      |
| 0x24A8 | GPIO_EU-SART0_SCLKROUTE_CLR | RW   | SCLK Port/Pin Select    |
| 0x24AC | GPIO_EU-SART0_TXROUTE_CLR   | RW   | TX Port/Pin Select      |
| 0x24B4 | GPIO_EUSART1_ROUTEEEN_CLR   | RW   | EUSART1 Pin Enable      |
| 0x24B8 | GPIO_EU-SART1_CSROUTE_CLR   | RW   | CS Port/Pin Select      |
| 0x24BC | GPIO_EU-SART1_CTSROUTE_CLR  | RW   | CTS Port/Pin Select     |
| 0x24C0 | GPIO_EU-SART1_RTSPROUTE_CLR | RW   | RTS Port/Pin Select     |
| 0x24C4 | GPIO_EU-SART1_RXROUTE_CLR   | RW   | RX Port/Pin Select      |
| 0x24C8 | GPIO_EU-SART1_SCLKROUTE_CLR | RW   | SCLK Port/Pin Select    |
| 0x24CC | GPIO_EU-SART1_TXROUTE_CLR   | RW   | TX Port/Pin Select      |
| 0x24D4 | GPIO_FRC_ROUTEEN_CLR        | RW   | FRC Pin Enable          |
| 0x24D8 | GPIO_FRC_DCLKROUTE_CLR      | RW   | DCLK Port/Pin Select    |
| 0x24DC | GPIO_FRC_DFRAME-ROUTE_CLR   | RW   | DFRAME Port/Pin Select  |
| 0x24E0 | GPIO_FRC_DOUTROUTE_CLR      | RW   | DOUT Port/Pin Select    |
| 0x24E8 | GPIO_I2C0_ROUTEEN_CLR       | RW   | I2C0 Pin Enable         |
| 0x24EC | GPIO_I2C0_SCLROUTE_CLR      | RW   | SCL Port/Pin Select     |
| 0x24F0 | GPIO_I2C0_SDAROUTE_CLR      | RW   | SDA Port/Pin Select     |
| 0x24F8 | GPIO_I2C1_ROUTEEN_CLR       | RW   | I2C1 Pin Enable         |

| Offset | Name                             | Type | Description                 |
|--------|----------------------------------|------|-----------------------------|
| 0x24FC | GPIO_I2C1_SCLROUTE_CLR           | RW   | SCL Port/Pin Select         |
| 0x2500 | GPIO_I2C1_SDAROUTE_CLR           | RW   | SDA Port/Pin Select         |
| 0x2508 | GPIO_KEYSCAN_ROU-TEEN_CLR        | RW   | KEYSCAN Pin Enable          |
| 0x250C | GPIO_KEYSCAN_COL-OUT0ROUTE_CLR   | RW   | COLOUT0 Port/Pin Select     |
| 0x2510 | GPIO_KEYSCAN_COL-OUT1ROUTE_CLR   | RW   | COLOUT1 Port/Pin Select     |
| 0x2514 | GPIO_KEYSCAN_COL-OUT2ROUTE_CLR   | RW   | COLOUT2 Port/Pin Select     |
| 0x2518 | GPIO_KEYSCAN_COL-OUT3ROUTE_CLR   | RW   | COLOUT3 Port/Pin Select     |
| 0x251C | GPIO_KEYSCAN_COL-OUT4ROUTE_CLR   | RW   | COLOUT4 Port/Pin Select     |
| 0x2520 | GPIO_KEYSCAN_COL-OUT5ROUTE_CLR   | RW   | COLOUT5 Port/Pin Select     |
| 0x2524 | GPIO_KEYSCAN_COL-OUT6ROUTE_CLR   | RW   | COLOUT6 Port/Pin Select     |
| 0x2528 | GPIO_KEYSCAN_COL-OUT7ROUTE_CLR   | RW   | COLOUT7 Port/Pin Select     |
| 0x252C | GPIO_KEYSCAN_ROW-SENSE0ROUTE_CLR | RW   | ROWSENSE0 Port/Pin Select   |
| 0x2530 | GPIO_KEYSCAN_ROW-SENSE1ROUTE_CLR | RW   | ROWSENSE1 Port/Pin Select   |
| 0x2534 | GPIO_KEYSCAN_ROW-SENSE2ROUTE_CLR | RW   | ROWSENSE2 Port/Pin Select   |
| 0x2538 | GPIO_KEYSCAN_ROW-SENSE3ROUTE_CLR | RW   | ROWSENSE3 Port/Pin Select   |
| 0x253C | GPIO_KEYSCAN_ROW-SENSE4ROUTE_CLR | RW   | ROWSENSE4 Port/Pin Select   |
| 0x2540 | GPIO_KEYSCAN_ROW-SENSE5ROUTE_CLR | RW   | ROWSENSE5 Port/Pin Select   |
| 0x2548 | GPIO_LETIMER_ROU-TEEN_CLR        | RW   | LETIMER Pin Enable          |
| 0x254C | GPIO_LETIM-ER_OUT0ROUTE_CLR      | RW   | OUT0 Port/Pin Select        |
| 0x2550 | GPIO_LETIM-ER_OUT1ROUTE_CLR      | RW   | OUT1 Port/Pin Select        |
| 0x2558 | GPIO_MODEM_ROUTEEN_CLR           | RW   | MODEM Pin Enable            |
| 0x255C | GPIO_MO-DEM_ANT0ROUTE_CLR        | RW   | ANT0 Port/Pin Select        |
| 0x2560 | GPIO_MO-DEM_ANT1ROUTE_CLR        | RW   | ANT1 Port/Pin Select        |
| 0x2564 | GPIO_MODEM_ANTROLLO-VERROUTE_CLR | RW   | ANTROLLOVER Port/Pin Select |

| Offset | Name                            | Type | Description                 |
|--------|---------------------------------|------|-----------------------------|
| 0x2568 | GPIO_MO-DEM_ANTRR0ROUTE_CLR     | RW   | ANTRR0 Port/Pin Select      |
| 0x256C | GPIO_MO-DEM_ANTRR1ROUTE_CLR     | RW   | ANTRR1 Port/Pin Select      |
| 0x2570 | GPIO_MO-DEM_ANTRR2ROUTE_CLR     | RW   | ANTRR2 Port/Pin Select      |
| 0x2574 | GPIO_MO-DEM_ANTRR3ROUTE_CLR     | RW   | ANTRR3 Port/Pin Select      |
| 0x2578 | GPIO_MO-DEM_ANTRR4ROUTE_CLR     | RW   | ANTRR4 Port/Pin Select      |
| 0x257C | GPIO_MO-DEM_ANTRR5ROUTE_CLR     | RW   | ANTRR5 Port/Pin Select      |
| 0x2580 | GPIO_MODEM_ANTSWEN-ROUTE_CLR    | RW   | ANTSWEN Port/Pin Select     |
| 0x2584 | GPIO_MODEM_ANTSWUS-ROUTE_CLR    | RW   | ANTSWUS Port/Pin Select     |
| 0x2588 | GPIO_MODEM_ANTRIG-ROUTE_CLR     | RW   | ANTTRIG Port/Pin Select     |
| 0x258C | GPIO_MODEM_ANTRIGSTOP-ROUTE_CLR | RW   | ANTTRIGSTOP Port/Pin Select |
| 0x2590 | GPIO_MO-DEM_DCLKROUTE_CLR       | RW   | DCLK Port/Pin Select        |
| 0x2594 | GPIO_MODEM_DIN-ROUTE_CLR        | RW   | DIN Port/Pin Select         |
| 0x2598 | GPIO_MODEM_DOUT-ROUTE_CLR       | RW   | DOUT Port/Pin Select        |
| 0x25A4 | GPIO_PCNT0_S0IN-ROUTE_CLR       | RW   | S0IN Port/Pin Select        |
| 0x25A8 | GPIO_PCNT0_S1IN-ROUTE_CLR       | RW   | S1IN Port/Pin Select        |
| 0x25B0 | GPIO_PRS0_ROUTEEN_CLR           | RW   | PRS0 Pin Enable             |
| 0x25B4 | GPIO_PRS0_ASYNCH0ROUTE_CLR      | RW   | ASYNCH0 Port/Pin Select     |
| 0x25B8 | GPIO_PRS0_ASYNCH1ROUTE_CLR      | RW   | ASYNCH1 Port/Pin Select     |
| 0x25BC | GPIO_PRS0_ASYNCH2ROUTE_CLR      | RW   | ASYNCH2 Port/Pin Select     |
| 0x25C0 | GPIO_PRS0_ASYNCH3ROUTE_CLR      | RW   | ASYNCH3 Port/Pin Select     |
| 0x25C4 | GPIO_PRS0_ASYNCH4ROUTE_CLR      | RW   | ASYNCH4 Port/Pin Select     |
| 0x25C8 | GPIO_PRS0_ASYNCH5ROUTE_CLR      | RW   | ASYNCH5 Port/Pin Select     |
| 0x25CC | GPIO_PRS0_ASYNCH6ROUTE_CLR      | RW   | ASYNCH6 Port/Pin Select     |
| 0x25D0 | GPIO_PRS0_ASYNCH7ROUTE_CLR      | RW   | ASYNCH7 Port/Pin Select     |

| Offset | Name                                  | Type | Description                      |
|--------|---------------------------------------|------|----------------------------------|
| 0x25D4 | GPIO_PRS0_ASYNCH8ROUTE_CLR            | RW   | ASYNCH8 Port/Pin Select          |
| 0x25D8 | GPIO_PRS0_ASYNCH9ROUTE_CLR            | RW   | ASYNCH9 Port/Pin Select          |
| 0x25DC | GPIO_PRS0_ASYNCH10ROUTE_CLR           | RW   | ASYNCH10 Port/Pin Select         |
| 0x25E0 | GPIO_PRS0_ASYNCH11ROUTE_CLR           | RW   | ASYNCH11 Port/Pin Select         |
| 0x25E4 | GPIO_PRS0_ASYNCH12ROUTE_CLR           | RW   | ASYNCH12 Port/Pin Select         |
| 0x25E8 | GPIO_PRS0_ASYNCH13ROUTE_CLR           | RW   | ASYNCH13 Port/Pin Select         |
| 0x25EC | GPIO_PRS0_ASYNCH14ROUTE_CLR           | RW   | ASYNCH14 Port/Pin Select         |
| 0x25F0 | GPIO_PRS0_ASYNCH15ROUTE_CLR           | RW   | ASYNCH15 Port/Pin Select         |
| 0x25F4 | GPIO_PRS0_SYNCH0ROUTE_CLR             | RW   | SYNCH0 Port/Pin Select           |
| 0x25F8 | GPIO_PRS0_SYNCH1ROUTE_CLR             | RW   | SYNCH1 Port/Pin Select           |
| 0x25FC | GPIO_PRS0_SYNCH2ROUTE_CLR             | RW   | SYNCH2 Port/Pin Select           |
| 0x2600 | GPIO_PRS0_SYNCH3ROUTE_CLR             | RW   | SYNCH3 Port/Pin Select           |
| 0x2608 | GPIO_RAC_ROUTEEN_CLR                  | RW   | RAC Pin Enable                   |
| 0x260C | GPIO_RAC_LNAEN-ROUTE_CLR              | RW   | LNAEN Port/Pin Select            |
| 0x2610 | GPIO_RAC_PAENROUTE_CLR                | RW   | PAEN Port/Pin Select             |
| 0x2678 | GPIO_SYX00_BUFOUTREQI-NASYNCROUTE_CLR | RW   | BUFOUTREQINASYNC Port/Pin Select |
| 0x2680 | GPIO_TIMER0_ROUTEEN_CLR               | RW   | TIMER0 Pin Enable                |
| 0x2684 | GPIO_TIM-ER0_CC0ROUTE_CLR             | RW   | CC0 Port/Pin Select              |
| 0x2688 | GPIO_TIM-ER0_CC1ROUTE_CLR             | RW   | CC1 Port/Pin Select              |
| 0x268C | GPIO_TIM-ER0_CC2ROUTE_CLR             | RW   | CC2 Port/Pin Select              |
| 0x2690 | GPIO_TIM-ER0_CDTI0ROUTE_CLR           | RW   | CDTI0 Port/Pin Select            |
| 0x2694 | GPIO_TIM-ER0_CDTI1ROUTE_CLR           | RW   | CDTI1 Port/Pin Select            |
| 0x2698 | GPIO_TIM-ER0_CDTI2ROUTE_CLR           | RW   | CDTI2 Port/Pin Select            |
| 0x26A0 | GPIO_TIMER1_ROUTEEN_CLR               | RW   | TIMER1 Pin Enable                |
| 0x26A4 | GPIO_TIM-ER1_CC0ROUTE_CLR             | RW   | CC0 Port/Pin Select              |

| Offset | Name                        | Type | Description           |
|--------|-----------------------------|------|-----------------------|
| 0x26A8 | GPIO_TIM-ER1_CC1ROUTE_CLR   | RW   | CC1 Port/Pin Select   |
| 0x26AC | GPIO_TIM-ER1_CC2ROUTE_CLR   | RW   | CC2 Port/Pin Select   |
| 0x26B0 | GPIO_TIM-ER1_CDTI0ROUTE_CLR | RW   | CDTI0 Port/Pin Select |
| 0x26B4 | GPIO_TIM-ER1_CDTI1ROUTE_CLR | RW   | CDTI1 Port/Pin Select |
| 0x26B8 | GPIO_TIM-ER1_CDTI2ROUTE_CLR | RW   | CDTI2 Port/Pin Select |
| 0x26C0 | GPIO_TIMER2_ROUTEEN_CLR     | RW   | TIMER2 Pin Enable     |
| 0x26C4 | GPIO_TIM-ER2_CC0ROUTE_CLR   | RW   | CC0 Port/Pin Select   |
| 0x26C8 | GPIO_TIM-ER2_CC1ROUTE_CLR   | RW   | CC1 Port/Pin Select   |
| 0x26CC | GPIO_TIM-ER2_CC2ROUTE_CLR   | RW   | CC2 Port/Pin Select   |
| 0x26D0 | GPIO_TIM-ER2_CDTI0ROUTE_CLR | RW   | CDTI0 Port/Pin Select |
| 0x26D4 | GPIO_TIM-ER2_CDTI1ROUTE_CLR | RW   | CDTI1 Port/Pin Select |
| 0x26D8 | GPIO_TIM-ER2_CDTI2ROUTE_CLR | RW   | CDTI2 Port/Pin Select |
| 0x26E0 | GPIO_TIMER3_ROUTEEN_CLR     | RW   | TIMER3 Pin Enable     |
| 0x26E4 | GPIO_TIM-ER3_CC0ROUTE_CLR   | RW   | CC0 Port/Pin Select   |
| 0x26E8 | GPIO_TIM-ER3_CC1ROUTE_CLR   | RW   | CC1 Port/Pin Select   |
| 0x26EC | GPIO_TIM-ER3_CC2ROUTE_CLR   | RW   | CC2 Port/Pin Select   |
| 0x26F0 | GPIO_TIM-ER3_CDTI0ROUTE_CLR | RW   | CDTI0 Port/Pin Select |
| 0x26F4 | GPIO_TIM-ER3_CDTI1ROUTE_CLR | RW   | CDTI1 Port/Pin Select |
| 0x26F8 | GPIO_TIM-ER3_CDTI2ROUTE_CLR | RW   | CDTI2 Port/Pin Select |
| 0x2700 | GPIO_TIMER4_ROUTEEN_CLR     | RW   | TIMER4 Pin Enable     |
| 0x2704 | GPIO_TIM-ER4_CC0ROUTE_CLR   | RW   | CC0 Port/Pin Select   |
| 0x2708 | GPIO_TIM-ER4_CC1ROUTE_CLR   | RW   | CC1 Port/Pin Select   |
| 0x270C | GPIO_TIM-ER4_CC2ROUTE_CLR   | RW   | CC2 Port/Pin Select   |
| 0x2710 | GPIO_TIM-ER4_CDTI0ROUTE_CLR | RW   | CDTI0 Port/Pin Select |

| Offset | Name                        | Type | Description           |
|--------|-----------------------------|------|-----------------------|
| 0x2714 | GPIO_TIM-ER4_CDTI1ROUTE_CLR | RW   | CDTI1 Port/Pin Select |
| 0x2718 | GPIO_TIM-ER4_CDTI2ROUTE_CLR | RW   | CDTI2 Port/Pin Select |
| 0x2720 | GPIO_USART0_ROU-TEEN_CLR    | RW   | USART0 Pin Enable     |
| 0x2724 | GPIO_USART0_CSROUTE_CLR     | RW   | CS Port/Pin Select    |
| 0x2728 | GPIO_USART0_CTSROUTE_CLR    | RW   | CTS Port/Pin Select   |
| 0x272C | GPIO_USART0_RTSROUTE_CLR    | RW   | RTS Port/Pin Select   |
| 0x2730 | GPIO_USART0_RXROUTE_CLR     | RW   | RX Port/Pin Select    |
| 0x2734 | GPIO_USART0_CLKROUTE_CLR    | RW   | SCLK Port/Pin Select  |
| 0x2738 | GPIO_USART0_TXROUTE_CLR     | RW   | TX Port/Pin Select    |
| 0x3000 | GPIO_IPVERSION_TGL          | R    | Main                  |
| 0x3030 | GPIO_PORTA_CTRL_TGL         | RW   | Port Control          |
| 0x3034 | GPIO_PORTA_MODEL_TGL        | RW   | Mode Low              |
| 0x303C | GPIO_PORTA_MODEH_TGL        | RW   | Mode High             |
| 0x3040 | GPIO_PORTA_DOUT_TGL         | RW   | Data Out              |
| 0x3044 | GPIO_PORTA_DIN_TGL          | RH   | Data in               |
| 0x3060 | GPIO_PORTB_CTRL_TGL         | RW   | Port Control          |
| 0x3064 | GPIO_PORTB_MODEL_TGL        | RW   | Mode Low              |
| 0x3070 | GPIO_PORTB_DOUT_TGL         | RW   | Data Out              |
| 0x3074 | GPIO_PORTB_DIN_TGL          | RH   | Data in               |
| 0x3090 | GPIO_PORTC_CTRL_TGL         | RW   | Port Control          |
| 0x3094 | GPIO_PORTC_MODEL_TGL        | RW   | Mode Low              |
| 0x309C | GPIO_PORTC_MODEH_TGL        | RW   | Mode High             |
| 0x30A0 | GPIO_PORTC_DOUT_TGL         | RW   | Data Out              |
| 0x30A4 | GPIO_PORTC_DIN_TGL          | RH   | Data in               |
| 0x30C0 | GPIO_PORTD_CTRL_TGL         | RW   | Port Control          |
| 0x30C4 | GPIO_PORTD_MODEL_TGL        | RW   | Mode Low              |
| 0x30D0 | GPIO_PORTD_DOUT_TGL         | RW   | Data Out              |
| 0x30D4 | GPIO_PORTD_DIN_TGL          | RH   | Data in               |
| 0x3300 | GPIO_LOCK_TGL               | W    | Lock Register         |
| 0x3310 | GPIO_GPIOLOCKSTATUS_TGL     | RH   | Lock Status           |
| 0x3320 | GPIO_ABUSALLOC_TGL          | RW   | A Bus Allocation      |
| 0x3324 | GPIO_BBUSALLOC_TGL          | RW   | B Bus Allocation      |

| Offset | Name                                         | Type        | Description                             |
|--------|----------------------------------------------|-------------|-----------------------------------------|
| 0x3328 | <a href="#">GPIO_CDBUSALLOC_TGL</a>          | RW          | CD Bus Allocation                       |
| 0x3400 | <a href="#">GPIO_EXTIPSELL_TGL</a>           | RW          | External Interrupt Port Select Low      |
| 0x3404 | <a href="#">GPIO_EXTIPSELH_TGL</a>           | RW          | External Interrupt Port Select High     |
| 0x3408 | <a href="#">GPIO_EXTIPINSELL_TGL</a>         | RW          | External Interrupt Pin Select Low       |
| 0x340C | <a href="#">GPIO_EXTIPINSELH_TGL</a>         | RW          | External Interrupt Pin Select High      |
| 0x3410 | <a href="#">GPIO_EXTIRISE_TGL</a>            | RW          | External Interrupt Rising Edge Trigger  |
| 0x3414 | <a href="#">GPIO_EXTIFALL_TGL</a>            | RW          | External Interrupt Falling Edge Trigger |
| 0x3420 | <a href="#">GPIO_IF_TGL</a>                  | RWH INTFLAG | Interrupt Flag                          |
| 0x3424 | <a href="#">GPIO_IEN_TGL</a>                 | RW          | Interrupt Enable                        |
| 0x342C | <a href="#">GPIO_EM4WUEN_TGL</a>             | RW          | EM4 Wakeup Enable                       |
| 0x3430 | <a href="#">GPIO_EM4WUPOL_TGL</a>            | RW          | EM4 Wakeup Polarity                     |
| 0x3440 | <a href="#">GPIO_DBGROUTEPEN_TGL</a>         | RW          | Debugger Route Pin Enable               |
| 0x3444 | <a href="#">GPIO_TRACEROUTEPEN_TGL</a>       | RW          | Trace Route Pin Enable                  |
| 0x3450 | <a href="#">GPIO_ACMP0_ROUTEEN_TGL</a>       | RW          | ACMP0 Pin Enable                        |
| 0x3454 | <a href="#">GPIO_ACMP0_ACMPOUT-ROUTE_TGL</a> | RW          | ACMPOUT Port/Pin Select                 |
| 0x345C | <a href="#">GPIO_ACMP1_ROUTEEN_TGL</a>       | RW          | ACMP1 Pin Enable                        |
| 0x3460 | <a href="#">GPIO_ACMP1_ACMPOUT-ROUTE_TGL</a> | RW          | ACMPOUT Port/Pin Select                 |
| 0x3468 | <a href="#">GPIO_CMU_ROUTEEN_TGL</a>         | RW          | CMU Pin Enable                          |
| 0x346C | <a href="#">GPIO_CMU_CLKIN0ROUTE_TGL</a>     | RW          | CLKIN0 Port/Pin Select                  |
| 0x3470 | <a href="#">GPIO_CMU_CLKOUT0ROUTE_TGL</a>    | RW          | CLKOUT0 Port/Pin Select                 |
| 0x3474 | <a href="#">GPIO_CMU_CLKOUT1ROUTE_TGL</a>    | RW          | CLKOUT1 Port/Pin Select                 |
| 0x3478 | <a href="#">GPIO_CMU_CLKOUT2ROUTE_TGL</a>    | RW          | CLKOUT2 Port/Pin Select                 |
| 0x3494 | <a href="#">GPIO_EUSART0_ROUTEEN_TGL</a>     | RW          | EUSART0 Pin Enable                      |
| 0x3498 | <a href="#">GPIO_EU-SART0_CSROUTE_TGL</a>    | RW          | CS Port/Pin Select                      |
| 0x349C | <a href="#">GPIO_EU-SART0_CTSROUTE_TGL</a>   | RW          | CTS Port/Pin Select                     |
| 0x34A0 | <a href="#">GPIO_EU-SART0_RTSROUTE_TGL</a>   | RW          | RTS Port/Pin Select                     |
| 0x34A4 | <a href="#">GPIO_EU-SART0_RXROUTE_TGL</a>    | RW          | RX Port/Pin Select                      |
| 0x34A8 | <a href="#">GPIO_EU-SART0_SCLKROUTE_TGL</a>  | RW          | SCLK Port/Pin Select                    |
| 0x34AC | <a href="#">GPIO_EU-SART0_TXROUTE_TGL</a>    | RW          | TX Port/Pin Select                      |

| Offset | Name                           | Type | Description             |
|--------|--------------------------------|------|-------------------------|
| 0x34B4 | GPIO_EUSART1_ROU-TEEN_TGL      | RW   | EUSART1 Pin Enable      |
| 0x34B8 | GPIO_EU-SART1_CSROUTE_TGL      | RW   | CS Port/Pin Select      |
| 0x34BC | GPIO_EU-SART1_CTSROUTE_TGL     | RW   | CTS Port/Pin Select     |
| 0x34C0 | GPIO_EU-SART1_RTSPROUTE_TGL    | RW   | RTS Port/Pin Select     |
| 0x34C4 | GPIO_EU-SART1_RXROUTE_TGL      | RW   | RX Port/Pin Select      |
| 0x34C8 | GPIO_EU-SART1_SCLKROUTE_TGL    | RW   | SCLK Port/Pin Select    |
| 0x34CC | GPIO_EU-SART1_TXROUTE_TGL      | RW   | TX Port/Pin Select      |
| 0x34D4 | GPIO_FRC_ROUTEEN_TGL           | RW   | FRC Pin Enable          |
| 0x34D8 | GPIO_FRC_DCLKROUTE_TGL         | RW   | DCLK Port/Pin Select    |
| 0x34DC | GPIO_FRC_DFRAME-ROUTE_TGL      | RW   | DFRAME Port/Pin Select  |
| 0x34E0 | GPIO_FRC_DOUTROUTE_TGL         | RW   | DOUT Port/Pin Select    |
| 0x34E8 | GPIO_I2C0_ROUTEEN_TGL          | RW   | I2C0 Pin Enable         |
| 0x34EC | GPIO_I2C0_SCLROUTE_TGL         | RW   | SCL Port/Pin Select     |
| 0x34F0 | GPIO_I2C0_SDAROUTE_TGL         | RW   | SDA Port/Pin Select     |
| 0x34F8 | GPIO_I2C1_ROUTEEN_TGL          | RW   | I2C1 Pin Enable         |
| 0x34FC | GPIO_I2C1_SCLROUTE_TGL         | RW   | SCL Port/Pin Select     |
| 0x3500 | GPIO_I2C1_SDAROUTE_TGL         | RW   | SDA Port/Pin Select     |
| 0x3508 | GPIO_KEYSCAN_ROU-TEEN_TGL      | RW   | KEYSCAN Pin Enable      |
| 0x350C | GPIO_KEYSCAN_COL-OUT0ROUTE_TGL | RW   | COLOUT0 Port/Pin Select |
| 0x3510 | GPIO_KEYSCAN_COL-OUT1ROUTE_TGL | RW   | COLOUT1 Port/Pin Select |
| 0x3514 | GPIO_KEYSCAN_COL-OUT2ROUTE_TGL | RW   | COLOUT2 Port/Pin Select |
| 0x3518 | GPIO_KEYSCAN_COL-OUT3ROUTE_TGL | RW   | COLOUT3 Port/Pin Select |
| 0x351C | GPIO_KEYSCAN_COL-OUT4ROUTE_TGL | RW   | COLOUT4 Port/Pin Select |
| 0x3520 | GPIO_KEYSCAN_COL-OUT5ROUTE_TGL | RW   | COLOUT5 Port/Pin Select |
| 0x3524 | GPIO_KEYSCAN_COL-OUT6ROUTE_TGL | RW   | COLOUT6 Port/Pin Select |
| 0x3528 | GPIO_KEYSCAN_COL-OUT7ROUTE_TGL | RW   | COLOUT7 Port/Pin Select |

| Offset | Name                             | Type | Description                 |
|--------|----------------------------------|------|-----------------------------|
| 0x352C | GPIO_KEYSCAN_ROW-SENSE0ROUTE_TGL | RW   | ROWSENSE0 Port/Pin Select   |
| 0x3530 | GPIO_KEYSCAN_ROW-SENSE1ROUTE_TGL | RW   | ROWSENSE1 Port/Pin Select   |
| 0x3534 | GPIO_KEYSCAN_ROW-SENSE2ROUTE_TGL | RW   | ROWSENSE2 Port/Pin Select   |
| 0x3538 | GPIO_KEYSCAN_ROW-SENSE3ROUTE_TGL | RW   | ROWSENSE3 Port/Pin Select   |
| 0x353C | GPIO_KEYSCAN_ROW-SENSE4ROUTE_TGL | RW   | ROWSENSE4 Port/Pin Select   |
| 0x3540 | GPIO_KEYSCAN_ROW-SENSE5ROUTE_TGL | RW   | ROWSENSE5 Port/Pin Select   |
| 0x3548 | GPIO_LETIMER_ROU-TEEN_TGL        | RW   | LETIMER Pin Enable          |
| 0x354C | GPIO_LETIM-ER_OUT0ROUTE_TGL      | RW   | OUT0 Port/Pin Select        |
| 0x3550 | GPIO_LETIM-ER_OUT1ROUTE_TGL      | RW   | OUT1 Port/Pin Select        |
| 0x3558 | GPIO_MODEM_ROUTEEN_TGL           | RW   | MODEM Pin Enable            |
| 0x355C | GPIO_MO-DEM_ANT0ROUTE_TGL        | RW   | ANT0 Port/Pin Select        |
| 0x3560 | GPIO_MO-DEM_ANT1ROUTE_TGL        | RW   | ANT1 Port/Pin Select        |
| 0x3564 | GPIO_MODEM_ANTROLLO-VERROUTE_TGL | RW   | ANTROLLOVER Port/Pin Select |
| 0x3568 | GPIO_MO-DEM_ANTRR0ROUTE_TGL      | RW   | ANTRR0 Port/Pin Select      |
| 0x356C | GPIO_MO-DEM_ANTRR1ROUTE_TGL      | RW   | ANTRR1 Port/Pin Select      |
| 0x3570 | GPIO_MO-DEM_ANTRR2ROUTE_TGL      | RW   | ANTRR2 Port/Pin Select      |
| 0x3574 | GPIO_MO-DEM_ANTRR3ROUTE_TGL      | RW   | ANTRR3 Port/Pin Select      |
| 0x3578 | GPIO_MO-DEM_ANTRR4ROUTE_TGL      | RW   | ANTRR4 Port/Pin Select      |
| 0x357C | GPIO_MO-DEM_ANTRR5ROUTE_TGL      | RW   | ANTRR5 Port/Pin Select      |
| 0x3580 | GPIO_MODEM_ANTSWEN-ROUTE_TGL     | RW   | ANTSWEN Port/Pin Select     |
| 0x3584 | GPIO_MODEM_ANTSWUS-ROUTE_TGL     | RW   | ANTSWUS Port/Pin Select     |
| 0x3588 | GPIO_MODEM_ANTRIG-ROUTE_TGL      | RW   | ANTTRIG Port/Pin Select     |
| 0x358C | GPIO_MODEM_ANTRIGSTOP-ROUTE_TGL  | RW   | ANTTRIGSTOP Port/Pin Select |
| 0x3590 | GPIO_MO-DEM_DCLKROUTE_TGL        | RW   | DCLK Port/Pin Select        |

| Offset | Name                        | Type | Description              |
|--------|-----------------------------|------|--------------------------|
| 0x3594 | GPIO_MODEM_DIN-ROUTE_TGL    | RW   | DIN Port/Pin Select      |
| 0x3598 | GPIO_MODEM_DOUT-ROUTE_TGL   | RW   | DOUT Port/Pin Select     |
| 0x35A4 | GPIO_PCNTO_S0IN-ROUTE_TGL   | RW   | S0IN Port/Pin Select     |
| 0x35A8 | GPIO_PCNTO_S1IN-ROUTE_TGL   | RW   | S1IN Port/Pin Select     |
| 0x35B0 | GPIO_PRS0_ROUTEEN_TGL       | RW   | PRS0 Pin Enable          |
| 0x35B4 | GPIO_PRS0_ASYNCH0ROUTE_TGL  | RW   | ASYNCH0 Port/Pin Select  |
| 0x35B8 | GPIO_PRS0_ASYNCH1ROUTE_TGL  | RW   | ASYNCH1 Port/Pin Select  |
| 0x35BC | GPIO_PRS0_ASYNCH2ROUTE_TGL  | RW   | ASYNCH2 Port/Pin Select  |
| 0x35C0 | GPIO_PRS0_ASYNCH3ROUTE_TGL  | RW   | ASYNCH3 Port/Pin Select  |
| 0x35C4 | GPIO_PRS0_ASYNCH4ROUTE_TGL  | RW   | ASYNCH4 Port/Pin Select  |
| 0x35C8 | GPIO_PRS0_ASYNCH5ROUTE_TGL  | RW   | ASYNCH5 Port/Pin Select  |
| 0x35CC | GPIO_PRS0_ASYNCH6ROUTE_TGL  | RW   | ASYNCH6 Port/Pin Select  |
| 0x35D0 | GPIO_PRS0_ASYNCH7ROUTE_TGL  | RW   | ASYNCH7 Port/Pin Select  |
| 0x35D4 | GPIO_PRS0_ASYNCH8ROUTE_TGL  | RW   | ASYNCH8 Port/Pin Select  |
| 0x35D8 | GPIO_PRS0_ASYNCH9ROUTE_TGL  | RW   | ASYNCH9 Port/Pin Select  |
| 0x35DC | GPIO_PRS0_ASYNCH10ROUTE_TGL | RW   | ASYNCH10 Port/Pin Select |
| 0x35E0 | GPIO_PRS0_ASYNCH11ROUTE_TGL | RW   | ASYNCH11 Port/Pin Select |
| 0x35E4 | GPIO_PRS0_ASYNCH12ROUTE_TGL | RW   | ASYNCH12 Port/Pin Select |
| 0x35E8 | GPIO_PRS0_ASYNCH13ROUTE_TGL | RW   | ASYNCH13 Port/Pin Select |
| 0x35EC | GPIO_PRS0_ASYNCH14ROUTE_TGL | RW   | ASYNCH14 Port/Pin Select |
| 0x35F0 | GPIO_PRS0_ASYNCH15ROUTE_TGL | RW   | ASYNCH15 Port/Pin Select |
| 0x35F4 | GPIO_PRS0_SYNCH0ROUTE_TGL   | RW   | SYNCH0 Port/Pin Select   |
| 0x35F8 | GPIO_PRS0_SYNCH1ROUTE_TGL   | RW   | SYNCH1 Port/Pin Select   |
| 0x35FC | GPIO_PRS0_SYNCH2ROUTE_TGL   | RW   | SYNCH2 Port/Pin Select   |

| Offset | Name                                  | Type | Description                      |
|--------|---------------------------------------|------|----------------------------------|
| 0x3600 | GPIO_PRS0_SYNCH3ROUTE_TGL             | RW   | SYNCH3 Port/Pin Select           |
| 0x3608 | GPIO_RAC_ROUTEEN_TGL                  | RW   | RAC Pin Enable                   |
| 0x360C | GPIO_RAC_LNAEN-ROUTE_TGL              | RW   | LNAEN Port/Pin Select            |
| 0x3610 | GPIO_RAC_PAENROUTE_TGL                | RW   | PAEN Port/Pin Select             |
| 0x3678 | GPIO_SYX00_BUFOUTREQINASYNCRROUTE_TGL | RW   | BUFOUTREQINASYNC Port/Pin Select |
| 0x3680 | GPIO_TIMER0_ROUTEEN_TGL               | RW   | TIMER0 Pin Enable                |
| 0x3684 | GPIO_TIM-ER0_CC0ROUTE_TGL             | RW   | CC0 Port/Pin Select              |
| 0x3688 | GPIO_TIM-ER0_CC1ROUTE_TGL             | RW   | CC1 Port/Pin Select              |
| 0x368C | GPIO_TIM-ER0_CC2ROUTE_TGL             | RW   | CC2 Port/Pin Select              |
| 0x3690 | GPIO_TIM-ER0_CDTI0ROUTE_TGL           | RW   | CDTI0 Port/Pin Select            |
| 0x3694 | GPIO_TIM-ER0_CDTI1ROUTE_TGL           | RW   | CDTI1 Port/Pin Select            |
| 0x3698 | GPIO_TIM-ER0_CDTI2ROUTE_TGL           | RW   | CDTI2 Port/Pin Select            |
| 0x36A0 | GPIO_TIMER1_ROUTEEN_TGL               | RW   | TIMER1 Pin Enable                |
| 0x36A4 | GPIO_TIM-ER1_CC0ROUTE_TGL             | RW   | CC0 Port/Pin Select              |
| 0x36A8 | GPIO_TIM-ER1_CC1ROUTE_TGL             | RW   | CC1 Port/Pin Select              |
| 0x36AC | GPIO_TIM-ER1_CC2ROUTE_TGL             | RW   | CC2 Port/Pin Select              |
| 0x36B0 | GPIO_TIM-ER1_CDTI0ROUTE_TGL           | RW   | CDTI0 Port/Pin Select            |
| 0x36B4 | GPIO_TIM-ER1_CDTI1ROUTE_TGL           | RW   | CDTI1 Port/Pin Select            |
| 0x36B8 | GPIO_TIM-ER1_CDTI2ROUTE_TGL           | RW   | CDTI2 Port/Pin Select            |
| 0x36C0 | GPIO_TIMER2_ROUTEEN_TGL               | RW   | TIMER2 Pin Enable                |
| 0x36C4 | GPIO_TIM-ER2_CC0ROUTE_TGL             | RW   | CC0 Port/Pin Select              |
| 0x36C8 | GPIO_TIM-ER2_CC1ROUTE_TGL             | RW   | CC1 Port/Pin Select              |
| 0x36CC | GPIO_TIM-ER2_CC2ROUTE_TGL             | RW   | CC2 Port/Pin Select              |
| 0x36D0 | GPIO_TIM-ER2_CDTI0ROUTE_TGL           | RW   | CDTI0 Port/Pin Select            |
| 0x36D4 | GPIO_TIM-ER2_CDTI1ROUTE_TGL           | RW   | CDTI1 Port/Pin Select            |

| Offset | Name                        | Type | Description           |
|--------|-----------------------------|------|-----------------------|
| 0x36D8 | GPIO_TIM-ER2_CDTI2ROUTE_TGL | RW   | CDTI2 Port/Pin Select |
| 0x36E0 | GPIO_TIMER3_ROUTEEN_TGL     | RW   | TIMER3 Pin Enable     |
| 0x36E4 | GPIO_TIM-ER3_CC0ROUTE_TGL   | RW   | CC0 Port/Pin Select   |
| 0x36E8 | GPIO_TIM-ER3_CC1ROUTE_TGL   | RW   | CC1 Port/Pin Select   |
| 0x36EC | GPIO_TIM-ER3_CC2ROUTE_TGL   | RW   | CC2 Port/Pin Select   |
| 0x36F0 | GPIO_TIM-ER3_CDTI0ROUTE_TGL | RW   | CDTI0 Port/Pin Select |
| 0x36F4 | GPIO_TIM-ER3_CDTI1ROUTE_TGL | RW   | CDTI1 Port/Pin Select |
| 0x36F8 | GPIO_TIM-ER3_CDTI2ROUTE_TGL | RW   | CDTI2 Port/Pin Select |
| 0x3700 | GPIO_TIMER4_ROUTEEN_TGL     | RW   | TIMER4 Pin Enable     |
| 0x3704 | GPIO_TIM-ER4_CC0ROUTE_TGL   | RW   | CC0 Port/Pin Select   |
| 0x3708 | GPIO_TIM-ER4_CC1ROUTE_TGL   | RW   | CC1 Port/Pin Select   |
| 0x370C | GPIO_TIM-ER4_CC2ROUTE_TGL   | RW   | CC2 Port/Pin Select   |
| 0x3710 | GPIO_TIM-ER4_CDTI0ROUTE_TGL | RW   | CDTI0 Port/Pin Select |
| 0x3714 | GPIO_TIM-ER4_CDTI1ROUTE_TGL | RW   | CDTI1 Port/Pin Select |
| 0x3718 | GPIO_TIM-ER4_CDTI2ROUTE_TGL | RW   | CDTI2 Port/Pin Select |
| 0x3720 | GPIO_USART0_ROU-TEEN_TGL    | RW   | USART0 Pin Enable     |
| 0x3724 | GPIO_USART0_CSROUTE_TG_L    | RW   | CS Port/Pin Select    |
| 0x3728 | GPIO_USART0_CTSROUTE_T_GL   | RW   | CTS Port/Pin Select   |
| 0x372C | GPIO_USART0_RTSROUTE_T_GL   | RW   | RTS Port/Pin Select   |
| 0x3730 | GPIO_USART0_RXROUTE_TG_L    | RW   | RX Port/Pin Select    |
| 0x3734 | GPIO_USART0_CLKROUTE_T_GL   | RW   | SCLK Port/Pin Select  |
| 0x3738 | GPIO_USART0_TXROUTE_TGL     | RW   | TX Port/Pin Select    |

## 24.6 GPIO Register Description

### 24.6.1 GPIO\_IPVERSION - Main

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 0x000  | 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 |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x3 |    |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | R  |           |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    | IPVERSION |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Bit  | Name      | Reset | Access | Description                   |
|------|-----------|-------|--------|-------------------------------|
| 31:0 | IPVERSION | 0x3   | R      | ip version id<br>IPVERSION ID |

## 24.6.2 GPIO\_PORTA\_CTRL - Port Control

| Offset | Bit Position |           |    |     |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    |        |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|-----------|----|-----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|----|--------|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x030  | 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 |  |
| Reset  |              |           |    | 0x0 |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    | 0x0    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |           | RW |     |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    | RW     |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              | DINDISALT |    |     |    |    |    |    |    | SLEWRATEALT | RW |    |    |    |    |    |    |    |    | DINDIS |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 28    | DINDISALT   | 0x0   | RW     | <b>Data In Disable Alt</b><br><br>Data input disable for port pins using alternate modes.                                                                                         |
| 27:23 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 22:20 | SLEWRATEALT | 0x4   | RW     | <b>Slew Rate Alt</b><br><br>Slewrate limit for port pins using alternate modes. Higher values representer faster slewrates.                                                       |
| 19:13 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | DINDIS      | 0x0   | RW     | <b>Data In Disable</b><br><br>Data input disable for port pins not using alternate modes.                                                                                         |
| 11:7  | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 6:4   | SLEWRATE    | 0x4   | RW     | <b>Slew Rate</b><br><br>Slewrate limit for port pins using not alternate modes. Higher values representer faster slewrates.                                                       |
| 3:0   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 24.6.3 GPIO\_PORTA\_MODEL - Mode Low

| Offset | Bit Position |    |    |    |       |    |    |    |       |    |    |    |       |    |    |    |       |    |    |    |       |    |   |   |       |   |   |   |       |   |   |   |
|--------|--------------|----|----|----|-------|----|----|----|-------|----|----|----|-------|----|----|----|-------|----|----|----|-------|----|---|---|-------|---|---|---|-------|---|---|---|
| 0x034  | 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 |
| Reset  | 0x0          |    |    |    | 0x0   |    |    |    | 0x0   |    |    |    | 0x0   |    |    |    | 0x0   |    |    |    | 0x0   |    |   |   | 0x0   |   |   |   |       |   |   |   |
| Access | RW           |    |    |    | RW    |    |    |    | RW    |    |    |    | RW    |    |    |    | RW    |    |    |    | RW    |    |   |   | RW    |   |   |   |       |   |   |   |
| Name   | MODE7        |    |    |    | MODE6 |    |    |    | MODE5 |    |    |    | MODE4 |    |    |    | MODE3 |    |    |    | MODE2 |    |   |   | MODE1 |   |   |   | MODE0 |   |   |   |

| Bit   | Name   | Reset                   | Access | Description                                                       |
|-------|--------|-------------------------|--------|-------------------------------------------------------------------|
| 31:28 | MODE7  | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n |                         |        |                                                                   |
|       | Value  | Mode                    |        | Description                                                       |
|       | 0      | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1      | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2      | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3      | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |
|       | 4      | PUSHPULL                |        | Push-pull output.                                                 |
|       | 5      | PUSHPULLALT             |        | Push-pull using alternate control.                                |
|       | 6      | WIREDOR                 |        | Wired-or output.                                                  |
|       | 7      | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                   |
|       | 8      | WIREDAND                |        | Open-drain output.                                                |
|       | 9      | WIREDANDFILTER          |        | Open-drain output with filter.                                    |
|       | 10     | WIREDANDPULLUP          |        | Open-drain output with pullup.                                    |
|       | 11     | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                         |
|       | 12     | WIREDANDALT             |        | Open-drain output using alternate control.                        |
|       | 13     | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.            |
|       | 14     | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.            |
|       | 15     | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup. |
| 27:24 | MODE6  | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n |                         |        |                                                                   |
|       | Value  | Mode                    |        | Description                                                       |
|       | 0      | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1      | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2      | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3      | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |

| Bit   | Name                    | Reset                   | Access | Description                                                       |
|-------|-------------------------|-------------------------|--------|-------------------------------------------------------------------|
| 4     | PUSHPULL                |                         |        | Push-pull output.                                                 |
| 5     | PUSHPULLALT             |                         |        | Push-pull using alternate control.                                |
| 6     | WIREDOR                 |                         |        | Wired-or output.                                                  |
| 7     | WIREDORPULLDOWN         |                         |        | Wired-or output with pull-down.                                   |
| 8     | WIREDAND                |                         |        | Open-drain output.                                                |
| 9     | WIREDANDFILTER          |                         |        | Open-drain output with filter.                                    |
| 10    | WIREDANDPULLUP          |                         |        | Open-drain output with pullup.                                    |
| 11    | WIREDANDPULLUPFILTER    |                         |        | Open-drain output with filter and pullup.                         |
| 12    | WIREDANDALT             |                         |        | Open-drain output using alternate control.                        |
| 13    | WIREDANDALTFILTER       |                         |        | Open-drain output using alternate control with filter.            |
| 14    | WIREDANDALTPULLUP       |                         |        | Open-drain output using alternate control with pullup.            |
| 15    | WIREDANDALTPULLUPFILTER |                         |        | Open-drain output using alternate control with filter and pullup. |
| 23:20 | MODE5                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |
|       | Value                   | Mode                    |        | Description                                                       |
|       | 0                       | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1                       | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2                       | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3                       | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |
|       | 4                       | PUSHPULL                |        | Push-pull output.                                                 |
|       | 5                       | PUSHPULLALT             |        | Push-pull using alternate control.                                |
|       | 6                       | WIREDOR                 |        | Wired-or output.                                                  |
|       | 7                       | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                   |
|       | 8                       | WIREDAND                |        | Open-drain output.                                                |
|       | 9                       | WIREDANDFILTER          |        | Open-drain output with filter.                                    |
|       | 10                      | WIREDANDPULLUP          |        | Open-drain output with pullup.                                    |
|       | 11                      | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                         |
|       | 12                      | WIREDANDALT             |        | Open-drain output using alternate control.                        |
|       | 13                      | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.            |
|       | 14                      | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.            |
|       | 15                      | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup. |
| 19:16 | MODE4                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |

| Bit   | Name   | Reset                   | Access | Description   |
|-------|--------|-------------------------|--------|---------------|
|       | Value  | Mode                    |        |               |
|       | 0      | DISABLED                |        |               |
|       | 1      | INPUT                   |        |               |
|       | 2      | INPUTPULL               |        |               |
|       | 3      | INPUTPULLFILTER         |        |               |
|       | 4      | PUSHPULL                |        |               |
|       | 5      | PUSHPULLALT             |        |               |
|       | 6      | WIREDOR                 |        |               |
|       | 7      | WIREDORPULLDOWN         |        |               |
|       | 8      | WIREDAND                |        |               |
|       | 9      | WIREDANDFILTER          |        |               |
|       | 10     | WIREDANDPULLUP          |        |               |
|       | 11     | WIREDANDPULLUPFILTER    |        |               |
|       | 12     | WIREDANDALT             |        |               |
|       | 13     | WIREDANDALTFILTER       |        |               |
|       | 14     | WIREDANDALTPULLUP       |        |               |
|       | 15     | WIREDANDALTPULLUPFILTER |        |               |
| 15:12 | MODE3  | 0x0                     | RW     | <b>MODE n</b> |
|       | MODE n |                         |        |               |
|       | Value  | Mode                    |        |               |
|       | 0      | DISABLED                |        |               |
|       | 1      | INPUT                   |        |               |
|       | 2      | INPUTPULL               |        |               |
|       | 3      | INPUTPULLFILTER         |        |               |
|       | 4      | PUSHPULL                |        |               |
|       | 5      | PUSHPULLALT             |        |               |
|       | 6      | WIREDOR                 |        |               |
|       | 7      | WIREDORPULLDOWN         |        |               |
|       | 8      | WIREDAND                |        |               |
|       | 9      | WIREDANDFILTER          |        |               |
|       | 10     | WIREDANDPULLUP          |        |               |
|       | 11     | WIREDANDPULLUPFILTER    |        |               |
|       | 12     | WIREDANDALT             |        |               |
|       | 13     | WIREDANDALTFILTER       |        |               |
|       | 14     | WIREDANDALTPULLUP       |        |               |

| Bit  | Name   | Reset                     | Access | Description                                                       |
|------|--------|---------------------------|--------|-------------------------------------------------------------------|
|      | 15     | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |
| 11:8 | MODE2  | 0x0                       | RW     | <b>MODE n</b>                                                     |
|      | MODE n |                           |        |                                                                   |
|      | Value  | Mode                      |        | Description                                                       |
|      | 0      | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|      | 1      | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|      | 2      | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|      | 3      | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|      | 4      | PUSHPULL                  |        | Push-pull output.                                                 |
|      | 5      | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|      | 6      | WIREDOR                   |        | Wired-or output.                                                  |
|      | 7      | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|      | 8      | WIREDAND                  |        | Open-drain output.                                                |
|      | 9      | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|      | 10     | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |
|      | 11     | WIREDANDPULLUPFIL-TER     |        | Open-drain output with filter and pullup.                         |
|      | 12     | WIREDANDALT               |        | Open-drain output using alternate control.                        |
|      | 13     | WIREDANDALT FILTER        |        | Open-drain output using alternate control with filter.            |
|      | 14     | WIREDANDALT PULLUP        |        | Open-drain output using alternate control with pullup.            |
|      | 15     | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |
| 7:4  | MODE1  | 0x0                       | RW     | <b>MODE n</b>                                                     |
|      | MODE n |                           |        |                                                                   |
|      | Value  | Mode                      |        | Description                                                       |
|      | 0      | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|      | 1      | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|      | 2      | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|      | 3      | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|      | 4      | PUSHPULL                  |        | Push-pull output.                                                 |
|      | 5      | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|      | 6      | WIREDOR                   |        | Wired-or output.                                                  |
|      | 7      | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|      | 8      | WIREDAND                  |        | Open-drain output.                                                |
|      | 9      | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|      | 10     | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |

| Bit | Name                      | Reset                     | Access | Description                                                       |
|-----|---------------------------|---------------------------|--------|-------------------------------------------------------------------|
| 11  | WIREDANDPULLUPFIL-TER     |                           |        | Open-drain output with filter and pullup.                         |
| 12  | WIREDANDALT               |                           |        | Open-drain output using alternate control.                        |
| 13  | WIREDANDALTFILTER         |                           |        | Open-drain output using alternate control with filter.            |
| 14  | WIREDANDALTPULLUP         |                           |        | Open-drain output using alternate control with pullup.            |
| 15  | WIREDANDALTPULLUP- FILTER |                           |        | Open-drain output using alternate control with filter and pullup. |
| 3:0 | MODE0                     | 0x0                       | RW     | <b>MODE n</b>                                                     |
|     | MODE n                    |                           |        |                                                                   |
|     | Value                     | Mode                      |        | Description                                                       |
|     | 0                         | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|     | 1                         | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|     | 2                         | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|     | 3                         | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|     | 4                         | PUSHPULL                  |        | Push-pull output.                                                 |
|     | 5                         | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|     | 6                         | WIREDOR                   |        | Wired-or output.                                                  |
|     | 7                         | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|     | 8                         | WIREDAND                  |        | Open-drain output.                                                |
|     | 9                         | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|     | 10                        | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |
|     | 11                        | WIREDANDPULLUPFIL-TER     |        | Open-drain output with filter and pullup.                         |
|     | 12                        | WIREDANDALT               |        | Open-drain output using alternate control.                        |
|     | 13                        | WIREDANDALTFILTER         |        | Open-drain output using alternate control with filter.            |
|     | 14                        | WIREDANDALTPULLUP         |        | Open-drain output using alternate control with pullup.            |
|     | 15                        | WIREDANDALTPULLUP- FILTER |        | Open-drain output using alternate control with filter and pullup. |

## 24.6.4 GPIO\_PORTA\_MODEH - Mode High

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |       |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-------|---|---|---|
| 0x03C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0 |       |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW  |       |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     | MODE1 |   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     | MODE0 |   |   |   |

| Bit  | Name     | Reset                   | Access | Description                                                                                                                                                       |
|------|----------|-------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 7:4  | MODE1    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                     |
|      | MODE n   |                         |        |                                                                                                                                                                   |
|      | Value    | Mode                    |        | Description                                                                                                                                                       |
|      | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                            |
|      | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                             |
|      | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                    |
|      | 3        | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.                                                                                                        |
|      | 4        | PUSHPULL                |        | Push-pull output.                                                                                                                                                 |
|      | 5        | PUSHPULLALT             |        | Push-pull using alternate control.                                                                                                                                |
|      | 6        | WIREDOR                 |        | Wired-or output.                                                                                                                                                  |
|      | 7        | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                                                                                                                   |
|      | 8        | WIREDAND                |        | Open-drain output.                                                                                                                                                |
|      | 9        | WIREDANDFILTER          |        | Open-drain output with filter.                                                                                                                                    |
|      | 10       | WIREDANDPULLUP          |        | Open-drain output with pullup.                                                                                                                                    |
|      | 11       | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                                                                                                                         |
|      | 12       | WIREDANDALT             |        | Open-drain output using alternate control.                                                                                                                        |
|      | 13       | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.                                                                                                            |
|      | 14       | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.                                                                                                            |
|      | 15       | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup.                                                                                                 |
| 3:0  | MODE0    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                     |
|      | MODE n   |                         |        |                                                                                                                                                                   |
|      | Value    | Mode                    |        | Description                                                                                                                                                       |
|      | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                            |
|      | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                             |
|      | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                    |

| Bit | Name | Reset                     | Access | Description                                                       |
|-----|------|---------------------------|--------|-------------------------------------------------------------------|
| 3   |      | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
| 4   |      | PUSHPULL                  |        | Push-pull output.                                                 |
| 5   |      | PUSHPULLALT               |        | Push-pull using alternate control.                                |
| 6   |      | WIREDOR                   |        | Wired-or output.                                                  |
| 7   |      | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
| 8   |      | WIREDAND                  |        | Open-drain output.                                                |
| 9   |      | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
| 10  |      | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |
| 11  |      | WIREDANDPULLUPFIL-TER     |        | Open-drain output with filter and pullup.                         |
| 12  |      | WIREDANDALT               |        | Open-drain output using alternate control.                        |
| 13  |      | WIREDANDALTFILTER         |        | Open-drain output using alternate control with filter.            |
| 14  |      | WIREDANDALTPULLUP         |        | Open-drain output using alternate control with pullup.            |
| 15  |      | WIREDANDALTPULLUP- FILTER |        | Open-drain output using alternate control with filter and pullup. |

#### 24.6.5 GPIO\_PORTA\_DOUT - Data Out

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|----|------|
| 0x040  | 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  |      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |    |      |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | RW |      |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    | DOUT |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:0   | DOUT     | 0x0   | RW     | <b>Data output</b><br><br>Data output                                                                                                                                             |

#### 24.6.6 GPIO\_PORTA\_DIN - Data in

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 0x044  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DIN |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:0   | DIN      | 0x0   | R      | <b>Data input</b>                                                                                                                                                                 |
|       |          |       |        | Data input                                                                                                                                                                        |

## 24.6.7 GPIO\_PORTB\_CTRL - Port Control

| Offset | Bit Position |           |    |     |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    |        |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|-----------|----|-----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|----|--------|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x060  | 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 |  |
| Reset  |              |           |    | 0x0 |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    | 0x0    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |           | RW |     |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    | RW     |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              | DINDISALT |    |     |    |    |    |    |    | SLEWRATEALT | RW |    |    |    |    |    |    |    |    | DINDIS |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 28    | DINDISALT   | 0x0   | RW     | <b>Data In Disable Alt</b><br><br>Data input disable for port pins using alternate modes.                                                                                         |
| 27:23 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 22:20 | SLEWRATEALT | 0x4   | RW     | <b>Slew Rate Alt</b><br><br>Slewrate limit for port pins using alternate modes. Higher values representer faster slewrates.                                                       |
| 19:13 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | DINDIS      | 0x0   | RW     | <b>Data In Disable</b><br><br>Data input disable for port pins not using alternate modes.                                                                                         |
| 11:7  | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 6:4   | SLEWRATE    | 0x4   | RW     | <b>Slew Rate</b><br><br>Slewrate limit for port pins using not alternate modes. Higher values representer faster slewrates.                                                       |
| 3:0   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 24.6.8 GPIO\_PORTB\_MODEL - Mode Low

| Offset | Bit Position |    |    |    |       |    |    |    |    |       |    |    |    |    |       |    |    |    |    |       |    |    |   |   |       |   |   |   |   |       |   |   |  |  |
|--------|--------------|----|----|----|-------|----|----|----|----|-------|----|----|----|----|-------|----|----|----|----|-------|----|----|---|---|-------|---|---|---|---|-------|---|---|--|--|
| 0x064  | 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 |  |  |
| Reset  |              |    |    |    | 0x0   |    |    |    |    | 0x0   |    |    |    |    | 0x0   |    |    |    |    | 0x0   |    |    |   |   | 0x0   |   |   |   |   |       |   |   |  |  |
| Access |              |    |    |    | RW    |    |    |    |    | RW    |    |    |    |    | RW    |    |    |    |    | RW    |    |    |   |   | RW    |   |   |   |   |       |   |   |  |  |
| Name   |              |    |    |    | MODE5 |    |    |    |    | MODE4 |    |    |    |    | MODE3 |    |    |    |    | MODE2 |    |    |   |   | MODE1 |   |   |   |   | MODE0 |   |   |  |  |

| Bit   | Name     | Reset                   | Access | Description                                                                                                                                                                       |
|-------|----------|-------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved |                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:20 | MODE5    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                                     |
|       | MODE n   |                         |        |                                                                                                                                                                                   |
|       | Value    | Mode                    |        | Description                                                                                                                                                                       |
|       | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                                            |
|       | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                                             |
|       | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                                    |
|       | 3        | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.                                                                                                                        |
|       | 4        | PUSHPULL                |        | Push-pull output.                                                                                                                                                                 |
|       | 5        | PUSHPULLALT             |        | Push-pull using alternate control.                                                                                                                                                |
|       | 6        | WIREDOR                 |        | Wired-or output.                                                                                                                                                                  |
|       | 7        | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                                                                                                                                   |
|       | 8        | WIREDAND                |        | Open-drain output.                                                                                                                                                                |
|       | 9        | WIREDANDFILTER          |        | Open-drain output with filter.                                                                                                                                                    |
|       | 10       | WIREDANDPULLUP          |        | Open-drain output with pullup.                                                                                                                                                    |
|       | 11       | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                                                                                                                                         |
|       | 12       | WIREDANDALT             |        | Open-drain output using alternate control.                                                                                                                                        |
|       | 13       | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.                                                                                                                            |
|       | 14       | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.                                                                                                                            |
|       | 15       | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup.                                                                                                                 |
| 19:16 | MODE4    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                                     |
|       | MODE n   |                         |        |                                                                                                                                                                                   |
|       | Value    | Mode                    |        | Description                                                                                                                                                                       |
|       | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                                            |
|       | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                                             |
|       | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                                    |

| Bit   | Name                    | Reset                   | Access | Description                                                       |
|-------|-------------------------|-------------------------|--------|-------------------------------------------------------------------|
| 3     | INPUTPULLFILTER         |                         |        | Input enabled with filter. DOUT determines pull direction.        |
| 4     | PUSHPULL                |                         |        | Push-pull output.                                                 |
| 5     | PUSHPULLALT             |                         |        | Push-pull using alternate control.                                |
| 6     | WIREDOR                 |                         |        | Wired-or output.                                                  |
| 7     | WIREDORPULLDOWN         |                         |        | Wired-or output with pull-down.                                   |
| 8     | WIREDAND                |                         |        | Open-drain output.                                                |
| 9     | WIREDANDFILTER          |                         |        | Open-drain output with filter.                                    |
| 10    | WIREDANDPULLUP          |                         |        | Open-drain output with pullup.                                    |
| 11    | WIREDANDPULLUPFILTER    |                         |        | Open-drain output with filter and pullup.                         |
| 12    | WIREDANDALT             |                         |        | Open-drain output using alternate control.                        |
| 13    | WIREDANDALTFILTER       |                         |        | Open-drain output using alternate control with filter.            |
| 14    | WIREDANDALTPULLUP       |                         |        | Open-drain output using alternate control with pullup.            |
| 15    | WIREDANDALTPULLUPFILTER |                         |        | Open-drain output using alternate control with filter and pullup. |
| 15:12 | MODE3                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |
|       | Value                   | Mode                    |        | Description                                                       |
|       | 0                       | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1                       | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2                       | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3                       | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |
|       | 4                       | PUSHPULL                |        | Push-pull output.                                                 |
|       | 5                       | PUSHPULLALT             |        | Push-pull using alternate control.                                |
|       | 6                       | WIREDOR                 |        | Wired-or output.                                                  |
|       | 7                       | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                   |
|       | 8                       | WIREDAND                |        | Open-drain output.                                                |
|       | 9                       | WIREDANDFILTER          |        | Open-drain output with filter.                                    |
|       | 10                      | WIREDANDPULLUP          |        | Open-drain output with pullup.                                    |
|       | 11                      | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                         |
|       | 12                      | WIREDANDALT             |        | Open-drain output using alternate control.                        |
|       | 13                      | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.            |
|       | 14                      | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.            |
|       | 15                      | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup. |
| 11:8  | MODE2                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |

| Bit | Name   | Reset                   | Access | Description   |
|-----|--------|-------------------------|--------|---------------|
|     | Value  | Mode                    |        |               |
|     | 0      | DISABLED                |        |               |
|     | 1      | INPUT                   |        |               |
|     | 2      | INPUTPULL               |        |               |
|     | 3      | INPUTPULLFILTER         |        |               |
|     | 4      | PUSHPULL                |        |               |
|     | 5      | PUSHPULLALT             |        |               |
|     | 6      | WIREDOR                 |        |               |
|     | 7      | WIREDORPULLDOWN         |        |               |
|     | 8      | WIREDAND                |        |               |
|     | 9      | WIREDANDFILTER          |        |               |
|     | 10     | WIREDANDPULLUP          |        |               |
|     | 11     | WIREDANDPULLUPFILTER    |        |               |
|     | 12     | WIREDANDALT             |        |               |
|     | 13     | WIREDANDALTFILTER       |        |               |
|     | 14     | WIREDANDALTPULLUP       |        |               |
|     | 15     | WIREDANDALTPULLUPFILTER |        |               |
| 7:4 | MODE1  | 0x0                     | RW     | <b>MODE n</b> |
|     | MODE n |                         |        |               |
|     | Value  | Mode                    |        |               |
|     | 0      | DISABLED                |        |               |
|     | 1      | INPUT                   |        |               |
|     | 2      | INPUTPULL               |        |               |
|     | 3      | INPUTPULLFILTER         |        |               |
|     | 4      | PUSHPULL                |        |               |
|     | 5      | PUSHPULLALT             |        |               |
|     | 6      | WIREDOR                 |        |               |
|     | 7      | WIREDORPULLDOWN         |        |               |
|     | 8      | WIREDAND                |        |               |
|     | 9      | WIREDANDFILTER          |        |               |
|     | 10     | WIREDANDPULLUP          |        |               |
|     | 11     | WIREDANDPULLUPFILTER    |        |               |
|     | 12     | WIREDANDALT             |        |               |
|     | 13     | WIREDANDALTFILTER       |        |               |

| Bit | Name   | Reset                     | Access | Description                                                       |
|-----|--------|---------------------------|--------|-------------------------------------------------------------------|
|     | 14     | WIREDANDALT PULLUP        |        | Open-drain output using alternate control with pullup.            |
|     | 15     | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |
| 3:0 | MODE0  | 0x0                       | RW     | <b>MODE n</b>                                                     |
|     | MODE n |                           |        |                                                                   |
|     | Value  | Mode                      |        | Description                                                       |
|     | 0      | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|     | 1      | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|     | 2      | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|     | 3      | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|     | 4      | PUSHPULL                  |        | Push-pull output.                                                 |
|     | 5      | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|     | 6      | WIREDOR                   |        | Wired-or output.                                                  |
|     | 7      | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|     | 8      | WIREDAND                  |        | Open-drain output.                                                |
|     | 9      | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|     | 10     | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |
|     | 11     | WIREDANDPULLUPFIL-TER     |        | Open-drain output with filter and pullup.                         |
|     | 12     | WIREDANDALT               |        | Open-drain output using alternate control.                        |
|     | 13     | WIREDANDALT FILTER        |        | Open-drain output using alternate control with filter.            |
|     | 14     | WIREDANDALT PULLUP        |        | Open-drain output using alternate control with pullup.            |
|     | 15     | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |

#### 24.6.9 GPIO\_PORTB\_DOUT - Data Out

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----|--|--|--|--|------|
| Reset  | 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 |     |  |  |  |  |      |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0 |  |  |  |  |      |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |  |  |  | DOUT |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                                       |
|------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:0  | DOUT        | 0x0   | RW     | <b>Data output</b>                                                                                                                                                                |
|      | Data output |       |        |                                                                                                                                                                                   |

**24.6.10 GPIO\_PORTB\_DIN - Data in**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 0x074         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DIN |   |   |   |   |   |   |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:0  | DIN             | 0x0   | R      | <b>Data input</b>                                                                                                                                                                 |
|      |                 |       |        | Data input                                                                                                                                                                        |

## 24.6.11 GPIO\_PORTC\_CTRL - Port Control

| Offset | Bit Position |           |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|-----------|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x090  | 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 |
| Reset  |              | 0x0       | RW |    |    |    |    |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |           | RW |    |    |    |    |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              | DINDISALT |    |    |    |    |    | SLEWRATEALT | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|        |              |           |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 28    | DINDISALT   | 0x0   | RW     | <b>Data In Disable Alt</b><br><br>Data input disable for port pins using alternate modes.                                                                                         |
| 27:23 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 22:20 | SLEWRATEALT | 0x4   | RW     | <b>Slew Rate Alt</b><br><br>Slewrate limit for port pins using alternate modes. Higher values representer faster slewrates.                                                       |
| 19:13 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | DINDIS      | 0x0   | RW     | <b>Data In Disable</b><br><br>Data input disable for port pins not using alternate modes.                                                                                         |
| 11:7  | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 6:4   | SLEWRATE    | 0x4   | RW     | <b>Slew Rate</b><br><br>Slewrate limit for port pins using not alternate modes. Higher values representer faster slewrates.                                                       |
| 3:0   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 24.6.12 GPIO\_PORTC\_MODEL - Mode Low

| Offset        | Bit Position |     |    |       |    |    |    |       |    |    |    |    |    |    |       |    |    |    |       |    |    |    |   |   |   |   |   |   |   |       |   |   |
|---------------|--------------|-----|----|-------|----|----|----|-------|----|----|----|----|----|----|-------|----|----|----|-------|----|----|----|---|---|---|---|---|---|---|-------|---|---|
| 0x094         | 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 |
| <b>Reset</b>  |              | 0x0 |    |       |    |    |    |       |    |    |    |    |    |    |       |    |    |    |       |    |    |    |   |   |   |   |   |   |   |       |   |   |
| <b>Access</b> |              | RW  |    |       |    |    | RW |       |    |    |    |    |    |    | RW    |    |    |    |       |    |    |    |   |   |   |   |   |   |   |       |   |   |
| <b>Name</b>   | MODE7        |     |    | MODE6 |    |    |    | MODE5 |    |    |    |    |    |    | MODE4 |    |    |    | MODE3 |    |    |    |   |   |   |   |   |   |   | MODE0 |   |   |

| Bit   | Name   | Reset                   | Access | Description                                                       |
|-------|--------|-------------------------|--------|-------------------------------------------------------------------|
| 31:28 | MODE7  | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n |                         |        |                                                                   |
|       | Value  | Mode                    |        | Description                                                       |
|       | 0      | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1      | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2      | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3      | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |
|       | 4      | PUSHPULL                |        | Push-pull output.                                                 |
|       | 5      | PUSHPULLALT             |        | Push-pull using alternate control.                                |
|       | 6      | WIREDOR                 |        | Wired-or output.                                                  |
|       | 7      | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                   |
|       | 8      | WIREDAND                |        | Open-drain output.                                                |
|       | 9      | WIREDANDFILTER          |        | Open-drain output with filter.                                    |
|       | 10     | WIREDANDPULLUP          |        | Open-drain output with pullup.                                    |
|       | 11     | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                         |
|       | 12     | WIREDANDALT             |        | Open-drain output using alternate control.                        |
|       | 13     | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.            |
|       | 14     | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.            |
|       | 15     | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup. |
| 27:24 | MODE6  | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n |                         |        |                                                                   |
|       | Value  | Mode                    |        | Description                                                       |
|       | 0      | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1      | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2      | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3      | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |

| Bit   | Name                    | Reset                   | Access | Description                                                       |
|-------|-------------------------|-------------------------|--------|-------------------------------------------------------------------|
| 4     | PUSHPULL                |                         |        | Push-pull output.                                                 |
| 5     | PUSHPULLALT             |                         |        | Push-pull using alternate control.                                |
| 6     | WIREDOR                 |                         |        | Wired-or output.                                                  |
| 7     | WIREDORPULLDOWN         |                         |        | Wired-or output with pull-down.                                   |
| 8     | WIREDAND                |                         |        | Open-drain output.                                                |
| 9     | WIREDANDFILTER          |                         |        | Open-drain output with filter.                                    |
| 10    | WIREDANDPULLUP          |                         |        | Open-drain output with pullup.                                    |
| 11    | WIREDANDPULLUPFILTER    |                         |        | Open-drain output with filter and pullup.                         |
| 12    | WIREDANDALT             |                         |        | Open-drain output using alternate control.                        |
| 13    | WIREDANDALTFILTER       |                         |        | Open-drain output using alternate control with filter.            |
| 14    | WIREDANDALTPULLUP       |                         |        | Open-drain output using alternate control with pullup.            |
| 15    | WIREDANDALTPULLUPFILTER |                         |        | Open-drain output using alternate control with filter and pullup. |
| 23:20 | MODE5                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |
|       | Value                   | Mode                    |        | Description                                                       |
|       | 0                       | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1                       | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2                       | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3                       | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |
|       | 4                       | PUSHPULL                |        | Push-pull output.                                                 |
|       | 5                       | PUSHPULLALT             |        | Push-pull using alternate control.                                |
|       | 6                       | WIREDOR                 |        | Wired-or output.                                                  |
|       | 7                       | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                   |
|       | 8                       | WIREDAND                |        | Open-drain output.                                                |
|       | 9                       | WIREDANDFILTER          |        | Open-drain output with filter.                                    |
|       | 10                      | WIREDANDPULLUP          |        | Open-drain output with pullup.                                    |
|       | 11                      | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                         |
|       | 12                      | WIREDANDALT             |        | Open-drain output using alternate control.                        |
|       | 13                      | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.            |
|       | 14                      | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.            |
|       | 15                      | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup. |
| 19:16 | MODE4                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |

| Bit   | Name   | Reset                   | Access | Description   |
|-------|--------|-------------------------|--------|---------------|
|       | Value  | Mode                    |        |               |
|       | 0      | DISABLED                |        |               |
|       | 1      | INPUT                   |        |               |
|       | 2      | INPUTPULL               |        |               |
|       | 3      | INPUTPULLFILTER         |        |               |
|       | 4      | PUSHPULL                |        |               |
|       | 5      | PUSHPULLALT             |        |               |
|       | 6      | WIREDOR                 |        |               |
|       | 7      | WIREDORPULLDOWN         |        |               |
|       | 8      | WIREDAND                |        |               |
|       | 9      | WIREDANDFILTER          |        |               |
|       | 10     | WIREDANDPULLUP          |        |               |
|       | 11     | WIREDANDPULLUPFILTER    |        |               |
|       | 12     | WIREDANDALT             |        |               |
|       | 13     | WIREDANDALTFILTER       |        |               |
|       | 14     | WIREDANDALTPULLUP       |        |               |
|       | 15     | WIREDANDALTPULLUPFILTER |        |               |
| 15:12 | MODE3  | 0x0                     | RW     | <b>MODE n</b> |
|       | MODE n |                         |        |               |
|       | Value  | Mode                    |        |               |
|       | 0      | DISABLED                |        |               |
|       | 1      | INPUT                   |        |               |
|       | 2      | INPUTPULL               |        |               |
|       | 3      | INPUTPULLFILTER         |        |               |
|       | 4      | PUSHPULL                |        |               |
|       | 5      | PUSHPULLALT             |        |               |
|       | 6      | WIREDOR                 |        |               |
|       | 7      | WIREDORPULLDOWN         |        |               |
|       | 8      | WIREDAND                |        |               |
|       | 9      | WIREDANDFILTER          |        |               |
|       | 10     | WIREDANDPULLUP          |        |               |
|       | 11     | WIREDANDPULLUPFILTER    |        |               |
|       | 12     | WIREDANDALT             |        |               |
|       | 13     | WIREDANDALTFILTER       |        |               |
|       | 14     | WIREDANDALTPULLUP       |        |               |

| Bit  | Name   | Reset                     | Access | Description                                                       |
|------|--------|---------------------------|--------|-------------------------------------------------------------------|
|      | 15     | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |
| 11:8 | MODE2  | 0x0                       | RW     | <b>MODE n</b>                                                     |
|      | MODE n |                           |        |                                                                   |
|      | Value  | Mode                      |        | Description                                                       |
|      | 0      | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|      | 1      | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|      | 2      | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|      | 3      | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|      | 4      | PUSHPULL                  |        | Push-pull output.                                                 |
|      | 5      | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|      | 6      | WIREDOR                   |        | Wired-or output.                                                  |
|      | 7      | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|      | 8      | WIREDAND                  |        | Open-drain output.                                                |
|      | 9      | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|      | 10     | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |
|      | 11     | WIREDANDPULLUPFIL-TER     |        | Open-drain output with filter and pullup.                         |
|      | 12     | WIREDANDALT               |        | Open-drain output using alternate control.                        |
|      | 13     | WIREDANDALT FILTER        |        | Open-drain output using alternate control with filter.            |
|      | 14     | WIREDANDALT PULLUP        |        | Open-drain output using alternate control with pullup.            |
|      | 15     | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |
| 7:4  | MODE1  | 0x0                       | RW     | <b>MODE n</b>                                                     |
|      | MODE n |                           |        |                                                                   |
|      | Value  | Mode                      |        | Description                                                       |
|      | 0      | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|      | 1      | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|      | 2      | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|      | 3      | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|      | 4      | PUSHPULL                  |        | Push-pull output.                                                 |
|      | 5      | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|      | 6      | WIREDOR                   |        | Wired-or output.                                                  |
|      | 7      | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|      | 8      | WIREDAND                  |        | Open-drain output.                                                |
|      | 9      | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|      | 10     | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |

| Bit | Name                      | Reset                     | Access | Description                                                       |
|-----|---------------------------|---------------------------|--------|-------------------------------------------------------------------|
| 11  | WIREDANDPULLUPFIL-TER     |                           |        | Open-drain output with filter and pullup.                         |
| 12  | WIREDANDALT               |                           |        | Open-drain output using alternate control.                        |
| 13  | WIREDANDALTFILTER         |                           |        | Open-drain output using alternate control with filter.            |
| 14  | WIREDANDALTPULLUP         |                           |        | Open-drain output using alternate control with pullup.            |
| 15  | WIREDANDALTPULLUP- FILTER |                           |        | Open-drain output using alternate control with filter and pullup. |
| 3:0 | MODE0                     | 0x0                       | RW     | <b>MODE n</b>                                                     |
|     | MODE n                    |                           |        |                                                                   |
|     | Value                     | Mode                      |        | Description                                                       |
|     | 0                         | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|     | 1                         | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|     | 2                         | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|     | 3                         | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|     | 4                         | PUSHPULL                  |        | Push-pull output.                                                 |
|     | 5                         | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|     | 6                         | WIREDOR                   |        | Wired-or output.                                                  |
|     | 7                         | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|     | 8                         | WIREDAND                  |        | Open-drain output.                                                |
|     | 9                         | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|     | 10                        | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |
|     | 11                        | WIREDANDPULLUPFIL-TER     |        | Open-drain output with filter and pullup.                         |
|     | 12                        | WIREDANDALT               |        | Open-drain output using alternate control.                        |
|     | 13                        | WIREDANDALTFILTER         |        | Open-drain output using alternate control with filter.            |
|     | 14                        | WIREDANDALTPULLUP         |        | Open-drain output using alternate control with pullup.            |
|     | 15                        | WIREDANDALTPULLUP- FILTER |        | Open-drain output using alternate control with filter and pullup. |

## 24.6.13 GPIO\_PORTC\_MODEH - Mode High

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |       |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-------|---|---|---|
| 0x09C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0 |       |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RW  |       |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     | MODE1 |   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     | MODE0 |   |   |   |

| Bit  | Name     | Reset                   | Access | Description                                                                                                                                                       |
|------|----------|-------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 7:4  | MODE1    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                     |
|      | MODE n   |                         |        |                                                                                                                                                                   |
|      | Value    | Mode                    |        | Description                                                                                                                                                       |
|      | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                            |
|      | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                             |
|      | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                    |
|      | 3        | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.                                                                                                        |
|      | 4        | PUSHPULL                |        | Push-pull output.                                                                                                                                                 |
|      | 5        | PUSHPULLALT             |        | Push-pull using alternate control.                                                                                                                                |
|      | 6        | WIREDOR                 |        | Wired-or output.                                                                                                                                                  |
|      | 7        | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                                                                                                                   |
|      | 8        | WIREDAND                |        | Open-drain output.                                                                                                                                                |
|      | 9        | WIREDANDFILTER          |        | Open-drain output with filter.                                                                                                                                    |
|      | 10       | WIREDANDPULLUP          |        | Open-drain output with pullup.                                                                                                                                    |
|      | 11       | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                                                                                                                         |
|      | 12       | WIREDANDALT             |        | Open-drain output using alternate control.                                                                                                                        |
|      | 13       | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.                                                                                                            |
|      | 14       | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.                                                                                                            |
|      | 15       | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup.                                                                                                 |
| 3:0  | MODE0    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                     |
|      | MODE n   |                         |        |                                                                                                                                                                   |
|      | Value    | Mode                    |        | Description                                                                                                                                                       |
|      | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                            |
|      | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                             |
|      | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                    |

| Bit | Name | Reset                   | Access | Description                                                       |
|-----|------|-------------------------|--------|-------------------------------------------------------------------|
| 3   |      | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |
| 4   |      | PUSHPULL                |        | Push-pull output.                                                 |
| 5   |      | PUSHPULLALT             |        | Push-pull using alternate control.                                |
| 6   |      | WIREDOR                 |        | Wired-or output.                                                  |
| 7   |      | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                   |
| 8   |      | WIREDAND                |        | Open-drain output.                                                |
| 9   |      | WIREDANDFILTER          |        | Open-drain output with filter.                                    |
| 10  |      | WIREDANDPULLUP          |        | Open-drain output with pullup.                                    |
| 11  |      | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                         |
| 12  |      | WIREDANDALT             |        | Open-drain output using alternate control.                        |
| 13  |      | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.            |
| 14  |      | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.            |
| 15  |      | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup. |

#### 24.6.14 GPIO\_PORTC\_DOUT - Data Out

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|----|------|
| 0x0A0  | 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  |      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |    |      |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | RW |      |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    | DOUT |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:0   | DOUT     | 0x0   | RW     | <b>Data output</b><br><br>Data output                                                                                                                                             |

**24.6.15 GPIO\_PORTC\_DIN - Data in**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |     |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|-----|
| 0x0A4  | 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 |     |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |   |     |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | R |     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   | DIN |

| Bit   | Name     | Reset                                                                                                                                                                             | Access | Description       |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------|
| 31:10 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                   |
| 9:0   | DIN      | 0x0                                                                                                                                                                               | R      | <b>Data input</b> |
|       |          |                                                                                                                                                                                   |        | Data input        |

## 24.6.16 GPIO\_PORTD\_CTRL - Port Control

| Offset | Bit Position |           |    |     |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    |        |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|-----------|----|-----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|----|--------|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x0C0  | 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 |  |
| Reset  |              |           |    | 0x0 |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    | 0x0    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access |              |           | RW |     |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    | RW     |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              | DINDISALT |    |     |    |    |    |    |    | SLEWRATEALT | RW |    |    |    |    |    |    |    |    | DINDIS |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 28    | DINDISALT   | 0x0   | RW     | <b>Data In Disable Alt</b><br><br>Data input disable for port pins using alternate modes.                                                                                         |
| 27:23 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 22:20 | SLEWRATEALT | 0x4   | RW     | <b>Slew Rate Alt</b><br><br>Slewrate limit for port pins using alternate modes. Higher values representer faster slewrates.                                                       |
| 19:13 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 12    | DINDIS      | 0x0   | RW     | <b>Data In Disable</b><br><br>Data input disable for port pins not using alternate modes.                                                                                         |
| 11:7  | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 6:4   | SLEWRATE    | 0x4   | RW     | <b>Slew Rate</b><br><br>Slewrate limit for port pins using not alternate modes. Higher values representer faster slewrates.                                                       |
| 3:0   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

## 24.6.17 GPIO\_PORTD\_MODEL - Mode Low

| Offset | Bit Position |    |    |    |       |    |    |    |    |       |    |    |    |    |       |    |    |    |    |       |    |    |   |   |       |   |   |   |   |       |   |   |  |  |
|--------|--------------|----|----|----|-------|----|----|----|----|-------|----|----|----|----|-------|----|----|----|----|-------|----|----|---|---|-------|---|---|---|---|-------|---|---|--|--|
| 0x0C4  | 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 |  |  |
| Reset  |              |    |    |    | 0x0   |    |    |    |    | 0x0   |    |    |    |    | 0x0   |    |    |    |    | 0x0   |    |    |   |   | 0x0   |   |   |   |   |       |   |   |  |  |
| Access |              |    |    |    | RW    |    |    |    |    | RW    |    |    |    |    | RW    |    |    |    |    | RW    |    |    |   |   | RW    |   |   |   |   |       |   |   |  |  |
| Name   |              |    |    |    | MODE5 |    |    |    |    | MODE4 |    |    |    |    | MODE3 |    |    |    |    | MODE2 |    |    |   |   | MODE1 |   |   |   |   | MODE0 |   |   |  |  |

| Bit   | Name     | Reset                   | Access | Description                                                                                                                                                                       |
|-------|----------|-------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved |                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:20 | MODE5    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                                     |
|       | MODE n   |                         |        |                                                                                                                                                                                   |
|       | Value    | Mode                    |        | Description                                                                                                                                                                       |
|       | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                                            |
|       | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                                             |
|       | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                                    |
|       | 3        | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.                                                                                                                        |
|       | 4        | PUSHPULL                |        | Push-pull output.                                                                                                                                                                 |
|       | 5        | PUSHPULLALT             |        | Push-pull using alternate control.                                                                                                                                                |
|       | 6        | WIREDOR                 |        | Wired-or output.                                                                                                                                                                  |
|       | 7        | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                                                                                                                                   |
|       | 8        | WIREDAND                |        | Open-drain output.                                                                                                                                                                |
|       | 9        | WIREDANDFILTER          |        | Open-drain output with filter.                                                                                                                                                    |
|       | 10       | WIREDANDPULLUP          |        | Open-drain output with pullup.                                                                                                                                                    |
|       | 11       | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                                                                                                                                         |
|       | 12       | WIREDANDALT             |        | Open-drain output using alternate control.                                                                                                                                        |
|       | 13       | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.                                                                                                                            |
|       | 14       | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.                                                                                                                            |
|       | 15       | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup.                                                                                                                 |
| 19:16 | MODE4    | 0x0                     | RW     | <b>MODE n</b>                                                                                                                                                                     |
|       | MODE n   |                         |        |                                                                                                                                                                                   |
|       | Value    | Mode                    |        | Description                                                                                                                                                                       |
|       | 0        | DISABLED                |        | Input disabled. Pullup if DOUT is set.                                                                                                                                            |
|       | 1        | INPUT                   |        | Input enabled. Filter if DOUT is set.                                                                                                                                             |
|       | 2        | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                                                                                                                                    |

| Bit   | Name                    | Reset                   | Access | Description                                                       |
|-------|-------------------------|-------------------------|--------|-------------------------------------------------------------------|
| 3     | INPUTPULLFILTER         |                         |        | Input enabled with filter. DOUT determines pull direction.        |
| 4     | PUSHPULL                |                         |        | Push-pull output.                                                 |
| 5     | PUSHPULLALT             |                         |        | Push-pull using alternate control.                                |
| 6     | WIREDOR                 |                         |        | Wired-or output.                                                  |
| 7     | WIREDORPULLDOWN         |                         |        | Wired-or output with pull-down.                                   |
| 8     | WIREDAND                |                         |        | Open-drain output.                                                |
| 9     | WIREDANDFILTER          |                         |        | Open-drain output with filter.                                    |
| 10    | WIREDANDPULLUP          |                         |        | Open-drain output with pullup.                                    |
| 11    | WIREDANDPULLUPFILTER    |                         |        | Open-drain output with filter and pullup.                         |
| 12    | WIREDANDALT             |                         |        | Open-drain output using alternate control.                        |
| 13    | WIREDANDALTFILTER       |                         |        | Open-drain output using alternate control with filter.            |
| 14    | WIREDANDALTPULLUP       |                         |        | Open-drain output using alternate control with pullup.            |
| 15    | WIREDANDALTPULLUPFILTER |                         |        | Open-drain output using alternate control with filter and pullup. |
| 15:12 | MODE3                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |
|       | Value                   | Mode                    |        | Description                                                       |
|       | 0                       | DISABLED                |        | Input disabled. Pullup if DOUT is set.                            |
|       | 1                       | INPUT                   |        | Input enabled. Filter if DOUT is set.                             |
|       | 2                       | INPUTPULL               |        | Input enabled. DOUT determines pull direction.                    |
|       | 3                       | INPUTPULLFILTER         |        | Input enabled with filter. DOUT determines pull direction.        |
|       | 4                       | PUSHPULL                |        | Push-pull output.                                                 |
|       | 5                       | PUSHPULLALT             |        | Push-pull using alternate control.                                |
|       | 6                       | WIREDOR                 |        | Wired-or output.                                                  |
|       | 7                       | WIREDORPULLDOWN         |        | Wired-or output with pull-down.                                   |
|       | 8                       | WIREDAND                |        | Open-drain output.                                                |
|       | 9                       | WIREDANDFILTER          |        | Open-drain output with filter.                                    |
|       | 10                      | WIREDANDPULLUP          |        | Open-drain output with pullup.                                    |
|       | 11                      | WIREDANDPULLUPFILTER    |        | Open-drain output with filter and pullup.                         |
|       | 12                      | WIREDANDALT             |        | Open-drain output using alternate control.                        |
|       | 13                      | WIREDANDALTFILTER       |        | Open-drain output using alternate control with filter.            |
|       | 14                      | WIREDANDALTPULLUP       |        | Open-drain output using alternate control with pullup.            |
|       | 15                      | WIREDANDALTPULLUPFILTER |        | Open-drain output using alternate control with filter and pullup. |
| 11:8  | MODE2                   | 0x0                     | RW     | <b>MODE n</b>                                                     |
|       | MODE n                  |                         |        |                                                                   |

| Bit | Name   | Reset                   | Access | Description   |
|-----|--------|-------------------------|--------|---------------|
|     | Value  | Mode                    |        |               |
|     | 0      | DISABLED                |        |               |
|     | 1      | INPUT                   |        |               |
|     | 2      | INPUTPULL               |        |               |
|     | 3      | INPUTPULLFILTER         |        |               |
|     | 4      | PUSHPULL                |        |               |
|     | 5      | PUSHPULLALT             |        |               |
|     | 6      | WIREDOR                 |        |               |
|     | 7      | WIREDORPULLDOWN         |        |               |
|     | 8      | WIREDAND                |        |               |
|     | 9      | WIREDANDFILTER          |        |               |
|     | 10     | WIREDANDPULLUP          |        |               |
|     | 11     | WIREDANDPULLUPFILTER    |        |               |
|     | 12     | WIREDANDALT             |        |               |
|     | 13     | WIREDANDALTFILTER       |        |               |
|     | 14     | WIREDANDALTPULLUP       |        |               |
|     | 15     | WIREDANDALTPULLUPFILTER |        |               |
| 7:4 | MODE1  | 0x0                     | RW     | <b>MODE n</b> |
|     | MODE n |                         |        |               |
|     | Value  | Mode                    |        |               |
|     | 0      | DISABLED                |        |               |
|     | 1      | INPUT                   |        |               |
|     | 2      | INPUTPULL               |        |               |
|     | 3      | INPUTPULLFILTER         |        |               |
|     | 4      | PUSHPULL                |        |               |
|     | 5      | PUSHPULLALT             |        |               |
|     | 6      | WIREDOR                 |        |               |
|     | 7      | WIREDORPULLDOWN         |        |               |
|     | 8      | WIREDAND                |        |               |
|     | 9      | WIREDANDFILTER          |        |               |
|     | 10     | WIREDANDPULLUP          |        |               |
|     | 11     | WIREDANDPULLUPFILTER    |        |               |
|     | 12     | WIREDANDALT             |        |               |
|     | 13     | WIREDANDALTFILTER       |        |               |

| Bit | Name   | Reset                     | Access | Description                                                       |
|-----|--------|---------------------------|--------|-------------------------------------------------------------------|
| 14  |        | WIREDANDALT PULLUP        |        | Open-drain output using alternate control with pullup.            |
| 15  |        | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |
| 3:0 | MODE0  | 0x0                       | RW     | <b>MODE n</b>                                                     |
|     | MODE n |                           |        |                                                                   |
|     | Value  | Mode                      |        | Description                                                       |
|     | 0      | DISABLED                  |        | Input disabled. Pullup if DOUT is set.                            |
|     | 1      | INPUT                     |        | Input enabled. Filter if DOUT is set.                             |
|     | 2      | INPUTPULL                 |        | Input enabled. DOUT determines pull direction.                    |
|     | 3      | INPUTPULLFILTER           |        | Input enabled with filter. DOUT determines pull direction.        |
|     | 4      | PUSHPULL                  |        | Push-pull output.                                                 |
|     | 5      | PUSHPULLALT               |        | Push-pull using alternate control.                                |
|     | 6      | WIREDOR                   |        | Wired-or output.                                                  |
|     | 7      | WIREDORPULLDOWN           |        | Wired-or output with pull-down.                                   |
|     | 8      | WIREDAND                  |        | Open-drain output.                                                |
|     | 9      | WIREDANDFILTER            |        | Open-drain output with filter.                                    |
|     | 10     | WIREDANDPULLUP            |        | Open-drain output with pullup.                                    |
|     | 11     | WIREDANDPULLUPFIL-TER     |        | Open-drain output with filter and pullup.                         |
|     | 12     | WIREDANDALT               |        | Open-drain output using alternate control.                        |
|     | 13     | WIREDANDALT FILTER        |        | Open-drain output using alternate control with filter.            |
|     | 14     | WIREDANDALT PULLUP        |        | Open-drain output using alternate control with pullup.            |
|     | 15     | WIREDANDALT PULLUP-FILTER |        | Open-drain output using alternate control with filter and pullup. |

**24.6.18 GPIO\_PORTD\_DOUT - Data Out**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| Reset  | 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 |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                                       |
|------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:0  | DOUT        | 0x0   | RW     | <b>Data output</b>                                                                                                                                                                |
|      | Data output |       |        |                                                                                                                                                                                   |

**24.6.19 GPIO\_PORTD\_DIN - Data in**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 0x0D4         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DIN |   |   |   |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:0  | DIN      | 0x0   | R      | <b>Data input</b>                                                                                                                                                                 |
|      |          |       |        | Data input                                                                                                                                                                        |

**24.6.20 GPIO\_LOCK - Lock Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| 0x300         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0xA534  |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W       |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | LOCKKEY |   |   |   |   |   |   |   |

| Bit   | Name     | Reset  | Access | Description                                                                                                                                                                       |
|-------|----------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0  | LOCKKEY  | 0xA534 | W      | <b>Configuration Lock Key</b>                                                                                                                                                     |
|       |          |        |        | Write any other value than the unlock code to lock configuration registers. Write the unlock code to unlock (See text for detailed list of configuration registers.)              |
|       |          |        |        |                                                                                                                                                                                   |
|       | Value    |        | Mode   | Description                                                                                                                                                                       |
|       | 42292    |        | UNLOCK | Unlock code                                                                                                                                                                       |

#### **24.6.21 GPIO\_GPIOLOCKSTATUS - Lock Status**

| Bit                                             | Name     | Reset | Access                 | Description                                                                                                                                                                       |
|-------------------------------------------------|----------|-------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1                                            | Reserved |       |                        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0                                               | LOCK     | 0x0   | R                      | <b>GPIO LOCK status</b>                                                                                                                                                           |
| Indicates current lock status of GPIO registers |          |       |                        |                                                                                                                                                                                   |
| Value                                           | Mode     |       | Description            |                                                                                                                                                                                   |
| 0                                               | UNLOCKED |       | Registers are unlocked |                                                                                                                                                                                   |
| 1                                               | LOCKED   |       | Registers are locked   |                                                                                                                                                                                   |

**24.6.22 GPIO\_ABUSALLOC - A Bus Allocation**

| Offset | Bit Position |    |    |    |       |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |        |    |   |   |        |   |   |   |        |   |   |   |
|--------|--------------|----|----|----|-------|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|--------|----|---|---|--------|---|---|---|--------|---|---|---|
| 0x320  | 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 |
| Reset  |              |    |    |    | 0x0   |    |    |    |    |    |    |    | 0x0   |    |    |    |    |    |    |    | 0x0    |    |   |   |        |   |   |   | 0x0    |   |   |   |
| Access |              |    |    |    | RW    |    |    |    |    |    |    |    | RW    |    |    |    |    |    |    |    | RW     |    |   |   |        |   |   |   | RW     |   |   |   |
| Name   |              |    |    |    | AODD1 |    |    |    |    |    |    |    | AODD0 |    |    |    |    |    |    |    | AEVEN1 |    |   |   | AEVEN0 |   |   |   | AEVEN0 |   |   |   |

| Bit   | Name     | Reset | Access   | Description                                                                                                                                                                       |
|-------|----------|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved |       |          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:24 | AODD1    | 0x0   | RW       | <b>A Bus Odd 1</b><br><br>peripheral allocation to A Bus Odd 1                                                                                                                    |
|       |          | Value | Mode     | Description                                                                                                                                                                       |
|       |          | 0     | TRISTATE | The bus is not allocated                                                                                                                                                          |
|       |          | 1     | ADC0     | The bus is allocated to ADC0                                                                                                                                                      |
|       |          | 2     | ACMP0    | The bus is allocated to ACMP0                                                                                                                                                     |
|       |          | 3     | ACMP1    | The bus is allocated to ACMP1                                                                                                                                                     |
|       |          | 4     | VDAC0CH1 | The bus is allocated to VDAC0 CH1                                                                                                                                                 |
|       |          | 5     | VDAC1CH1 | The bus is allocated to VDAC1 CH1                                                                                                                                                 |
| 23:20 | Reserved |       |          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | AODD0    | 0x0   | RW       | <b>A Bus Odd 0</b><br><br>peripheral allocation to A Bus Odd 0                                                                                                                    |
|       |          | Value | Mode     | Description                                                                                                                                                                       |
|       |          | 0     | TRISTATE | The bus is not allocated                                                                                                                                                          |
|       |          | 1     | ADC0     | The bus is allocated to ADC0                                                                                                                                                      |
|       |          | 2     | ACMP0    | The bus is allocated to ACMP0                                                                                                                                                     |
|       |          | 3     | ACMP1    | The bus is allocated to ACMP1                                                                                                                                                     |
|       |          | 4     | VDAC0CH0 | The bus is allocated to VDAC0 CH0                                                                                                                                                 |
|       |          | 5     | VDAC1CH0 | The bus is allocated to VDAC1 CH0                                                                                                                                                 |
| 15:12 | Reserved |       |          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:8  | AEVEN1   | 0x0   | RW       | <b>A Bus Even 1</b><br><br>peripheral allocation to A Bus Even 1                                                                                                                  |
|       |          | Value | Mode     | Description                                                                                                                                                                       |
|       |          | 0     | TRISTATE | The bus is not allocated                                                                                                                                                          |

| Bit   | Name     | Reset                             | Access | Description                                                                                                                                                                       |
|-------|----------|-----------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | ADC0     |                                   |        | The bus is allocated to ADC0                                                                                                                                                      |
| 2     | ACMP0    |                                   |        | The bus is allocated to ACMP0                                                                                                                                                     |
| 3     | ACMP1    |                                   |        | The bus is allocated to ACMP1                                                                                                                                                     |
| 4     | VDAC0CH1 |                                   |        | The bus is allocated to VDAC0 CH1                                                                                                                                                 |
| 5     | VDAC1CH1 |                                   |        | The bus is allocated to VDAC1 CH1                                                                                                                                                 |
| 7:4   | Reserved |                                   |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | AEVEN0   | 0x0                               | RW     | <b>A Bus Even 0</b><br><br>peripheral allocation to A Bus Even 0                                                                                                                  |
| Value | Mode     | Description                       |        |                                                                                                                                                                                   |
| 0     | TRISTATE | The bus is not allocated          |        |                                                                                                                                                                                   |
| 1     | ADC0     | The bus is allocated to ADC0      |        |                                                                                                                                                                                   |
| 2     | ACMP0    | The bus is allocated to ACMP0     |        |                                                                                                                                                                                   |
| 3     | ACMP1    | The bus is allocated to ACMP1     |        |                                                                                                                                                                                   |
| 4     | VDAC0CH0 | The bus is allocated to VDAC0 CH0 |        |                                                                                                                                                                                   |
| 5     | VDAC1CH0 | The bus is allocated to VDAC1 CH0 |        |                                                                                                                                                                                   |

**24.6.23 GPIO\_BBUSALLOC - B Bus Allocation**

| Offset | Bit Position |    |    |    |       |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |        |    |   |   |   |   |   |   |        |   |   |   |
|--------|--------------|----|----|----|-------|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|--------|----|---|---|---|---|---|---|--------|---|---|---|
| 0x324  | 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 |
| Reset  |              |    |    |    | 0x0   |    |    |    |    |    |    |    | 0x0   |    |    |    |    |    |    |    | 0x0    |    |   |   |   |   |   |   | 0x0    |   |   |   |
| Access |              |    |    |    | RW    |    |    |    |    |    |    |    | RW    |    |    |    |    |    |    |    | RW     |    |   |   |   |   |   |   | RW     |   |   |   |
| Name   |              |    |    |    | BODD1 |    |    |    |    |    |    |    | BODDO |    |    |    |    |    |    |    | BEVEN1 |    |   |   |   |   |   |   | BEVEN0 |   |   |   |

| Bit   | Name     | Reset | Access   | Description                                                                                                                                                                       |
|-------|----------|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved |       |          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:24 | BODD1    | 0x0   | RW       | <b>B Bus Odd 1</b><br><br>peripheral allocation to B Bus Odd 1                                                                                                                    |
|       |          | Value | Mode     | Description                                                                                                                                                                       |
|       |          | 0     | TRISTATE | The bus is not allocated                                                                                                                                                          |
|       |          | 1     | ADC0     | The bus is allocated to ADC0                                                                                                                                                      |
|       |          | 2     | ACMP0    | The bus is allocated to ACMP0                                                                                                                                                     |
|       |          | 3     | ACMP1    | The bus is allocated to ACMP1                                                                                                                                                     |
|       |          | 4     | VDAC0CH1 | The bus is allocated to VDAC0 CH1                                                                                                                                                 |
|       |          | 5     | VDAC1CH1 | The bus is allocated to VDAC1 CH1                                                                                                                                                 |
| 23:20 | Reserved |       |          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | BODDO    | 0x0   | RW       | <b>B Bus Odd 0</b><br><br>peripheral allocation to B Bus Odd 0                                                                                                                    |
|       |          | Value | Mode     | Description                                                                                                                                                                       |
|       |          | 0     | TRISTATE | The bus is not allocated                                                                                                                                                          |
|       |          | 1     | ADC0     | The bus is allocated to ADC0                                                                                                                                                      |
|       |          | 2     | ACMP0    | The bus is allocated to ACMP0                                                                                                                                                     |
|       |          | 3     | ACMP1    | The bus is allocated to ACMP1                                                                                                                                                     |
|       |          | 4     | VDAC0CH0 | The bus is allocated to VDAC0 CH0                                                                                                                                                 |
|       |          | 5     | VDAC1CH0 | The bus is allocated to VDAC1 CH0                                                                                                                                                 |
| 15:12 | Reserved |       |          | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:8  | BEVEN1   | 0x0   | RW       | <b>B Bus Even 1</b><br><br>peripheral allocation to B Bus Even 1                                                                                                                  |
|       |          | Value | Mode     | Description                                                                                                                                                                       |
|       |          | 0     | TRISTATE | The bus is not allocated                                                                                                                                                          |

| Bit   | Name     | Reset                             | Access | Description                                                                                                                                                                       |
|-------|----------|-----------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | ADC0     |                                   |        | The bus is allocated to ADC0                                                                                                                                                      |
| 2     | ACMP0    |                                   |        | The bus is allocated to ACMP0                                                                                                                                                     |
| 3     | ACMP1    |                                   |        | The bus is allocated to ACMP1                                                                                                                                                     |
| 4     | VDAC0CH1 |                                   |        | The bus is allocated to VDAC0 CH1                                                                                                                                                 |
| 5     | VDAC1CH1 |                                   |        | The bus is allocated to VDAC1 CH1                                                                                                                                                 |
| 7:4   | Reserved |                                   |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | BEVEN0   | 0x0                               | RW     | <b>B Bus Even 0</b><br><br>peripheral allocation to B Bus Even 0                                                                                                                  |
| Value | Mode     | Description                       |        |                                                                                                                                                                                   |
| 0     | TRISTATE | The bus is not allocated          |        |                                                                                                                                                                                   |
| 1     | ADC0     | The bus is allocated to ADC0      |        |                                                                                                                                                                                   |
| 2     | ACMP0    | The bus is allocated to ACMP0     |        |                                                                                                                                                                                   |
| 3     | ACMP1    | The bus is allocated to ACMP1     |        |                                                                                                                                                                                   |
| 4     | VDAC0CH0 | The bus is allocated to VDAC0 CH0 |        |                                                                                                                                                                                   |
| 5     | VDAC1CH0 | The bus is allocated to VDAC1 CH0 |        |                                                                                                                                                                                   |

**24.6.24 GPIO\_CDBUSALLOC - CD Bus Allocation**

| Offset        | Bit Position |    |    |    |    |    |        |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |         |    |   |   |   |   |   |   |   |   |         |    |
|---------------|--------------|----|----|----|----|----|--------|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|----|---------|----|---|---|---|---|---|---|---|---|---------|----|
| 0x328         | 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 |         |    |
| <b>Reset</b>  |              |    |    |    |    |    | 0x0    |    |    |    |    |    |    | 0x0    |    |    |    |    |    |    |    |    | 0x0     |    |   |   |   |   |   |   |   |   |         |    |
| <b>Access</b> |              |    |    |    |    |    | RW     |    |    |    |    |    |    | RW     |    |    |    |    |    |    |    |    |         | RW |   |   |   |   |   |   |   |   |         |    |
| <b>Name</b>   |              |    |    |    |    |    | CDODD1 |    |    |    |    |    |    | CDODD0 |    |    |    |    |    |    |    |    | CDEVEN1 |    |   |   |   |   |   |   |   |   | CDEVENO | RW |

| Bit   | Name                                   | Reset    | Access | Description                                                                                                                                                                       |
|-------|----------------------------------------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | <i>Reserved</i>                        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:24 | CDODD1                                 | 0x0      | RW     | <b>CD Bus Odd 1</b>                                                                                                                                                               |
|       | peripheral allocation to CD Bus Odd 1  |          |        |                                                                                                                                                                                   |
|       | Value                                  | Mode     |        | Description                                                                                                                                                                       |
|       | 0                                      | TRISTATE |        | The bus is not allocated                                                                                                                                                          |
|       | 1                                      | ADC0     |        | The bus is allocated to ADC0                                                                                                                                                      |
|       | 2                                      | ACMP0    |        | The bus is allocated to ACMP0                                                                                                                                                     |
|       | 3                                      | ACMP1    |        | The bus is allocated to ACMP1                                                                                                                                                     |
|       | 4                                      | VDAC0CH1 |        | The bus is allocated to VDAC0 CH1                                                                                                                                                 |
|       | 5                                      | VDAC1CH1 |        | The bus is allocated to VDAC1 CH1                                                                                                                                                 |
| 23:20 | <i>Reserved</i>                        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | CDODD0                                 | 0x0      | RW     | <b>CD Bus Odd 0</b>                                                                                                                                                               |
|       | peripheral allocation to CD Bus Odd 0  |          |        |                                                                                                                                                                                   |
|       | Value                                  | Mode     |        | Description                                                                                                                                                                       |
|       | 0                                      | TRISTATE |        | The bus is not allocated                                                                                                                                                          |
|       | 1                                      | ADC0     |        | The bus is allocated to ADC0                                                                                                                                                      |
|       | 2                                      | ACMP0    |        | The bus is allocated to ACMP0                                                                                                                                                     |
|       | 3                                      | ACMP1    |        | The bus is allocated to ACMP1                                                                                                                                                     |
|       | 4                                      | VDAC0CH0 |        | The bus is allocated to VDAC0 CH0                                                                                                                                                 |
|       | 5                                      | VDAC1CH0 |        | The bus is allocated to VDAC1 CH0                                                                                                                                                 |
| 15:12 | <i>Reserved</i>                        |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:8  | CDEVEN1                                | 0x0      | RW     | <b>CD Bus Even 1</b>                                                                                                                                                              |
|       | peripheral allocation to CD Bus Even 1 |          |        |                                                                                                                                                                                   |
|       | Value                                  | Mode     |        | Description                                                                                                                                                                       |
|       | 0                                      | TRISTATE |        | The bus is not allocated                                                                                                                                                          |

| Bit   | Name     | Reset                             | Access | Description                                                                                                                                                                       |
|-------|----------|-----------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | ADC0     |                                   |        | The bus is allocated to ADC0                                                                                                                                                      |
| 2     | ACMP0    |                                   |        | The bus is allocated to ACMP0                                                                                                                                                     |
| 3     | ACMP1    |                                   |        | The bus is allocated to ACMP1                                                                                                                                                     |
| 4     | VDAC0CH1 |                                   |        | The bus is allocated to VDAC0 CH1                                                                                                                                                 |
| 5     | VDAC1CH1 |                                   |        | The bus is allocated to VDAC1 CH1                                                                                                                                                 |
| 7:4   | Reserved |                                   |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 3:0   | CDEVEN0  | 0x0                               | RW     | <b>CD Bus Even 0</b><br><br>peripheral allocation to CD Bus Even 0                                                                                                                |
| Value | Mode     | Description                       |        |                                                                                                                                                                                   |
| 0     | TRISTATE | The bus is not allocated          |        |                                                                                                                                                                                   |
| 1     | ADC0     | The bus is allocated to ADC0      |        |                                                                                                                                                                                   |
| 2     | ACMP0    | The bus is allocated to ACMP0     |        |                                                                                                                                                                                   |
| 3     | ACMP1    | The bus is allocated to ACMP1     |        |                                                                                                                                                                                   |
| 4     | VDAC0CH0 | The bus is allocated to VDAC0 CH0 |        |                                                                                                                                                                                   |
| 5     | VDAC1CH0 | The bus is allocated to VDAC1 CH0 |        |                                                                                                                                                                                   |

**24.6.25 GPIO\_EXTIPSELL - External Interrupt Port Select Low**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x400  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name                                         | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 29:28 | EXTIPSEL7                                    | 0x0   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 7 (EXTI7) |       |        |                                                                                                                                                                                   |
|       | Value                                        | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                            | PORTA |        | Port A group selected                                                                                                                                                             |
|       | 1                                            | PORTB |        | Port B group selected                                                                                                                                                             |
|       | 2                                            | PORTC |        | Port C group selected                                                                                                                                                             |
|       | 3                                            | PORTD |        | Port D group selected                                                                                                                                                             |
| 27:26 | Reserved                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 25:24 | EXTIPSEL6                                    | 0x0   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 6 (EXTI6) |       |        |                                                                                                                                                                                   |
|       | Value                                        | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                            | PORTA |        | Port A group selected                                                                                                                                                             |
|       | 1                                            | PORTB |        | Port B group selected                                                                                                                                                             |
|       | 2                                            | PORTC |        | Port C group selected                                                                                                                                                             |
|       | 3                                            | PORTD |        | Port D group selected                                                                                                                                                             |
| 23:22 | Reserved                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 21:20 | EXTIPSEL5                                    | 0x0   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 5 (EXTI5) |       |        |                                                                                                                                                                                   |
|       | Value                                        | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                            | PORTA |        | Port A group selected                                                                                                                                                             |
|       | 1                                            | PORTB |        | Port B group selected                                                                                                                                                             |
|       | 2                                            | PORTC |        | Port C group selected                                                                                                                                                             |
|       | 3                                            | PORTD |        | Port D group selected                                                                                                                                                             |

| Bit   | Name                                         | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:18 | Reserved                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17:16 | EXTIPSEL4                                    | 0x0   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 4 (EXTI4) |       |        |                                                                                                                                                                                   |
|       | Value                                        | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                            | PORTA |        | Port A group selected                                                                                                                                                             |
|       | 1                                            | PORTB |        | Port B group selected                                                                                                                                                             |
|       | 2                                            | PORTC |        | Port C group selected                                                                                                                                                             |
|       | 3                                            | PORTD |        | Port D group selected                                                                                                                                                             |
| 15:14 | Reserved                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13:12 | EXTIPSEL3                                    | 0x0   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 3 (EXTI3) |       |        |                                                                                                                                                                                   |
|       | Value                                        | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                            | PORTA |        | Port A group selected                                                                                                                                                             |
|       | 1                                            | PORTB |        | Port B group selected                                                                                                                                                             |
|       | 2                                            | PORTC |        | Port C group selected                                                                                                                                                             |
|       | 3                                            | PORTD |        | Port D group selected                                                                                                                                                             |
| 11:10 | Reserved                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | EXTIPSEL2                                    | 0x0   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 2 (EXTI2) |       |        |                                                                                                                                                                                   |
|       | Value                                        | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                            | PORTA |        | Port A group selected                                                                                                                                                             |
|       | 1                                            | PORTB |        | Port B group selected                                                                                                                                                             |
|       | 2                                            | PORTC |        | Port C group selected                                                                                                                                                             |
|       | 3                                            | PORTD |        | Port D group selected                                                                                                                                                             |
| 7:6   | Reserved                                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:4   | EXTIPSEL1                                    | 0x0   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 1 (EXTI1) |       |        |                                                                                                                                                                                   |
|       | Value                                        | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                            | PORTA |        | Port A group selected                                                                                                                                                             |
|       | 1                                            | PORTB |        | Port B group selected                                                                                                                                                             |
|       | 2                                            | PORTC |        | Port C group selected                                                                                                                                                             |
|       | 3                                            | PORTD |        | Port D group selected                                                                                                                                                             |

| Bit   | Name                                         | Reset                 | Access | Description                                                                                                                                                                       |
|-------|----------------------------------------------|-----------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2   | <i>Reserved</i>                              |                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | EXTIPSEL0                                    | 0x0                   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
|       | Port select for external interrupt 0 (EXTI0) |                       |        |                                                                                                                                                                                   |
| Value | Mode                                         | Description           |        |                                                                                                                                                                                   |
| 0     | PORTA                                        | Port A group selected |        |                                                                                                                                                                                   |
| 1     | PORTB                                        | Port B group selected |        |                                                                                                                                                                                   |
| 2     | PORTC                                        | Port C group selected |        |                                                                                                                                                                                   |
| 3     | PORTD                                        | Port D group selected |        |                                                                                                                                                                                   |

**24.6.26 GPIO\_EXTIPSELH - External Interrupt Port Select High**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x404  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name                                   | Reset                                                                                                                                                                      | Access                | Description                           |
|-------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------------------------|
| 31:14 | Reserved                               | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |                       |                                       |
| 13:12 | EXTIPSEL3                              | 0x0                                                                                                                                                                        | RW                    | <b>External Interrupt Port Select</b> |
|       | Port select for external interrupt 3+8 |                                                                                                                                                                            |                       |                                       |
|       | Value                                  | Mode                                                                                                                                                                       | Description           |                                       |
|       | 0                                      | PORTA                                                                                                                                                                      | Port A group selected |                                       |
|       | 1                                      | PORTB                                                                                                                                                                      | Port B group selected |                                       |
|       | 2                                      | PORTC                                                                                                                                                                      | Port C group selected |                                       |
|       | 3                                      | PORTD                                                                                                                                                                      | Port D group selected |                                       |
| 11:10 | Reserved                               | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |                       |                                       |
| 9:8   | EXTIPSEL2                              | 0x0                                                                                                                                                                        | RW                    | <b>External Interrupt Port Select</b> |
|       | Port select for external interrupt 2+8 |                                                                                                                                                                            |                       |                                       |
|       | Value                                  | Mode                                                                                                                                                                       | Description           |                                       |
|       | 0                                      | PORTA                                                                                                                                                                      | Port A group selected |                                       |
|       | 1                                      | PORTB                                                                                                                                                                      | Port B group selected |                                       |
|       | 2                                      | PORTC                                                                                                                                                                      | Port C group selected |                                       |
|       | 3                                      | PORTD                                                                                                                                                                      | Port D group selected |                                       |
| 7:6   | Reserved                               | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |                       |                                       |
| 5:4   | EXTIPSEL1                              | 0x0                                                                                                                                                                        | RW                    | <b>External Interrupt Port Select</b> |
|       | Port select for external interrupt 1+8 |                                                                                                                                                                            |                       |                                       |
|       | Value                                  | Mode                                                                                                                                                                       | Description           |                                       |
|       | 0                                      | PORTA                                                                                                                                                                      | Port A group selected |                                       |
|       | 1                                      | PORTB                                                                                                                                                                      | Port B group selected |                                       |
|       | 2                                      | PORTC                                                                                                                                                                      | Port C group selected |                                       |
|       | 3                                      | PORTD                                                                                                                                                                      | Port D group selected |                                       |

| Bit                                    | Name            | Reset                 | Access | Description                                                                                                                                                                       |
|----------------------------------------|-----------------|-----------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2                                    | <i>Reserved</i> |                       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0                                    | EXTIPSEL0       | 0x0                   | RW     | <b>External Interrupt Port Select</b>                                                                                                                                             |
| Port select for external interrupt 0+8 |                 |                       |        |                                                                                                                                                                                   |
| <hr/>                                  |                 |                       |        |                                                                                                                                                                                   |
| Value                                  | Mode            | Description           |        |                                                                                                                                                                                   |
| 0                                      | PORTA           | Port A group selected |        |                                                                                                                                                                                   |
| 1                                      | PORTB           | Port B group selected |        |                                                                                                                                                                                   |
| 2                                      | PORTC           | Port C group selected |        |                                                                                                                                                                                   |
| 3                                      | PORTD           | Port D group selected |        |                                                                                                                                                                                   |
| <hr/>                                  |                 |                       |        |                                                                                                                                                                                   |

## 24.6.27 GPIO\_EXTIPINSEL - External Interrupt Pin Select Low

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x408  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 29:28 | EXTIPINSEL7 | 0x0   | RW     | <b>External Interrupt Pin select</b><br><br>OFFSET select for External Interrupt 7 (EXTI7)                                                                                        |
|       | Value       | Mode  |        | Description                                                                                                                                                                       |
|       | 0           | PIN0  |        | OFFSET=0                                                                                                                                                                          |
|       | 1           | PIN1  |        | OFFSET=1                                                                                                                                                                          |
|       | 2           | PIN2  |        | OFFSET=2                                                                                                                                                                          |
|       | 3           | PIN3  |        | OFFSET=3                                                                                                                                                                          |
| 27:26 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 25:24 | EXTIPINSEL6 | 0x0   | RW     | <b>External Interrupt Pin select</b><br><br>OFFSET select for External Interrupt 6 (EXTI6)                                                                                        |
|       | Value       | Mode  |        | Description                                                                                                                                                                       |
|       | 0           | PIN0  |        | OFFSET=0                                                                                                                                                                          |
|       | 1           | PIN1  |        | OFFSET=1                                                                                                                                                                          |
|       | 2           | PIN2  |        | OFFSET=2                                                                                                                                                                          |
|       | 3           | PIN3  |        | OFFSET=3                                                                                                                                                                          |
| 23:22 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 21:20 | EXTIPINSEL5 | 0x0   | RW     | <b>External Interrupt Pin select</b><br><br>OFFSET select for External Interrupt 5 (EXTI5)                                                                                        |
|       | Value       | Mode  |        | Description                                                                                                                                                                       |
|       | 0           | PIN0  |        | OFFSET=0                                                                                                                                                                          |
|       | 1           | PIN1  |        | OFFSET=1                                                                                                                                                                          |
|       | 2           | PIN2  |        | OFFSET=2                                                                                                                                                                          |
|       | 3           | PIN3  |        | OFFSET=3                                                                                                                                                                          |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:18 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 17:16 | EXTIPINSEL4 | 0x0   | RW     | <b>External Interrupt Pin select</b><br>OFFSET select for External Interrupt 4 (EXTI4)                                                                                            |
|       | Value       | Mode  |        | Description                                                                                                                                                                       |
|       | 0           | PIN0  |        | OFFSET=0                                                                                                                                                                          |
|       | 1           | PIN1  |        | OFFSET=1                                                                                                                                                                          |
|       | 2           | PIN2  |        | OFFSET=2                                                                                                                                                                          |
|       | 3           | PIN3  |        | OFFSET=3                                                                                                                                                                          |
| 15:14 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13:12 | EXTIPINSEL3 | 0x0   | RW     | <b>External Interrupt Pin select</b><br>OFFSET select for External Interrupt 3 (EXTI3)                                                                                            |
|       | Value       | Mode  |        | Description                                                                                                                                                                       |
|       | 0           | PIN0  |        | OFFSET=0                                                                                                                                                                          |
|       | 1           | PIN1  |        | OFFSET=1                                                                                                                                                                          |
|       | 2           | PIN2  |        | OFFSET=2                                                                                                                                                                          |
|       | 3           | PIN3  |        | OFFSET=3                                                                                                                                                                          |
| 11:10 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | EXTIPINSEL2 | 0x0   | RW     | <b>External Interrupt Pin select</b><br>OFFSET select for External Interrupt 2 (EXTI2)                                                                                            |
|       | Value       | Mode  |        | Description                                                                                                                                                                       |
|       | 0           | PIN0  |        | OFFSET=0                                                                                                                                                                          |
|       | 1           | PIN1  |        | OFFSET=1                                                                                                                                                                          |
|       | 2           | PIN2  |        | OFFSET=2                                                                                                                                                                          |
|       | 3           | PIN3  |        | OFFSET=3                                                                                                                                                                          |
| 7:6   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:4   | EXTIPINSEL1 | 0x0   | RW     | <b>External Interrupt Pin select</b><br>OFFSET select for External Interrupt 1 (EXTI1)                                                                                            |
|       | Value       | Mode  |        | Description                                                                                                                                                                       |
|       | 0           | PIN0  |        | OFFSET=0                                                                                                                                                                          |
|       | 1           | PIN1  |        | OFFSET=1                                                                                                                                                                          |
|       | 2           | PIN2  |        | OFFSET=2                                                                                                                                                                          |
|       | 3           | PIN3  |        | OFFSET=3                                                                                                                                                                          |

| Bit | Name                                           | Reset | Access      | Description                                                                                                                                                                       |
|-----|------------------------------------------------|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2 | <i>Reserved</i>                                |       |             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0 | EXTIPINSEL0                                    | 0x0   | RW          | <b>External Interrupt Pin select</b>                                                                                                                                              |
|     | OFFSET select for External Interrupt 0 (EXTI0) |       |             |                                                                                                                                                                                   |
|     | Value                                          | Mode  | Description |                                                                                                                                                                                   |
|     | 0                                              | PIN0  | OFFSET=0    |                                                                                                                                                                                   |
|     | 1                                              | PIN1  | OFFSET=1    |                                                                                                                                                                                   |
|     | 2                                              | PIN2  | OFFSET=2    |                                                                                                                                                                                   |
|     | 3                                              | PIN3  | OFFSET=3    |                                                                                                                                                                                   |

## 24.6.28 GPIO\_EXTIPINSELH - External Interrupt Pin Select High

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x40C  | 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 |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EXTIPINSEL3 | RW |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit   | Name                                                   | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | Reserved                                               |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 13:12 | EXTIPINSEL3                                            | 0x0   | RW     | <b>External Interrupt Pin select</b>                                                                                                                                              |
|       | OFFSET select for External Interrupt {b+8} (EXTI{b+8}) |       |        |                                                                                                                                                                                   |
|       | Value                                                  | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                                      | PIN8  |        | OFFSET=8                                                                                                                                                                          |
|       | 1                                                      | PIN9  |        | OFFSET=9                                                                                                                                                                          |
|       | 2                                                      | PIN10 |        | OFFSET=10                                                                                                                                                                         |
|       | 3                                                      | PIN11 |        | OFFSET=11                                                                                                                                                                         |
| 11:10 | Reserved                                               |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:8   | EXTIPINSEL2                                            | 0x0   | RW     | <b>External Interrupt Pin select</b>                                                                                                                                              |
|       | OFFSET select for External Interrupt {b+8} (EXTI{b+8}) |       |        |                                                                                                                                                                                   |
|       | Value                                                  | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                                      | PIN8  |        | OFFSET=8                                                                                                                                                                          |
|       | 1                                                      | PIN9  |        | OFFSET=9                                                                                                                                                                          |
|       | 2                                                      | PIN10 |        | OFFSET=10                                                                                                                                                                         |
|       | 3                                                      | PIN11 |        | OFFSET=11                                                                                                                                                                         |
| 7:6   | Reserved                                               |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5:4   | EXTIPINSEL1                                            | 0x0   | RW     | <b>External Interrupt Pin select</b>                                                                                                                                              |
|       | OFFSET select for External Interrupt {b+8} (EXTI{b+8}) |       |        |                                                                                                                                                                                   |
|       | Value                                                  | Mode  |        | Description                                                                                                                                                                       |
|       | 0                                                      | PIN8  |        | OFFSET=8                                                                                                                                                                          |
|       | 1                                                      | PIN9  |        | OFFSET=9                                                                                                                                                                          |
|       | 2                                                      | PIN10 |        | OFFSET=10                                                                                                                                                                         |
|       | 3                                                      | PIN11 |        | OFFSET=11                                                                                                                                                                         |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | EXTIPINSEL0 | 0x0   | RW     | <b>External Interrupt Pin select</b>                                                                                                                                              |
|       |             |       |        | OFFSET select for External Interrupt {b+8} (EXTI{b+8})                                                                                                                            |
| Value | Mode        |       |        | Description                                                                                                                                                                       |
| 0     | PIN8        |       |        | OFFSET=8                                                                                                                                                                          |
| 1     | PIN9        |       |        | OFFSET=9                                                                                                                                                                          |
| 2     | PIN10       |       |        | OFFSET=10                                                                                                                                                                         |
| 3     | PIN11       |       |        | OFFSET=11                                                                                                                                                                         |

#### 24.6.29 GPIO\_EXTIRISE - External Interrupt Rising Edge Trigger

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:0  | EXTIRISE | 0x0   | RW     | <b>EXT Int Rise</b><br>External Interrupt n Rising Edge Trigger Enable                                                                                                            |

**24.6.30 GPIO\_EXTIFALL - External Interrupt Falling Edge Trigger**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |    |          |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|----|----------|
| 0x414         | 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   |    |          |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0 |    |          |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     | RW |          |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |    | EXTIFALL |

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | <b>Reserved</b> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:0  | <b>EXTIFALL</b> | 0x0   | RW     | <b>EXT Int FALL</b><br><br>External Interrupt n Falling Edge Trigger Enable                                                                                                       |

## 24.6.31 GPIO\_IF - Interrupt Flag

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x420  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name   | EM4WU        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:16 | EM4WU    | 0x0   | RW     | <b>EM4 wake up</b>                                                                                                                                                                |
| 15:12 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11    | EXTIF11  | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 10    | EXTIF10  | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 9     | EXTIF9   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 8     | EXTIF8   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 7     | EXTIF7   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 6     | EXTIF6   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 5     | EXTIF5   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 4     | EXTIF4   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 3     | EXTIF3   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 2     | EXTIF2   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 1     | EXTIF1   | 0x0   | RW     | <b>External Pin Flag</b><br>External Pin interrupt flag                                                                                                                           |
| 0     | EXTIF0   | 0x0   | RW     | <b>External Pin Flag</b>                                                                                                                                                          |

| Bit | Name                        | Reset | Access | Description |
|-----|-----------------------------|-------|--------|-------------|
|     | External Pin interrupt flag |       |        |             |

**24.6.32 GPIO\_IEN - Interrupt Enable**

| Offset | Bit Position                                                                                                                                                                      |            |           |           |           |           |           |           |           |           |           |           |          |          |         |         |         |         |         |         |         |         |         |         |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| Reset  | 31                                                                                                                                                                                | 30         | 29        | 28        | 27        | 26        | 25        | 24        | 23        | 22        | 21        | 20        | 19       | 18       | 17      | 16      | 15      | 14      | 13      | 12      |         |         |         |         |
| Access | RW                                                                                                                                                                                | RW         | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW        | RW       | RW       | RW      | RW      | RW      | RW      | RW      | RW      |         |         |         |         |
| Name   | EM4WUIEN11                                                                                                                                                                        | EM4WUIEN10 | EM4WUIEN9 | EM4WUIEN8 | EM4WUIEN7 | EM4WUIEN6 | EM4WUIEN5 | EM4WUIEN4 | EM4WUIEN3 | EM4WUIEN2 | EM4WUIEN1 | EM4WUIEN0 | EXTIEN11 | EXTIEN10 | EXTIEN9 | EXTIEN8 | EXTIEN7 | EXTIEN6 | EXTIEN5 | EXTIEN4 | EXTIEN3 | EXTIEN2 | EXTIEN1 | EXTIEN0 |
| 31:28  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |            |           |           |           |           |           |           |           |           |           |           |          |          |         |         |         |         |         |         |         |         |         |         |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                                       |
|-------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27    | EM4WUIEN11 | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 26    | EM4WUIEN10 | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 25    | EM4WUIEN9  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 24    | EM4WUIEN8  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 23    | EM4WUIEN7  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 22    | EM4WUIEN6  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 21    | EM4WUIEN5  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 20    | EM4WUIEN4  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 19    | EM4WUIEN3  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 18    | EM4WUIEN2  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 17    | EM4WUIEN1  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 16    | EM4WUIEN0  | 0x0   | RW     | <b>EM4 Wake Up Interrupt En</b><br>EM4 wakeup interrupt enable                                                                                                                    |
| 15:12 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

| Bit | Name     | Reset | Access | Description                                                 |
|-----|----------|-------|--------|-------------------------------------------------------------|
| 11  | EXTIEN11 | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 10  | EXTIEN10 | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 9   | EXTIEN9  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 8   | EXTIEN8  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 7   | EXTIEN7  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 6   | EXTIEN6  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 5   | EXTIEN5  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 4   | EXTIEN4  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 3   | EXTIEN3  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 2   | EXTIEN2  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 1   | EXTIEN1  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |
| 0   | EXTIEN0  | 0x0   | RW     | <b>External Pin Enable</b><br>External Pin interrupt enable |

**24.6.33 GPIO\_EM4WUEN - EM4 Wakeup Enable**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x42C  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | EM4WUEN      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:16 | EM4WUEN  | 0x0   | RW     | <b>EM4 wake up enable</b><br><br>Write 1 to enable EM4 wake up request, write 0 to disable EM4 wake up request                                                                    |
| 15:0  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**24.6.34 GPIO\_EM4WUPOL - EM4 Wakeup Polarity**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0x430  | 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 |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Name   | EM4WUPOL     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 27:16 | EM4WUPOL | 0x0   | RW     | <b>EM4 Wake-Up Polarity</b><br><br>EM4 Wakeup Polarity                                                                                                                            |
| 15:0  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |

**24.6.35 GPIO\_DBGROUTEPEN - Debugger Route Pin Enable**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x440         | 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 |  |  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit  | Name        | Reset | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-------------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                                                                                                       |
| 3    | TDIPEN      | 0x1   | RW     | <b>JTAG Test Debug Input Pin Enable</b><br><br>Enable JTAG TDI connection to pin.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2    | TDOPEN      | 0x1   | RW     | <b>JTAG Test Debug Output Pin Enable</b><br><br>Enable JTAG TDO connection to pin.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1    | SWDIOTMSPEN | 0x1   | RW     | <b>Route Location 0</b><br><br>Enable Serial Wire Data and JTAG Test Mode Select connection to pin. <b>WARNING:</b> When the pin is disabled, the device can no longer be accessed by a debugger. A reset will set the pin back to a default state as enabled. If you disable this pin, make sure you have at least a 3 second timeout at the start of your program code before you disable the pin. This way, the debugger will have time to halt the device after a reset before the pin is disabled. |
| 0    | SWCLKTCKPEN | 0x1   | RW     | <b>Route Pin Enable</b><br><br>Enable Serial Wire and JTAG CLock connection to pin. <b>WARNING:</b> When the pin is disabled, the device can no longer be accessed by a debugger. A reset will set the pin back to a default state as enabled. If you disable this pin, make sure you have at least a 3 second timeout at the start of your program code before you disable the pin. This way, the debugger will have time to halt the device after a reset before the pin is disabled.                 |

#### 24.6.36 GPIO TRACEROUTEPEN - Trace Route Pin Enable

| Bit  | Name                                 | Reset | Access | Description                                                                                                                                                                       |
|------|--------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved                             |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | TRACEDATA3PEN                        | 0x0   | RW     | <b>Trace Data3 Pin Enable</b>                                                                                                                                                     |
|      | Trace Data3 Pin Enable               |       |        |                                                                                                                                                                                   |
| 4    | TRACEDATA2PEN                        | 0x0   | RW     | <b>Trace Data2 Pin Enable</b>                                                                                                                                                     |
|      | Trace Data2 Pin Enable               |       |        |                                                                                                                                                                                   |
| 3    | TRACEDATA1PEN                        | 0x0   | RW     | <b>Trace Data1 Pin Enable</b>                                                                                                                                                     |
|      | Trace Data1 Pin Enable               |       |        |                                                                                                                                                                                   |
| 2    | TRACEDATA0PEN                        | 0x0   | RW     | <b>Trace Data0 Pin Enable</b>                                                                                                                                                     |
|      | Trace Data0 Pin Enable               |       |        |                                                                                                                                                                                   |
| 1    | TRACECLKPEN                          | 0x0   | RW     | <b>Trace Clk Pin Enable</b>                                                                                                                                                       |
|      | Trace Clk Pin Enable                 |       |        |                                                                                                                                                                                   |
| 0    | SWVPEN                               | 0x0   | RW     | <b>Serial Wire Viewer Output Pin Enable</b>                                                                                                                                       |
|      | Serial Wire Viewer Output Pin Enable |       |        |                                                                                                                                                                                   |

#### 24.6.37 GPIO\_ACMP0\_ROUTEEN - ACMP0 Pin Enable

| Bit  | Name       | Reset | Access | Description                                                                                                                                                                       |
|------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | ACMPOUTPEN | 0x0   | RW     | <b>ACMPOUT pin enable control bit</b><br>ACMPOUT pin enable control bit                                                                                                           |

#### 24.6.38 GPIO\_ACMP0\_ACMPOUTROUTE - ACMPOUT Port/Pin Select

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ACMPOUT pin select register</b>                                                                                                                                                |
|       | ACMPOUT pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ACMPOUT port select register</b>                                                                                                                                               |
|       | ACMPOUT port select register |       |        |                                                                                                                                                                                   |

#### 24.6.39 GPIO\_ACMP1\_ROUTEEN - ACMP1 Pin Enable

| Bit  | Name       | Reset | Access | Description                                                                                                                                                                       |
|------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | ACMPOUTPEN | 0x0   | RW     | <b>ACMPOUT pin enable control bit</b><br>ACMPOUT pin enable control bit                                                                                                           |

#### 24.6.40 GPIO\_ACMP1\_ACMPOUTROUTE - ACMPOUT Port/Pin Select

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |        |    |     |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|--------|----|-----|
| Reset  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 0x0 | RW | Access |    |     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    | PORT   | RW | 0x0 |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ACMPOUT pin select register</b>                                                                                                                                                |
|       | ACMPOUT pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ACMPOUT port select register</b>                                                                                                                                               |
|       | ACMPOUT port select register |       |        |                                                                                                                                                                                   |

**24.6.41 GPIO\_CMU\_ROUTEEN - CMU Pin Enable**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |            |    |            |    |             |    |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------|----|------------|----|-------------|----|---|
| 0x468         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0        | 2  | 0x0        | 1  | 0x0         | 0  |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW         | RW | RW         | RW | RW          | RW |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | CLKOUT2PEN | RW | CLKOUT1PEN | RW | CLKOUT0OPEN | RW |   |

| Bit  | Name                           | Reset | Access | Description                                                                                                                                                                       |
|------|--------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | <i>Reserved</i>                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2    | CLKOUT2PEN                     | 0x0   | RW     | <b>CLKOUT2 pin enable control bit</b>                                                                                                                                             |
|      | CLKOUT2 pin enable control bit |       |        |                                                                                                                                                                                   |
| 1    | CLKOUT1PEN                     | 0x0   | RW     | <b>CLKOUT1 pin enable control bit</b>                                                                                                                                             |
|      | CLKOUT1 pin enable control bit |       |        |                                                                                                                                                                                   |
| 0    | CLKOUT0OPEN                    | 0x0   | RW     | <b>CLKOUT0 pin enable control bit</b>                                                                                                                                             |
|      | CLKOUT0 pin enable control bit |       |        |                                                                                                                                                                                   |

**24.6.42 GPIO\_CMU\_CLKIN0ROUTE - CLKIN0 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |     |     |     |     |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|-----|-----|-----|-----|---|
| 0x46C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 | 0x0 | 0x0 | 0   |     |     |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW  | PIN | PIN | PIN | PIN |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PIN | PIN | PIN | PIN | PIN |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | <i>Reserved</i>             |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>CLKIN0 pin select register</b>                                                                                                                                                 |
|       | CLKIN0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | <i>Reserved</i>             |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>CLKIN0 port select register</b>                                                                                                                                                |
|       | CLKIN0 port select register |       |        |                                                                                                                                                                                   |

**24.6.43 GPIO\_CMU\_CLKOUT0ROUTE - CLKOUT0 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x470         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset                                                                                                                                                                      | Access | Description                         |
|-------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|
| 31:20 | Reserved                     | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                     |
| 19:16 | PIN                          | 0x0                                                                                                                                                                        | RW     | <b>CLKOUT0 pin select register</b>  |
|       | CLKOUT0 pin select register  |                                                                                                                                                                            |        |                                     |
| 15:2  | Reserved                     | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                     |
| 1:0   | PORT                         | 0x0                                                                                                                                                                        | RW     | <b>CLKOUT0 port select register</b> |
|       | CLKOUT0 port select register |                                                                                                                                                                            |        |                                     |

**24.6.44 GPIO\_CMU\_CLKOUT1ROUTE - CLKOUT1 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x474         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset                                                                                                                                                                      | Access | Description                         |
|-------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|
| 31:20 | Reserved                     | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                     |
| 19:16 | PIN                          | 0x0                                                                                                                                                                        | RW     | <b>CLKOUT1 pin select register</b>  |
|       | CLKOUT1 pin select register  |                                                                                                                                                                            |        |                                     |
| 15:2  | Reserved                     | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                     |
| 1:0   | PORT                         | 0x0                                                                                                                                                                        | RW     | <b>CLKOUT1 port select register</b> |
|       | CLKOUT1 port select register |                                                                                                                                                                            |        |                                     |

**24.6.45 GPIO\_CMU\_CLKOUT2ROUTE - CLKOUT2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x478  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>CLKOUT2 pin select register</b>                                                                                                                                                |
|       | CLKOUT2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>CLKOUT2 port select register</b>                                                                                                                                               |
|       | CLKOUT2 port select register |       |        |                                                                                                                                                                                   |

## 24.6.46 GPIO\_EUSART0\_ROUTEEN - EUSART0 Pin Enable

| Offset  | Bit Position |    |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|---------|--------------|----|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 0x494   | 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 |  |  |
| Reset   |              |    |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Access  |              |    |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Name    |              |    |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| TXPEN   | 0x0          | RW | <b>TX pin enable control bit</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| SCLKPEN | 0x0          | RW | <b>SCLK pin enable control bit</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| RXPEN   | 0x0          | RW | <b>RX pin enable control bit</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| RTSPEN  | 0x0          | RW | <b>RTS pin enable control bit</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| CSPEN   | 0x0          | RW | <b>CS pin enable control bit</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Bit  | Name                        | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | TXPEN                       | 0x0   | RW     | <b>TX pin enable control bit</b>                                                                                                                                                  |
|      | TX pin enable control bit   |       |        |                                                                                                                                                                                   |
| 3    | SCLKPEN                     | 0x0   | RW     | <b>SCLK pin enable control bit</b>                                                                                                                                                |
|      | SCLK pin enable control bit |       |        |                                                                                                                                                                                   |
| 2    | RXPEN                       | 0x0   | RW     | <b>RX pin enable control bit</b>                                                                                                                                                  |
|      | RX pin enable control bit   |       |        |                                                                                                                                                                                   |
| 1    | RTSPEN                      | 0x0   | RW     | <b>RTS pin enable control bit</b>                                                                                                                                                 |
|      | RTS pin enable control bit  |       |        |                                                                                                                                                                                   |
| 0    | CSPEN                       | 0x0   | RW     | <b>CS pin enable control bit</b>                                                                                                                                                  |
|      | CS pin enable control bit   |       |        |                                                                                                                                                                                   |

#### 24.6.47 GPIO\_EUSART0\_CSROUTE - CS Port/Pin Select

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>CS pin select register</b>                                                                                                                                                     |
|       | CS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>CS port select register</b>                                                                                                                                                    |
|       | CS port select register |       |        |                                                                                                                                                                                   |

## 24.6.48 GPIO\_EUSART0\_CTSROUTE - CTS Port/Pin Select

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CTS pin select register</b>                                                                                                                                                    |
|       | CTS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CTS port select register</b>                                                                                                                                                   |
|       | CTS port select register |       |        |                                                                                                                                                                                   |

#### 24.6.49 GPIO\_EUSART0\_RTSROUTE - RTS Port/Pin Select

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>RTS pin select register</b>                                                                                                                                                    |
|       | RTS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>RTS port select register</b>                                                                                                                                                   |
|       | RTS port select register |       |        |                                                                                                                                                                                   |

#### 24.6.50 GPIO\_EUSART0\_RXROUTE - RX Port/Pin Select

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>RX pin select register</b>                                                                                                                                                     |
|       | RX pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>RX port select register</b>                                                                                                                                                    |
|       | RX port select register |       |        |                                                                                                                                                                                   |

**24.6.51 GPIO\_EUSART0\_SCLKROUTE - SCLK Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x4A8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>SCLK pin select register</b>                                                                                                                                                   |
|       | SCLK pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>SCLK port select register</b>                                                                                                                                                  |
|       | SCLK port select register |       |        |                                                                                                                                                                                   |

**24.6.52 GPIO\_EUSART0\_TXROUTE - TX Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x4AC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>TX pin select register</b>                                                                                                                                                     |
|       | TX pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>TX port select register</b>                                                                                                                                                    |
|       | TX port select register |       |        |                                                                                                                                                                                   |

## 24.6.53 GPIO\_EUSART1\_ROUTEEN - EUSART1 Pin Enable

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|
| 0x4B4         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 4 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 3 |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 2 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 1 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | TXPEN           | 0x0   | RW     | <b>TX pin enable control bit</b><br><br>TX pin enable control bit                                                                                                                 |
| 3    | SCLKPEN         | 0x0   | RW     | <b>SCLK pin enable control bit</b><br><br>SCLK pin enable control bit                                                                                                             |
| 2    | RXPEN           | 0x0   | RW     | <b>RX pin enable control bit</b><br><br>RX pin enable control bit                                                                                                                 |
| 1    | RTSPEN          | 0x0   | RW     | <b>RTS pin enable control bit</b><br><br>RTS pin enable control bit                                                                                                               |
| 0    | CSPEN           | 0x0   | RW     | <b>CS pin enable control bit</b><br><br>CS pin enable control bit                                                                                                                 |

**24.6.54 GPIO\_EUSART1\_CSROUTE - CS Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x4B8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>CS pin select register</b>                                                                                                                                                     |
|       | CS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>CS port select register</b>                                                                                                                                                    |
|       | CS port select register |       |        |                                                                                                                                                                                   |

**24.6.55 GPIO\_EUSART1\_CTSROUTE - CTS Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x4BC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CTS pin select register</b>                                                                                                                                                    |
|       | CTS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CTS port select register</b>                                                                                                                                                   |
|       | CTS port select register |       |        |                                                                                                                                                                                   |

#### 24.6.56 GPIO\_EUSART1\_RTSROUTE - RTS Port/Pin Select

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |     |    |     |     |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|-----|
| Reset  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 0x0 | 0x0 |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |     |    |     |     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    | PIN | RW | 0x0 | 0x0 |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>RTS pin select register</b>                                                                                                                                                    |
|       | RTS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>RTS port select register</b>                                                                                                                                                   |
|       | RTS port select register |       |        |                                                                                                                                                                                   |

## 24.6.57 GPIO\_EUSART1\_RXROUTE - RX Port/Pin Select

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>RX pin select register</b>                                                                                                                                                     |
|       | RX pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>RX port select register</b>                                                                                                                                                    |
|       | RX port select register |       |        |                                                                                                                                                                                   |

**24.6.58 GPIO\_EUSART1\_SCLKROUTE - SCLK Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x4C8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>SCLK pin select register</b>                                                                                                                                                   |
|       | SCLK pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>SCLK port select register</b>                                                                                                                                                  |
|       | SCLK port select register |       |        |                                                                                                                                                                                   |

**24.6.59 GPIO\_EUSART1\_TXROUTE - TX Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x4CC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>TX pin select register</b>                                                                                                                                                     |
|       | TX pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>TX port select register</b>                                                                                                                                                    |
|       | TX port select register |       |        |                                                                                                                                                                                   |

#### **24.6.60 GPIO\_FRC\_ROUTEEN - FRC Pin Enable**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |     |   |   |   |   |   |   |   |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|-----|---|---|---|---|---|---|---|--|--|--|
| Reset  | 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 |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |     |   |   |   |   |   |   |   |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DOUTPEN   | RW | 0x0 | 2 |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DFRAMEPEN | RW | 0x0 | 1 |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DCLKPEN   | RW | 0x0 | 0 |   |   |   |   |   |   |  |  |  |

| Bit  | Name                          | Reset | Access | Description                                                                                                                                                                       |
|------|-------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2    | DOUTPEN                       | 0x0   | RW     | <b>DOUT pin enable control bit</b>                                                                                                                                                |
|      | DOUT pin enable control bit   |       |        |                                                                                                                                                                                   |
| 1    | DFRAMEPEN                     | 0x0   | RW     | <b>DFRAME pin enable control bit</b>                                                                                                                                              |
|      | DFRAME pin enable control bit |       |        |                                                                                                                                                                                   |
| 0    | DCLKPEN                       | 0x0   | RW     | <b>DCLK pin enable control bit</b>                                                                                                                                                |
|      | DCLK pin enable control bit   |       |        |                                                                                                                                                                                   |

## 24.6.61 GPIO\_FRC\_DCLKROUTE - DCLK Port/Pin Select

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |    |     |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|----|-----|--|--|--|
| Reset  | 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 |  |    |     |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW  | 0x0 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |    |     |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PIN |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | RW | 0x0 |  |  |  |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>DCLK pin select register</b>                                                                                                                                                   |
|       | DCLK pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>DCLK port select register</b>                                                                                                                                                  |
|       | DCLK port select register |       |        |                                                                                                                                                                                   |

**24.6.62 GPIO\_FRC\_DFRAMEROUTE - DFRAIME Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x4DC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>DFRAIME pin select register</b>                                                                                                                                                |
|       | DFRAIME pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>DFRAIME port select register</b>                                                                                                                                               |
|       | DFRAIME port select register |       |        |                                                                                                                                                                                   |

**24.6.63 GPIO\_FRC\_DOUTROUTE - DOUT Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x4E0  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>DOUT pin select register</b>                                                                                                                                                   |
|       | DOUT pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>DOUT port select register</b>                                                                                                                                                  |
|       | DOUT port select register |       |        |                                                                                                                                                                                   |

**24.6.64 GPIO\_I2C0\_ROUTEEN - I2C0 Pin Enable**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |        |     |   |   |        |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|--------|-----|---|---|--------|-----|---|
| 0x4E8         | 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 | SDAPEN | 0x0 | 1 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |        | 0x0 | 0 |   |        |     |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RW     | RW  |   |   |        |     |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | SCLPEN | RW  |   |   |        |     |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | SDAPEN          | 0x0   | RW     | <b>SDA pin enable control bit</b><br>SDA pin enable control bit                                                                                                                   |
| 0    | SCLPEN          | 0x0   | RW     | <b>SCL pin enable control bit</b><br>SCL pin enable control bit                                                                                                                   |

**24.6.65 GPIO\_I2C0\_SCLROUTE - SCL Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |     |      |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|-----|------|---|---|---|
| 0x4EC         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | 0x0 | 0x0 |      |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RW  | RW  |      |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | PIN |     | PORT |   |   |   |

| Bit   | Name            | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN             | 0x0   | RW     | <b>SCL pin select register</b><br>SCL pin select register                                                                                                                         |
| 15:2  | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT            | 0x0   | RW     | <b>SCL port select register</b><br>SCL port select register                                                                                                                       |

**24.6.66 GPIO\_I2C0\_SDAROUTE - SDA Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x4F0  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>SDA pin select register</b>                                                                                                                                                    |
|       | SDA pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>SDA port select register</b>                                                                                                                                                   |
|       | SDA port select register |       |        |                                                                                                                                                                                   |

**24.6.67 GPIO\_I2C1\_ROUTEEN - I2C1 Pin Enable**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SDAPEN | 0x0    |     |   |   |        |     |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------|--------|-----|---|---|--------|-----|
| 0x4F8  | 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 | SDAPEN | 0x0 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0    | 0x0    | 0x0 |   |   |        |     |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW     | RW     | RW  |   |   |        |     |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | SDAPEN | SCLPEN | 0x0 |   |   |        |     |

| Bit  | Name                       | Reset | Access | Description                                                                                                                                                                       |
|------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | SDAPEN                     | 0x0   | RW     | <b>SDA pin enable control bit</b>                                                                                                                                                 |
|      | SDA pin enable control bit |       |        |                                                                                                                                                                                   |
| 0    | SCLPEN                     | 0x0   | RW     | <b>SCL pin enable control bit</b>                                                                                                                                                 |
|      | SCL pin enable control bit |       |        |                                                                                                                                                                                   |

**24.6.68 GPIO\_I2C1\_SCLROUTE - SCL Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x4FC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>SCL pin select register</b>                                                                                                                                                    |
|       | SCL pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>SCL port select register</b>                                                                                                                                                   |
|       | SDC port select register |       |        |                                                                                                                                                                                   |

**24.6.69 GPIO\_I2C1\_SDAROUTE - SDA Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x500  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>SDA pin select register</b>                                                                                                                                                    |
|       | SDA pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>SDA port select register</b>                                                                                                                                                   |
|       | SDA port select register |       |        |                                                                                                                                                                                   |

## 24.6.70 GPIO\_KEYSCAN\_ROUTEEEN - KEYSAN Pin Enable

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |                     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--|---------------------|
| 0x508         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |                     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | 0x0 0               |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | RW 0x0 0            |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  | COLOUT7PEN RW 0x0 7 |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7    | COLOUT7PEN      | 0x0   | RW     | <b>COLOUT7 pin enable control bit</b><br>COLOUT7 pin enable control bit                                                                                                           |
| 6    | COLOUT6PEN      | 0x0   | RW     | <b>COLOUT6 pin enable control bit</b><br>COLOUT6 pin enable control bit                                                                                                           |
| 5    | COLOUT5PEN      | 0x0   | RW     | <b>COLOUT5 pin enable control bit</b><br>COLOUT5 pin enable control bit                                                                                                           |
| 4    | COLOUT4PEN      | 0x0   | RW     | <b>COLOUT4 pin enable control bit</b><br>COLOUT4 pin enable control bit                                                                                                           |
| 3    | COLOUT3PEN      | 0x0   | RW     | <b>COLOUT3 pin enable control bit</b><br>COLOUT3 pin enable control bit                                                                                                           |
| 2    | COLOUT2PEN      | 0x0   | RW     | <b>COLOUT2 pin enable control bit</b><br>COLOUT2 pin enable control bit                                                                                                           |
| 1    | COLOUT1PEN      | 0x0   | RW     | <b>COLOUT1 pin enable control bit</b><br>COLOUT1 pin enable control bit                                                                                                           |
| 0    | COLOUT0OPEN     | 0x0   | RW     | <b>COLOUT0 pin enable control bit</b><br>COLOUT0 pin enable control bit                                                                                                           |

**24.6.71 GPIO\_KEYSCAN\_COLOUT0ROUTE - COLOUT0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x50C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>COLOUT0 pin select register</b>                                                                                                                                                |
|       | COLOUT0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>COLOUT0 port select register</b>                                                                                                                                               |
|       | COLOUT0 port select register |       |        |                                                                                                                                                                                   |

**24.6.72 GPIO\_KEYSCAN\_COLOUT1ROUTE - COLOUT1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x510  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>COLOUT1 pin select register</b>                                                                                                                                                |
|       | COLOUT1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>COLOUT1 port select register</b>                                                                                                                                               |
|       | COLOUT1 port select register |       |        |                                                                                                                                                                                   |

#### 24.6.73 GPIO KEYS SCAN COLOUT2ROUTE - COLOUT2 Port/Pin Select

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>COLOUT2 pin select register</b>                                                                                                                                                |
|       | COLOUT2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>COLOUT2 port select register</b>                                                                                                                                               |
|       | COLOUT2 port select register |       |        |                                                                                                                                                                                   |

#### 24.6.74 GPIO\_KEYSCAN\_COLOUT3ROUTE - COLOUT3 Port/Pin Select

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN      | 0x0   | RW     | <b>COLOUT3 pin select register</b>                                                                                                                                                |
|       |          |       |        | COLOUT3 pin select register                                                                                                                                                       |
| 15:2  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT     | 0x0   | RW     | <b>COLOUT3 port select register</b>                                                                                                                                               |
|       |          |       |        | COLOUT3 port select register                                                                                                                                                      |

**24.6.75 GPIO\_KEYSCAN\_COLOUT4ROUTE - COLOUT4 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x51C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>COLOUT4 pin select register</b>                                                                                                                                                |
|       | COLOUT4 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>COLOUT4 port select register</b>                                                                                                                                               |
|       | COLOUT4 port select register |       |        |                                                                                                                                                                                   |

**24.6.76 GPIO\_KEYSCAN\_COLOUT5ROUTE - COLOUT5 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x520  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>COLOUT5 pin select register</b>                                                                                                                                                |
|       | COLOUT5 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>COLOUT5 port select register</b>                                                                                                                                               |
|       | COLOUT5 port select register |       |        |                                                                                                                                                                                   |

**24.6.77 GPIO\_KEYSCAN\_COLOUT6ROUTE - COLOUT6 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x524  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>COLOUT6 pin select register</b>                                                                                                                                                |
|       | COLOUT6 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>COLOUT6 port select register</b>                                                                                                                                               |
|       | COLOUT6 port select register |       |        |                                                                                                                                                                                   |

**24.6.78 GPIO\_KEYSCAN\_COLOUT7ROUTE - COLOUT7 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x528  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>COLOUT7 pin select register</b>                                                                                                                                                |
|       | COLOUT7 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>COLOUT7 port select register</b>                                                                                                                                               |
|       | COLOUT7 port select register |       |        |                                                                                                                                                                                   |

**24.6.79 GPIO\_KEYSCAN\_ROWSENSE0ROUTE - ROWSENSE0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x52C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                           | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                            | 0x0   | RW     | <b>ROWSENSE0 pin select register</b>                                                                                                                                              |
|       | ROWSENSE0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                           | 0x0   | RW     | <b>ROWSENSE0 port select register</b>                                                                                                                                             |
|       | ROWSENSE0 port select register |       |        |                                                                                                                                                                                   |

**24.6.80 GPIO\_KEYSCAN\_ROWSENSE1ROUTE - ROWSENSE1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x530  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                           | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                            | 0x0   | RW     | <b>ROWSENSE1 pin select register</b>                                                                                                                                              |
|       | ROWSENSE1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                           | 0x0   | RW     | <b>ROWSENSE1 port select register</b>                                                                                                                                             |
|       | ROWSENSE1 port select register |       |        |                                                                                                                                                                                   |

**24.6.81 GPIO\_KEYSCAN\_ROWSENSE2ROUTE - ROWSENSE2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x534  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                           | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                            | 0x0   | RW     | <b>ROWSENSE2 pin select register</b>                                                                                                                                              |
|       | ROWSENSE2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                           | 0x0   | RW     | <b>ROWSENSE2 port select register</b>                                                                                                                                             |
|       | ROWSENSE2 port select register |       |        |                                                                                                                                                                                   |

**24.6.82 GPIO\_KEYSCAN\_ROWSENSE3ROUTE - ROWSENSE3 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x538  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                           | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                            | 0x0   | RW     | <b>ROWSENSE3 pin select register</b>                                                                                                                                              |
|       | ROWSENSE3 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                           | 0x0   | RW     | <b>ROWSENSE3 port select register</b>                                                                                                                                             |
|       | ROWSENSE3 port select register |       |        |                                                                                                                                                                                   |

**24.6.83 GPIO\_KEYSCAN\_ROWSENSE4ROUTE - ROWSENSE4 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x53C         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                           | Reset                                                                                                                                                                      | Access | Description                           |
|-------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------|
| 31:20 | Reserved                       | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                       |
| 19:16 | PIN                            | 0x0                                                                                                                                                                        | RW     | <b>ROWSENSE4 pin select register</b>  |
|       | ROWSENSE4 pin select register  |                                                                                                                                                                            |        |                                       |
| 15:2  | Reserved                       | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                       |
| 1:0   | PORT                           | 0x0                                                                                                                                                                        | RW     | <b>ROWSENSE4 port select register</b> |
|       | ROWSENSE4 port select register |                                                                                                                                                                            |        |                                       |

**24.6.84 GPIO\_KEYSCAN\_ROWSENSE5ROUTE - ROWSENSE5 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x540         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                           | Reset                                                                                                                                                                      | Access | Description                           |
|-------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------|
| 31:20 | Reserved                       | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                       |
| 19:16 | PIN                            | 0x0                                                                                                                                                                        | RW     | <b>ROWSENSE5 pin select register</b>  |
|       | ROWSENSE5 pin select register  |                                                                                                                                                                            |        |                                       |
| 15:2  | Reserved                       | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                       |
| 1:0   | PORT                           | 0x0                                                                                                                                                                        | RW     | <b>ROWSENSE5 port select register</b> |
|       | ROWSENSE5 port select register |                                                                                                                                                                            |        |                                       |

**24.6.85 GPIO\_LETIMER\_ROUTEEN - LETIMER Pin Enable**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |     |          |    |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|-----|----------|----|---|---|---|
| 0x548         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0      | 0x0 | 0        |    |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW       | RW  | 0        |    |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | OUT1OPEN | RW  | OUT0OPEN | RW |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | OUT1OPEN | 0x0   | RW     | <b>OUT1 pin enable control bit</b><br>OUT1 pin enable control bit                                                                                                                 |
| 0    | OUT0OPEN | 0x0   | RW     | <b>OUT0 pin enable control bit</b><br>OUT0 pin enable control bit                                                                                                                 |

**24.6.86 GPIO\_LETIMER\_OUT0ROUTE - OUT0 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |     |      |    |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|------|----|---|---|---|
| 0x54C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 | 0x0 | 0    |    |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW  | PORT | RW |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN |     |      |    |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN      | 0x0   | RW     | <b>OUT0 pin select register</b><br>OUT0 pin select register                                                                                                                       |
| 15:2  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT     | 0x0   | RW     | <b>OUT0 port select register</b><br>OUT0 port select register                                                                                                                     |

## 24.6.87 GPIO\_LETIMER\_OUT1ROUTE - OUT1 Port/Pin Select

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x550  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>OUT1 pin select register</b>                                                                                                                                                   |
|       | OUT1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>OUT1 port select register</b>                                                                                                                                                  |
|       | OUT1 port select register |       |        |                                                                                                                                                                                   |

## 24.6.88 GPIO\_MODEM\_ROUTEEN - MODEM Pin Enable

| Offset        | Bit Position |     |    |         |    |     |    |                |    |     |    |            |    |     |    |            |    |     |    |            |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |                |    |     |   |         |    |     |   |         |    |     |   |
|---------------|--------------|-----|----|---------|----|-----|----|----------------|----|-----|----|------------|----|-----|----|------------|----|-----|----|------------|----|-----|---|-----------|----|-----|---|-----------|----|-----|---|-----------|----|-----|---|-----------|----|-----|---|-----------|----|-----|---|----------------|----|-----|---|---------|----|-----|---|---------|----|-----|---|
| 0x558         | 31           | 30  | 29 | 28      | 27 | 26  | 25 | 24             | 23 | 22  | 21 | 20         | 19 | 18  | 17 | 16         | 15 |     |    |            |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |                |    |     |   |         |    |     |   |         |    |     |   |
| <b>Reset</b>  |              |     |    |         |    |     |    |                |    |     |    |            |    |     |    |            |    |     |    |            |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |                |    |     |   |         |    |     |   |         |    |     |   |
| <b>Access</b> |              |     |    |         |    |     |    |                |    |     |    |            |    |     |    |            |    |     |    |            |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |                |    |     |   |         |    |     |   |         |    |     |   |
| <b>Name</b>   |              |     |    |         |    |     |    |                |    |     |    |            |    |     |    |            |    |     |    |            |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |           |    |     |   |                |    |     |   |         |    |     |   |         |    |     |   |
| DOUTPEN       | RW           | 0x0 | 14 | DCLKPEN | RW | 0x0 | 13 | ANTTRIGSTOPPEN | RW | 0x0 | 12 | ANTTRIGPEN | RW | 0x0 | 11 | ANTSWUSPEN | RW | 0x0 | 10 | ANTSWENPEN | RW | 0x0 | 9 | ANTRR5PEN | RW | 0x0 | 8 | ANTRR4PEN | RW | 0x0 | 7 | ANTRR3PEN | RW | 0x0 | 6 | ANTRR2PEN | RW | 0x0 | 5 | ANTRR1PEN | RW | 0x0 | 4 | ANTROLLOVERPEN | RW | 0x0 | 3 | ANT1PEN | RW | 0x0 | 2 | ANTOPEN | RW | 0x0 | 0 |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 14    | DOUTPEN        | 0x0   | RW     | <b>DOUT pin enable control bit</b><br>DOUT pin enable control bit                                                                                                                 |
| 13    | DCLKPEN        | 0x0   | RW     | <b>DCLK pin enable control bit</b><br>DCLK pin enable control bit                                                                                                                 |
| 12    | ANTTRIGSTOPPEN | 0x0   | RW     | <b>ANTTRIGSTOP pin enable control bit</b><br>ANTTRIGSTOP pin enable control bit                                                                                                   |
| 11    | ANTTRIGPEN     | 0x0   | RW     | <b>ANTTRIG pin enable control bit</b><br>ANTTRIG pin enable control bit                                                                                                           |
| 10    | ANTSWUSPEN     | 0x0   | RW     | <b>ANTSWUS pin enable control bit</b><br>ANTSWUS pin enable control bit                                                                                                           |
| 9     | ANTSWENPEN     | 0x0   | RW     | <b>ANTSWEN pin enable control bit</b><br>ANTSWEN pin enable control bit                                                                                                           |
| 8     | ANTRR5PEN      | 0x0   | RW     | <b>ANTRR5 pin enable control bit</b><br>ANTRR5 pin enable control bit                                                                                                             |
| 7     | ANTRR4PEN      | 0x0   | RW     | <b>ANTRR4 pin enable control bit</b><br>ANTRR4 pin enable control bit                                                                                                             |
| 6     | ANTRR3PEN      | 0x0   | RW     | <b>ANTRR3 pin enable control bit</b><br>ANTRR3 pin enable control bit                                                                                                             |
| 5     | ANTRR2PEN      | 0x0   | RW     | <b>ANTRR2 pin enable control bit</b><br>ANTRR2 pin enable control bit                                                                                                             |
| 4     | ANTRR1PEN      | 0x0   | RW     | <b>ANTRR1 pin enable control bit</b><br>ANTRR1 pin enable control bit                                                                                                             |
| 3     | ANTROLLOVERPEN | 0x0   | RW     | <b>ANTROLLOVERPEN</b><br>ANTROLLOVERPEN                                                                                                                                           |
|       |                |       |        | ANTOPEN                                                                                                                                                                           |

| Bit | Name           | Reset | Access | Description                                                                     |
|-----|----------------|-------|--------|---------------------------------------------------------------------------------|
| 2   | ANTROLLOVERPEN | 0x0   | RW     | <b>ANTROLLOVER pin enable control bit</b><br>ANTROLLOVER pin enable control bit |
| 1   | ANT1PEN        | 0x0   | RW     | <b>ANT1 pin enable control bit</b><br>ANT1 pin enable control bit               |
| 0   | ANT0OPEN       | 0x0   | RW     | <b>ANT0 pin enable control bit</b><br>ANT0 pin enable control bit               |

**24.6.89 GPIO\_MODEM\_ANT0ROUTE - ANT0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|
| 0x55C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0 |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW  |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | PIN |   |   |

| Bit   | Name     | Reset                                                                                                                                                                      | Access | Description                                                   |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------|
| 31:20 | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                               |
| 19:16 | PIN      | 0x0                                                                                                                                                                        | RW     | <b>ANT0 pin select register</b><br>ANT0 pin select register   |
| 15:2  | Reserved | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                               |
| 1:0   | PORT     | 0x0                                                                                                                                                                        | RW     | <b>ANT0 port select register</b><br>ANT0 port select register |

**24.6.90 GPIO\_MODEM\_ANT1ROUTE - ANT1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x560  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>ANT1 pin select register</b>                                                                                                                                                   |
|       | ANT1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>ANT1 port select register</b>                                                                                                                                                  |
|       | ANT1 port select register |       |        |                                                                                                                                                                                   |

**24.6.91 GPIO\_MODEM\_ANTROLLOVERROUTE - ANTROLLOVER Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x564  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                             | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                              | 0x0   | RW     | <b>ANTROLLOVER pin select register</b>                                                                                                                                            |
|       | ANTROLLOVER pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                         |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                             | 0x0   | RW     | <b>ANTROLLOVER port select register</b>                                                                                                                                           |
|       | ANTROLLOVER port select register |       |        |                                                                                                                                                                                   |

**24.6.92 GPIO\_MODEM\_ANTRR0ROUTE - ANTRR0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x568  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>ANTRR0 pin select register</b>                                                                                                                                                 |
|       | ANTRR0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>ANTRR0 port select register</b>                                                                                                                                                |
|       | ANTRR0 port select register |       |        |                                                                                                                                                                                   |

**24.6.93 GPIO\_MODEM\_ANTRR1ROUTE - ANTRR1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x56C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>ANTRR1 pin select register</b>                                                                                                                                                 |
|       | ANTRR1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>ANTRR1 port select register</b>                                                                                                                                                |
|       | ANTRR1 port select register |       |        |                                                                                                                                                                                   |

**24.6.94 GPIO\_MODEM\_ANTRR2ROUTE - ANTRR2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x570  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>ANTRR2 pin select register</b>                                                                                                                                                 |
|       | ANTRR2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>ANTRR2 port select register</b>                                                                                                                                                |
|       | ANTRR2 port select register |       |        |                                                                                                                                                                                   |

**24.6.95 GPIO\_MODEM\_ANTRR3ROUTE - ANTRR3 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x574  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>ANTRR3 pin select register</b>                                                                                                                                                 |
|       | ANTRR3 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>ANTRR3 port select register</b>                                                                                                                                                |
|       | ANTRR3 port select register |       |        |                                                                                                                                                                                   |

**24.6.96 GPIO\_MODEM\_ANTRR4ROUTE - ANTRR4 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x578  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>ANTRR4 pin select register</b>                                                                                                                                                 |
|       | ANTRR4 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>ANTRR4 port select register</b>                                                                                                                                                |
|       | ANTRR4 port select register |       |        |                                                                                                                                                                                   |

**24.6.97 GPIO\_MODEM\_ANTRR5ROUTE - ANTRR5 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x57C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>ANTRR5 pin select register</b>                                                                                                                                                 |
|       | ANTRR5 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>ANTRR5 port select register</b>                                                                                                                                                |
|       | ANTRR5 port select register |       |        |                                                                                                                                                                                   |

**24.6.98 GPIO\_MODEM\_ANTSWENROUTE - ANTSWEN Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x580  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ANTSWEN pin select register</b>                                                                                                                                                |
|       | ANTSWEN pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ANTSWEN port select register</b>                                                                                                                                               |
|       | ANTSWEN port select register |       |        |                                                                                                                                                                                   |

**24.6.99 GPIO\_MODEM\_ANTSWUSRROUTE - ANTSWUS Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x584  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ANTSWUS pin select register</b>                                                                                                                                                |
|       | ANTSWUS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ANTSWUS port select register</b>                                                                                                                                               |
|       | ANTSWUS port select register |       |        |                                                                                                                                                                                   |

**24.6.100 GPIO\_MODEM\_ANTRIGROUTE - ANTRIG Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x588         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset                                                                                                                                                                             | Access | Description                         |
|-------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------|
| 31:20 | Reserved                     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                     |
| 19:16 | PIN                          | 0x0                                                                                                                                                                               | RW     | <b>ANTTRIG pin select register</b>  |
|       | ANTTRIG pin select register  |                                                                                                                                                                                   |        |                                     |
| 15:2  | Reserved                     | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                     |
| 1:0   | PORT                         | 0x0                                                                                                                                                                               | RW     | <b>ANTTRIG port select register</b> |
|       | ANTTRIG port select register |                                                                                                                                                                                   |        |                                     |

**24.6.101 GPIO\_MODEM\_ANTRIGSTOPROUTE - ANTRIGSTOP Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x58C         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                             | Reset                                                                                                                                                                             | Access | Description                             |
|-------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------|
| 31:20 | Reserved                         | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                         |
| 19:16 | PIN                              | 0x0                                                                                                                                                                               | RW     | <b>ANTTRIGSTOP pin select register</b>  |
|       | ANTTRIGSTOP pin select register  |                                                                                                                                                                                   |        |                                         |
| 15:2  | Reserved                         | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                         |
| 1:0   | PORT                             | 0x0                                                                                                                                                                               | RW     | <b>ANTTRIGSTOP port select register</b> |
|       | ANTTRIGSTOP port select register |                                                                                                                                                                                   |        |                                         |

**24.6.102 GPIO\_MODEM\_DCLKROUTE - DCLK Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x590         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN      | 0x0   | RW     | <b>DCLK pin select register</b>                                                                                                                                                   |
|       |          |       |        | DCLK pin select register                                                                                                                                                          |
| 15:2  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT     | 0x0   | RW     | <b>DCLK port select register</b>                                                                                                                                                  |
|       |          |       |        | DCLK port select register                                                                                                                                                         |

**24.6.103 GPIO\_MODEM\_DINROUTE - DIN Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x594         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN      | 0x0   | RW     | <b>DIN pin select register</b>                                                                                                                                                    |
|       |          |       |        | DIN pin select register                                                                                                                                                           |
| 15:2  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT     | 0x0   | RW     | <b>DIN port select register</b>                                                                                                                                                   |
|       |          |       |        | DIN port select register                                                                                                                                                          |

**24.6.104 GPIO\_MODEM\_DOUTROUTE - DOUT Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x598  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>DOUT pin select register</b>                                                                                                                                                   |
|       | DOUT pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>DOUT port select register</b>                                                                                                                                                  |
|       | DOUT port select register |       |        |                                                                                                                                                                                   |

**24.6.105 GPIO\_PCNT0\_S0INROUTE - S0IN Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5A4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>S0IN pin select register</b>                                                                                                                                                   |
|       | S0IN pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>S0IN port select register</b>                                                                                                                                                  |
|       | S0IN port select register |       |        |                                                                                                                                                                                   |

**24.6.106 GPIO\_PCNT0\_S1INROUTE - S1IN Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x5A8         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>S1IN pin select register</b>                                                                                                                                                   |
|       | S1IN pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>S1IN port select register</b>                                                                                                                                                  |
|       | S1IN port select register |       |        |                                                                                                                                                                                   |

## 24.6.107 GPIO\_PRS0\_ROUTEEN - PRS0 Pin Enable

| Offset | Bit Position |           |           |            |             |             |             |             |             |              |             |            |            |            |            |            |
|--------|--------------|-----------|-----------|------------|-------------|-------------|-------------|-------------|-------------|--------------|-------------|------------|------------|------------|------------|------------|
| Reset  | 31           | 30        | 29        | 28         | 27          | 26          | 25          | 24          | 23          | 22           | 21          | 20         |            |            |            |            |
| Access | RW           | RW        | RW        | RW         | RW          | RW          | RW          | RW          | RW          | RW           | RW          | RW         | RW         | RW         | RW         | RW         |
| Name   | SYNCH3PEN    | SYNCH2PEN | SYNCH1PEN | SYNCH0OPEN | ASYNCH15PEN | ASYNCH14PEN | ASYNCH13PEN | ASYNCH12PEN | ASYNCH11PEN | ASYNCH10OPEN | ASYNCH9OPEN | ASYNCH8PEN | ASYNCH7PEN | ASYNCH6PEN | ASYNCH5PEN | ASYNCH4PEN |

| Bit   | Name         | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19    | SYNCH3PEN    | 0x0   | RW     | <b>SYNCH3 pin enable control bit</b><br>SYNCH3 pin enable control bit                                                                                                             |
| 18    | SYNCH2PEN    | 0x0   | RW     | <b>SYNCH2 pin enable control bit</b><br>SYNCH2 pin enable control bit                                                                                                             |
| 17    | SYNCH1PEN    | 0x0   | RW     | <b>SYNCH1 pin enable control bit</b><br>SYNCH1 pin enable control bit                                                                                                             |
| 16    | SYNCH0OPEN   | 0x0   | RW     | <b>SYNCH0 pin enable control bit</b><br>SYNCH0 pin enable control bit                                                                                                             |
| 15    | ASYNCH15PEN  | 0x0   | RW     | <b>ASYNCH15 pin enable control bit</b><br>ASYNCH15 pin enable control bit                                                                                                         |
| 14    | ASYNCH14PEN  | 0x0   | RW     | <b>ASYNCH14 pin enable control bit</b><br>ASYNCH14 pin enable control bit                                                                                                         |
| 13    | ASYNCH13PEN  | 0x0   | RW     | <b>ASYNCH13 pin enable control bit</b><br>ASYNCH13 pin enable control bit                                                                                                         |
| 12    | ASYNCH12PEN  | 0x0   | RW     | <b>ASYNCH12 pin enable control bit</b><br>ASYNCH12 pin enable control bit                                                                                                         |
| 11    | ASYNCH11PEN  | 0x0   | RW     | <b>ASYNCH11 pin enable control bit</b><br>ASYNCH11 pin enable control bit                                                                                                         |
| 10    | ASYNCH10OPEN | 0x0   | RW     | <b>ASYNCH10 pin enable control bit</b><br>ASYNCH10 pin enable control bit                                                                                                         |
| 9     | ASYNCH9OPEN  | 0x0   | RW     | <b>ASYNCH9 pin enable control bit</b><br>ASYNCH9 pin enable control bit                                                                                                           |
| 8     | ASYNCH8PEN   | 0x0   | RW     | <b>ASYNCH8 pin enable control bit</b><br>ASYNCH8 pin enable control bit                                                                                                           |
| 7     | ASYNCH7PEN   | 0x0   | RW     | <b>ASYNCH7 pin enable control bit</b>                                                                                                                                             |

| Bit | Name                           | Reset | Access | Description                           |
|-----|--------------------------------|-------|--------|---------------------------------------|
|     | ASYNCH7 pin enable control bit |       |        |                                       |
| 6   | ASYNCH6PEN                     | 0x0   | RW     | <b>ASYNCH6 pin enable control bit</b> |
|     | ASYNCH6 pin enable control bit |       |        |                                       |
| 5   | ASYNCH5PEN                     | 0x0   | RW     | <b>ASYNCH5 pin enable control bit</b> |
|     | ASYNCH5 pin enable control bit |       |        |                                       |
| 4   | ASYNCH4PEN                     | 0x0   | RW     | <b>ASYNCH4 pin enable control bit</b> |
|     | ASYNCH4 pin enable control bit |       |        |                                       |
| 3   | ASYNCH3PEN                     | 0x0   | RW     | <b>ASYNCH3 pin enable control bit</b> |
|     | ASYNCH3 pin enable control bit |       |        |                                       |
| 2   | ASYNCH2PEN                     | 0x0   | RW     | <b>ASYNCH2 pin enable control bit</b> |
|     | ASYNCH2 pin enable control bit |       |        |                                       |
| 1   | ASYNCH1PEN                     | 0x0   | RW     | <b>ASYNCH1 pin enable control bit</b> |
|     | ASYNCH1 pin enable control bit |       |        |                                       |
| 0   | ASYNCH0PEN                     | 0x0   | RW     | <b>ASYNCH0 pin enable control bit</b> |
|     | ASYNCH0 pin enable control bit |       |        |                                       |

**24.6.108 GPIO\_PRS0\_ASYNCH0ROUTE - ASYNCH0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|------|
|        | 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 |  |      |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |      |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |      |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | PORT |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH0 pin select register</b>                                                                                                                                                |
|       | ASYNCH0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH0 port select register</b>                                                                                                                                               |
|       | ASYNCH0 port select register |       |        |                                                                                                                                                                                   |

**24.6.109 GPIO\_PRS0\_ASYNCH1ROUTE - ASYNCH1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |      |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|------|---|---|---|---|
| 0x5B8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |      |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW   |      |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT | PORT |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH1 pin select register</b>                                                                                                                                                |
|       | ASYNCH1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH1 port select register</b>                                                                                                                                               |
|       | ASYNCH1 port select register |       |        |                                                                                                                                                                                   |

**24.6.110 GPIO\_PRS0\_ASYNCH2ROUTE - ASYNCH2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |      |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|------|---|---|---|---|
| 0x5BC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |      |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW   |      |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT | PORT |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH2 pin select register</b>                                                                                                                                                |
|       | ASYNCH2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH2 port select register</b>                                                                                                                                               |
|       | ASYNCH2 port select register |       |        |                                                                                                                                                                                   |

**24.6.111 GPIO\_PRS0\_ASYNCH3ROUTE - ASYNCH3 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |      |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|------|---|---|---|---|
| 0x5C0  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |      |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW   |      |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT | PORT |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH3 pin select register</b>                                                                                                                                                |
|       | ASYNCH3 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH3 port select register</b>                                                                                                                                               |
|       | ASYNCH3 port select register |       |        |                                                                                                                                                                                   |

**24.6.112 GPIO\_PRS0\_ASYNCH4ROUTE - ASYNCH4 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |      |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|------|---|---|---|---|
| 0x5C4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |      |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW   |      |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT | PORT |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH4 pin select register</b>                                                                                                                                                |
|       | ASYNCH4 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH4 port select register</b>                                                                                                                                               |
|       | ASYNCH4 port select register |       |        |                                                                                                                                                                                   |

**24.6.113 GPIO\_PRS0\_ASYNCH5ROUTE - ASYNCH5 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x5C8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH5 pin select register</b>                                                                                                                                                |
|       | ASYNCH5 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH5 port select register</b>                                                                                                                                               |
|       | ASYNCH5 port select register |       |        |                                                                                                                                                                                   |

**24.6.114 GPIO\_PRS0\_ASYNCH6ROUTE - ASYNCH6 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x5CC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH6 pin select register</b>                                                                                                                                                |
|       | ASYNCH6 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH6 port select register</b>                                                                                                                                               |
|       | ASYNCH6 port select register |       |        |                                                                                                                                                                                   |

**24.6.115 GPIO\_PRS0\_ASYNCH7ROUTE - ASYNCH7 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |      |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|------|---|---|---|---|
| 0x5D0  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |      |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW   |      |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT | PORT |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH7 pin select register</b>                                                                                                                                                |
|       | ASYNCH7 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH7 port select register</b>                                                                                                                                               |
|       | ASYNCH7 port select register |       |        |                                                                                                                                                                                   |

**24.6.116 GPIO\_PRS0\_ASYNCH8ROUTE - ASYNCH8 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |      |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|------|---|---|---|---|
| 0x5D4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |      |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  | RW   |      |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT | PORT |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH8 pin select register</b>                                                                                                                                                |
|       | ASYNCH8 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH8 port select register</b>                                                                                                                                               |
|       | ASYNCH8 port select register |       |        |                                                                                                                                                                                   |

**24.6.117 GPIO\_PRS0\_ASYNCH9ROUTE - ASYNCH9 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5D8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                         | Reset | Access | Description                                                                                                                                                                       |
|-------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                          | 0x0   | RW     | <b>ASYNCH9 pin select register</b>                                                                                                                                                |
|       | ASYNCH9 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                         | 0x0   | RW     | <b>ASYNCH9 port select register</b>                                                                                                                                               |
|       | ASYNCH9 port select register |       |        |                                                                                                                                                                                   |

**24.6.118 GPIO\_PRS0\_ASYNCH10ROUTE - ASYNCH10 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5DC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                          | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                           | 0x0   | RW     | <b>ASYNCH10 pin select register</b>                                                                                                                                               |
|       | ASYNCH10 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                          | 0x0   | RW     | <b>ASYNCH10 port select register</b>                                                                                                                                              |
|       | ASYNCH10 port select register |       |        |                                                                                                                                                                                   |

**24.6.119 GPIO\_PRS0\_ASYNCH11ROUTE - ASYNCH11 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x5E0         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 12 |    |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 11 |    |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 10 |    |
|               | PORT         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 9  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 8  |    |
|               | 1            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 6  |    |
|               | 5            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 4  |    |
|               | 3            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 2  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |

| Bit   | Name                          | Reset                                                                                                                                                                             | Access | Description                          |
|-------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------|
| 31:20 | <i>Reserved</i>               | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                      |
| 19:16 | PIN                           | 0x0                                                                                                                                                                               | RW     | <b>ASYNCH11 pin select register</b>  |
|       | ASYNCH11 pin select register  |                                                                                                                                                                                   |        |                                      |
| 15:2  | <i>Reserved</i>               | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                      |
| 1:0   | PORT                          | 0x0                                                                                                                                                                               | RW     | <b>ASYNCH11 port select register</b> |
|       | ASYNCH11 port select register |                                                                                                                                                                                   |        |                                      |

**24.6.120 GPIO\_PRS0\_ASYNCH12ROUTE - ASYNCH12 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x5E4         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 12 |    |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 11 |    |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 10 |    |
|               | PORT         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 9  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 8  |    |
|               | 1            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 6  |    |
|               | 5            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 4  |    |
|               | 3            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 2  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1  |    |
|               | 0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |

| Bit   | Name                          | Reset                                                                                                                                                                             | Access | Description                          |
|-------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------|
| 31:20 | <i>Reserved</i>               | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                      |
| 19:16 | PIN                           | 0x0                                                                                                                                                                               | RW     | <b>ASYNCH12 pin select register</b>  |
|       | ASYNCH12 pin select register  |                                                                                                                                                                                   |        |                                      |
| 15:2  | <i>Reserved</i>               | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                      |
| 1:0   | PORT                          | 0x0                                                                                                                                                                               | RW     | <b>ASYNCH12 port select register</b> |
|       | ASYNCH12 port select register |                                                                                                                                                                                   |        |                                      |

**24.6.121 GPIO\_PRS0\_ASYNCH13ROUTE - ASYNCH13 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5E8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                          | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                           | 0x0   | RW     | <b>ASYNCH13 pin select register</b>                                                                                                                                               |
|       | ASYNCH13 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                          | 0x0   | RW     | <b>ASYNCH13 port select register</b>                                                                                                                                              |
|       | ASYNCH13 port select register |       |        |                                                                                                                                                                                   |

**24.6.122 GPIO\_PRS0\_ASYNCH14ROUTE - ASYNCH14 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5EC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                          | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                           | 0x0   | RW     | <b>ASYNCH14 pin select register</b>                                                                                                                                               |
|       | ASYNCH14 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                          | 0x0   | RW     | <b>ASYNCH14 port select register</b>                                                                                                                                              |
|       | ASYNCH14 port select register |       |        |                                                                                                                                                                                   |

**24.6.123 GPIO\_PRS0\_ASYNCH15ROUTE - ASYNCH15 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5F0         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                          | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                           | 0x0   | RW     | <b>ASYNCH15 pin select register</b>                                                                                                                                               |
|       | ASYNCH15 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                          | 0x0   | RW     | <b>ASYNCH15 port select register</b>                                                                                                                                              |
|       | ASYNCH15 port select register |       |        |                                                                                                                                                                                   |

**24.6.124 GPIO\_PRS0\_SYNCH0ROUTE - SYNCH0 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5F4         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>SYNCH0 pin select register</b>                                                                                                                                                 |
|       | SYNCH0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>SYNCH0 port select register</b>                                                                                                                                                |
|       | SYNCH0 port select register |       |        |                                                                                                                                                                                   |

**24.6.125 GPIO\_PRS0\_SYNCH1ROUTE - SYNCH1 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5F8         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset                                                                                                                                                                      | Access | Description                        |
|-------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------|
| 31:20 | Reserved                    | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                    |
| 19:16 | PIN                         | 0x0                                                                                                                                                                        | RW     | <b>SYNCH1 pin select register</b>  |
|       | SYNCH1 pin select register  |                                                                                                                                                                            |        |                                    |
| 15:2  | Reserved                    | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                    |
| 1:0   | PORT                        | 0x0                                                                                                                                                                        | RW     | <b>SYNCH1 port select register</b> |
|       | SYNCH1 port select register |                                                                                                                                                                            |        |                                    |

**24.6.126 GPIO\_PRS0\_SYNCH2ROUTE - SYNCH2 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x5FC         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset                                                                                                                                                                      | Access | Description                        |
|-------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------|
| 31:20 | Reserved                    | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                    |
| 19:16 | PIN                         | 0x0                                                                                                                                                                        | RW     | <b>SYNCH2 pin select register</b>  |
|       | SYNCH2 pin select register  |                                                                                                                                                                            |        |                                    |
| 15:2  | Reserved                    | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                    |
| 1:0   | PORT                        | 0x0                                                                                                                                                                        | RW     | <b>SYNCH2 port select register</b> |
|       | SYNCH2 port select register |                                                                                                                                                                            |        |                                    |

**24.6.127 GPIO\_PRS0\_SYNCH3ROUTE - SYNCH3 Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x600         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                        | Reset | Access | Description                                                                                                                                                                       |
|-------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                         | 0x0   | RW     | <b>SYNCH3 pin select register</b>                                                                                                                                                 |
|       | SYNCH3 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                        | 0x0   | RW     | <b>SYNCH3 port select register</b>                                                                                                                                                |
|       | SYNCH3 port select register |       |        |                                                                                                                                                                                   |

**24.6.128 GPIO\_RAC\_ROUTEEN - RAC Pin Enable**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |          |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|----------|---|---|---|---|---|---|
| 0x608         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |          |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW  |          |   |   |   |   |   |   |
| <b>Name</b>   | PAENPEN      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | LNAENPEN |   |   |   |   |   |   |

| Bit  | Name                         | Reset | Access | Description                                                                                                                                                                       |
|------|------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved                     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | PAENPEN                      | 0x0   | RW     | <b>PAEN pin enable control bit</b>                                                                                                                                                |
|      | PAEN pin enable control bit  |       |        |                                                                                                                                                                                   |
| 0    | LNAENPEN                     | 0x0   | RW     | <b>LNAEN pin enable control bit</b>                                                                                                                                               |
|      | LNAEN pin enable control bit |       |        |                                                                                                                                                                                   |

**24.6.129 GPIO\_RAC\_LNAENROUTE - LNAEN Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x60C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>LNAEN pin select register</b>                                                                                                                                                  |
|       | LNAEN pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>LNAEN port select register</b>                                                                                                                                                 |
|       | LNAEN port select register |       |        |                                                                                                                                                                                   |

**24.6.130 GPIO\_RAC\_PAENROUTE - PAEN Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x610  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>PAEN pin select register</b>                                                                                                                                                   |
|       | PAEN pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>PAEN port select register</b>                                                                                                                                                  |
|       | PAEN port select register |       |        |                                                                                                                                                                                   |

**24.6.131 GPIO\_SYX00\_BUFOUTREQINASYNCROUTE - BUFOUTREQINASYNC Port/Pin Select**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x678         | 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 |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| <b>Name</b>   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name            | Reset                                                                                                                                                                             | Access | Description                                                                               |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------|
| 31:20 | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                           |
| 19:16 | PIN             | 0x0                                                                                                                                                                               | RW     | <b>BUFOUTREQINASYNC pin select register</b><br><br>BUFOUTREQINASYNC pin select register   |
| 15:2  | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                           |
| 1:0   | PORT            | 0x0                                                                                                                                                                               | RW     | <b>BUFOUTREQINASYNC port select register</b><br><br>BUFOUTREQINASYNC port select register |

## 24.6.132 GPIO\_TIMER0\_ROUTEEN - TIMER0 Pin Enable

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 0x680  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | CCC2PEN  | 0x0   | RW     | <b>CDTI2 pin enable control bit</b><br>CDTI2 pin enable control bit                                                                                                               |
| 4    | CCC1PEN  | 0x0   | RW     | <b>CDTI1 pin enable control bit</b><br>CDTI1 pin enable control bit                                                                                                               |
| 3    | CCC0PEN  | 0x0   | RW     | <b>CDTI0 pin enable control bit</b><br>CDTI0 pin enable control bit                                                                                                               |
| 2    | CC2PEN   | 0x0   | RW     | <b>CC2 pin enable control bit</b><br>CC2 pin enable control bit                                                                                                                   |
| 1    | CC1PEN   | 0x0   | RW     | <b>CC1 pin enable control bit</b><br>CC1 pin enable control bit                                                                                                                   |
| 0    | CC0PEN   | 0x0   | RW     | <b>CC0 pin enable control bit</b><br>CC0 pin enable control bit                                                                                                                   |

**24.6.133 GPIO\_TIMER0\_CC0ROUTE - CC0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x684  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC0 pin select register</b>                                                                                                                                                    |
|       | CC0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC0 port select register</b>                                                                                                                                                   |
|       | CC0 port select register |       |        |                                                                                                                                                                                   |

**24.6.134 GPIO\_TIMER0\_CC1ROUTE - CC1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x688  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC1 pin select register</b>                                                                                                                                                    |
|       | CC1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC1 port select register</b>                                                                                                                                                   |
|       | CC1 port select register |       |        |                                                                                                                                                                                   |

**24.6.135 GPIO\_TIMER0\_CC2ROUTE - CC2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x68C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC2 pin select register</b>                                                                                                                                                    |
|       | CC2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC2 port select register</b>                                                                                                                                                   |
|       | CC2 port select register |       |        |                                                                                                                                                                                   |

**24.6.136 GPIO\_TIMER0\_CDTI0ROUTE - CDTI0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x690  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI0 pin select register</b>                                                                                                                                                  |
|       | CDTI0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI0 port select register</b>                                                                                                                                                 |
|       | CDTI0 port select register |       |        |                                                                                                                                                                                   |

**24.6.137 GPIO\_TIMER0\_CDTI1ROUTE - CDTI1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x694  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI1 pin select register</b>                                                                                                                                                  |
|       | CDTI1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI1 port select register</b>                                                                                                                                                 |
|       | CDTI1 port select register |       |        |                                                                                                                                                                                   |

**24.6.138 GPIO\_TIMER0\_CDTI2ROUTE - CDTI2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x698  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI2 pin select register</b>                                                                                                                                                  |
|       | CDTI2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI2 port select register</b>                                                                                                                                                 |
|       | CDTI2 port select register |       |        |                                                                                                                                                                                   |

## 24.6.139 GPIO\_TIMER1\_ROUTEEN - TIMER1 Pin Enable

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|-----|---|
| 0x6A0         | 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   |   |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 0x0 | 5 | 0x0 | 4 |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 0x0 | 3 | 0x0 | 2 |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 0x0 | 1 | 0x0 | 0 |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | CCC2PEN         | 0x0   | RW     | <b>CDTI2 pin enable control bit</b><br>CDTI2 pin enable control bit                                                                                                               |
| 4    | CCC1PEN         | 0x0   | RW     | <b>CDTI1 pin enable control bit</b><br>CDTI1 pin enable control bit                                                                                                               |
| 3    | CCC0PEN         | 0x0   | RW     | <b>CDTI0 pin enable control bit</b><br>CDTI0 pin enable control bit                                                                                                               |
| 2    | CC2PEN          | 0x0   | RW     | <b>CC2 pin enable control bit</b><br>CC2 pin enable control bit                                                                                                                   |
| 1    | CC1PEN          | 0x0   | RW     | <b>CC1 pin enable control bit</b><br>CC1 pin enable control bit                                                                                                                   |
| 0    | CC0PEN          | 0x0   | RW     | <b>CC0 pin enable control bit</b><br>CC0 pin enable control bit                                                                                                                   |

**24.6.140 GPIO\_TIMER1\_CC0ROUTE - CC0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6A4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC0 pin select register</b>                                                                                                                                                    |
|       | CC0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC0 port select register</b>                                                                                                                                                   |
|       | CC0 port select register |       |        |                                                                                                                                                                                   |

**24.6.141 GPIO\_TIMER1\_CC1ROUTE - CC1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6A8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC1 pin select register</b>                                                                                                                                                    |
|       | CC1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC1 port select register</b>                                                                                                                                                   |
|       | CC1 port select register |       |        |                                                                                                                                                                                   |

**24.6.142 GPIO\_TIMER1\_CC2ROUTE - CC2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6AC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC2 pin select register</b>                                                                                                                                                    |
|       | CC2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC2 port select register</b>                                                                                                                                                   |
|       | CC2 port select register |       |        |                                                                                                                                                                                   |

**24.6.143 GPIO\_TIMER1\_CDTI0ROUTE - CDTI0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6B0  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI0 pin select register</b>                                                                                                                                                  |
|       | CDTI0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI0 port select register</b>                                                                                                                                                 |
|       | CDTI0 port select register |       |        |                                                                                                                                                                                   |

**24.6.144 GPIO\_TIMER1\_CDTI1ROUTE - CDTI1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6B4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI1 pin select register</b>                                                                                                                                                  |
|       | CDTI1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI1 port select register</b>                                                                                                                                                 |
|       | CDTI1 port select register |       |        |                                                                                                                                                                                   |

**24.6.145 GPIO\_TIMER1\_CDTI2ROUTE - CDTI2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6B8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI2 pin select register</b>                                                                                                                                                  |
|       | CDTI2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI2 port select register</b>                                                                                                                                                 |
|       | CDTI2 port select register |       |        |                                                                                                                                                                                   |

## 24.6.146 GPIO\_TIMER2\_ROUTEEN - TIMER2 Pin Enable

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 0x6C0  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | CCC2PEN  | 0x0   | RW     | <b>CDTI2 pin enable control bit</b><br>CDTI2 pin enable control bit                                                                                                               |
| 4    | CCC1PEN  | 0x0   | RW     | <b>CDTI1 pin enable control bit</b><br>CDTI1 pin enable control bit                                                                                                               |
| 3    | CCC0PEN  | 0x0   | RW     | <b>CDTI0 pin enable control bit</b><br>CDTI0 pin enable control bit                                                                                                               |
| 2    | CC2PEN   | 0x0   | RW     | <b>CC2 pin enable control bit</b><br>CC2 pin enable control bit                                                                                                                   |
| 1    | CC1PEN   | 0x0   | RW     | <b>CC1 pin enable control bit</b><br>CC1 pin enable control bit                                                                                                                   |
| 0    | CC0PEN   | 0x0   | RW     | <b>CC0 pin enable control bit</b><br>CC0 pin enable control bit                                                                                                                   |

**24.6.147 GPIO\_TIMER2\_CC0ROUTE - CC0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6C4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC0 pin select register</b>                                                                                                                                                    |
|       | CC0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC0 port select register</b>                                                                                                                                                   |
|       | CC0 port select register |       |        |                                                                                                                                                                                   |

**24.6.148 GPIO\_TIMER2\_CC1ROUTE - CC1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6C8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC1 pin select register</b>                                                                                                                                                    |
|       | CC1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC1 port select register</b>                                                                                                                                                   |
|       | CC1 port select register |       |        |                                                                                                                                                                                   |

**24.6.149 GPIO\_TIMER2\_CC2ROUTE - CC2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x6CC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC2 pin select register</b>                                                                                                                                                    |
|       | CC2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC2 port select register</b>                                                                                                                                                   |
|       | CC2 port select register |       |        |                                                                                                                                                                                   |

**24.6.150 GPIO\_TIMER2\_CDTI0ROUTE - CDTI0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x6D0  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI0 pin select register</b>                                                                                                                                                  |
|       | CDTI0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI0 port select register</b>                                                                                                                                                 |
|       | CDTI0 port select register |       |        |                                                                                                                                                                                   |

**24.6.151 GPIO\_TIMER2\_CDTI1ROUTE - CDTI1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6D4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI1 pin select register</b>                                                                                                                                                  |
|       | CDTI1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI1 port select register</b>                                                                                                                                                 |
|       | CDTI1 port select register |       |        |                                                                                                                                                                                   |

**24.6.152 GPIO\_TIMER2\_CDTI2ROUTE - CDTI2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6D8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI2 pin select register</b>                                                                                                                                                  |
|       | CDTI2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI2 port select register</b>                                                                                                                                                 |
|       | CDTI2 port select register |       |        |                                                                                                                                                                                   |

## 24.6.153 GPIO\_TIMER3\_ROUTEEN - TIMER3 Pin Enable

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|
| 0x6E0  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | CCC2PEN  | 0x0   | RW     | <b>CDTI2 pin enable control bit</b><br>CDTI2 pin enable control bit                                                                                                               |
| 4    | CCC1PEN  | 0x0   | RW     | <b>CDTI1 pin enable control bit</b><br>CDTI1 pin enable control bit                                                                                                               |
| 3    | CCC0PEN  | 0x0   | RW     | <b>CDTI0 pin enable control bit</b><br>CDTI0 pin enable control bit                                                                                                               |
| 2    | CC2PEN   | 0x0   | RW     | <b>CC2 pin enable control bit</b><br>CC2 pin enable control bit                                                                                                                   |
| 1    | CC1PEN   | 0x0   | RW     | <b>CC1 pin enable control bit</b><br>CC1 pin enable control bit                                                                                                                   |
| 0    | CC0PEN   | 0x0   | RW     | <b>CC0 pin enable control bit</b><br>CC0 pin enable control bit                                                                                                                   |

#### 24.6.154 GPIO\_TIMER3\_CC0ROUTE - CC0 Port/Pin Select

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC0 pin select register</b>                                                                                                                                                    |
|       | CC0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC0 port select register</b>                                                                                                                                                   |
|       | CC0 port select register |       |        |                                                                                                                                                                                   |

#### 24.6.155 GPIO\_TIMER3\_CC1ROUTE - CC1 Port/Pin Select

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC1 pin select register</b>                                                                                                                                                    |
|       | CC1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC1 port select register</b>                                                                                                                                                   |
|       | CC1 port select register |       |        |                                                                                                                                                                                   |

**24.6.156 GPIO\_TIMER3\_CC2ROUTE - CC2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x6EC  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC2 pin select register</b>                                                                                                                                                    |
|       | CC2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC2 port select register</b>                                                                                                                                                   |
|       | CC2 port select register |       |        |                                                                                                                                                                                   |

**24.6.157 GPIO\_TIMER3\_CDTI0ROUTE - CDTI0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |      |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|------|---|---|---|---|---|
| 0x6F0  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0 |      |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW  |      |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PIN | PORT |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI0 pin select register</b>                                                                                                                                                  |
|       | CDTI0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI0 port select register</b>                                                                                                                                                 |
|       | CDTI0 port select register |       |        |                                                                                                                                                                                   |

**24.6.158 GPIO\_TIMER3\_CDTI1ROUTE - CDTI1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6F4  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset                                                                                                                                                                      | Access | Description                       |
|-------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------|
| 31:20 | Reserved                   | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                   |
| 19:16 | PIN                        | 0x0                                                                                                                                                                        | RW     | <b>CDTI1 pin select register</b>  |
|       | CDTI1 pin select register  |                                                                                                                                                                            |        |                                   |
| 15:2  | Reserved                   | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                   |
| 1:0   | PORT                       | 0x0                                                                                                                                                                        | RW     | <b>CDTI1 port select register</b> |
|       | CDTI1 port select register |                                                                                                                                                                            |        |                                   |

**24.6.159 GPIO\_TIMER3\_CDTI2ROUTE - CDTI2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x6F8  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset                                                                                                                                                                      | Access | Description                       |
|-------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------|
| 31:20 | Reserved                   | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                   |
| 19:16 | PIN                        | 0x0                                                                                                                                                                        | RW     | <b>CDTI2 pin select register</b>  |
|       | CDTI2 pin select register  |                                                                                                                                                                            |        |                                   |
| 15:2  | Reserved                   | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                   |
| 1:0   | PORT                       | 0x0                                                                                                                                                                        | RW     | <b>CDTI2 port select register</b> |
|       | CDTI2 port select register |                                                                                                                                                                            |        |                                   |

## 24.6.160 GPIO\_TIMER4\_ROUTEEN - TIMER4 Pin Enable

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |   |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|---|--|
| 0x700  | 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 |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 5 |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 3 |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CCC2PEN | 1 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CCC1PEN | 0 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CCC0PEN | 0 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CC2PEN  | 2 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CC1PEN  | 1 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CC0PEN  | 0 |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5    | CCC2PEN  | 0x0   | RW     | <b>CDTI2 pin enable control bit</b><br>CDTI2 pin enable control bit                                                                                                               |
| 4    | CCC1PEN  | 0x0   | RW     | <b>CDTI1 pin enable control bit</b><br>CDTI1 pin enable control bit                                                                                                               |
| 3    | CCC0PEN  | 0x0   | RW     | <b>CDTI0 pin enable control bit</b><br>CDTI0 pin enable control bit                                                                                                               |
| 2    | CC2PEN   | 0x0   | RW     | <b>CC2 pin enable control bit</b><br>CC2 pin enable control bit                                                                                                                   |
| 1    | CC1PEN   | 0x0   | RW     | <b>CC1 pin enable control bit</b><br>CC1 pin enable control bit                                                                                                                   |
| 0    | CC0PEN   | 0x0   | RW     | <b>CC0 pin enable control bit</b><br>CC0 pin enable control bit                                                                                                                   |

**24.6.161 GPIO\_TIMER4\_CC0ROUTE - CC0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x704  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC0 pin select register</b>                                                                                                                                                    |
|       | CC0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC0 port select register</b>                                                                                                                                                   |
|       | CC0 port select register |       |        |                                                                                                                                                                                   |

**24.6.162 GPIO\_TIMER4\_CC1ROUTE - CC1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x708  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC1 pin select register</b>                                                                                                                                                    |
|       | CC1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC1 port select register</b>                                                                                                                                                   |
|       | CC1 port select register |       |        |                                                                                                                                                                                   |

**24.6.163 GPIO\_TIMER4\_CC2ROUTE - CC2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x70C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CC2 pin select register</b>                                                                                                                                                    |
|       | CC2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CC2 port select register</b>                                                                                                                                                   |
|       | CC2 port select register |       |        |                                                                                                                                                                                   |

**24.6.164 GPIO\_TIMER4\_CDTI0ROUTE - CDTI0 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x710  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI0 pin select register</b>                                                                                                                                                  |
|       | CDTI0 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI0 port select register</b>                                                                                                                                                 |
|       | CDTI0 port select register |       |        |                                                                                                                                                                                   |

**24.6.165 GPIO\_TIMER4\_CDTI1ROUTE - CDTI1 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x714  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI1 pin select register</b>                                                                                                                                                  |
|       | CDTI1 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI1 port select register</b>                                                                                                                                                 |
|       | CDTI1 port select register |       |        |                                                                                                                                                                                   |

**24.6.166 GPIO\_TIMER4\_CDTI2ROUTE - CDTI2 Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x718  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                        | 0x0   | RW     | <b>CDTI2 pin select register</b>                                                                                                                                                  |
|       | CDTI2 pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                       | 0x0   | RW     | <b>CDTI2 port select register</b>                                                                                                                                                 |
|       | CDTI2 port select register |       |        |                                                                                                                                                                                   |

## 24.6.167 GPIO\_USART0\_ROUTEEN - USART0 Pin Enable

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|
| 0x720         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 4 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 3 |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 2 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 1 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |   |

| Bit  | Name                        | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | <i>Reserved</i>             |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | TXPEN                       | 0x0   | RW     | <b>TX pin enable control bit</b>                                                                                                                                                  |
|      | TX pin enable control bit   |       |        |                                                                                                                                                                                   |
| 3    | CLKPEN                      | 0x0   | RW     | <b>SCLK pin enable control bit</b>                                                                                                                                                |
|      | SCLK pin enable control bit |       |        |                                                                                                                                                                                   |
| 2    | RXPEN                       | 0x0   | RW     | <b>RX pin enable control bit</b>                                                                                                                                                  |
|      | RX pin enable control bit   |       |        |                                                                                                                                                                                   |
| 1    | RTSPEN                      | 0x0   | RW     | <b>RTS pin enable control bit</b>                                                                                                                                                 |
|      | RTS pin enable control bit  |       |        |                                                                                                                                                                                   |
| 0    | CSPEN                       | 0x0   | RW     | <b>CS pin enable control bit</b>                                                                                                                                                  |
|      | CS pin enable control bit   |       |        |                                                                                                                                                                                   |

**24.6.168 GPIO\_USART0\_CSROUTE - CS Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x724  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>CS pin select register</b>                                                                                                                                                     |
|       | CS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>CS port select register</b>                                                                                                                                                    |
|       | CS port select register |       |        |                                                                                                                                                                                   |

**24.6.169 GPIO\_USART0\_CTSROUTE - CTS Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x728  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>CTS pin select register</b>                                                                                                                                                    |
|       | CTS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>CTS port select register</b>                                                                                                                                                   |
|       | CTS port select register |       |        |                                                                                                                                                                                   |

#### 24.6.170 GPIO\_USART0\_RTSPROUTE - RTS Port/Pin Select

| Bit   | Name                     | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                      | 0x0   | RW     | <b>RTS pin select register</b>                                                                                                                                                    |
|       | RTS pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                 |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                     | 0x0   | RW     | <b>RTS port select register</b>                                                                                                                                                   |
|       | RTS port select register |       |        |                                                                                                                                                                                   |

## 24.6.171 GPIO\_USART0\_RXROUTE - RX Port/Pin Select

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN      | 0x0   | RW     | <b>RX pin select register</b>                                                                                                                                                     |
|       |          |       |        | RX pin select register                                                                                                                                                            |
| 15:2  | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT     | 0x0   | RW     | <b>RX port select register</b>                                                                                                                                                    |
|       |          |       |        | RX port select register                                                                                                                                                           |

**24.6.172 GPIO\_USART0\_CLKROUTE - SCLK Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x734  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                      | Reset | Access | Description                                                                                                                                                                       |
|-------|---------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                       | 0x0   | RW     | <b>SCLK pin select register</b>                                                                                                                                                   |
|       | SCLK pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                      | 0x0   | RW     | <b>SCLK port select register</b>                                                                                                                                                  |
|       | SCLK port select register |       |        |                                                                                                                                                                                   |

**24.6.173 GPIO\_USART0\_TXROUTE - TX Port/Pin Select**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x738  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0x0  |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   | PIN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | PORT |   |   |   |   |   |   |

| Bit   | Name                    | Reset | Access | Description                                                                                                                                                                       |
|-------|-------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 19:16 | PIN                     | 0x0   | RW     | <b>TX pin select register</b>                                                                                                                                                     |
|       | TX pin select register  |       |        |                                                                                                                                                                                   |
| 15:2  | Reserved                |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1:0   | PORT                    | 0x0   | RW     | <b>TX port select register</b>                                                                                                                                                    |
|       | TX port select register |       |        |                                                                                                                                                                                   |

## 25. LDMA - Linked DMA



### Quick Facts

#### What?

The LDMA controller can move data without CPU intervention, effectively reducing the energy consumption for a data transfer.

#### Why?

The LDMA can perform data transfers more energy efficiently than the CPU and allows autonomous operation in low energy modes.

#### How?

The LDMA controller has multiple highly configurable, prioritized DMA channels. A linked list of flexible descriptors makes it possible to tailor the controller to the specific needs of an application.

### 25.1 Introduction

The Linked Direct Memory Access (LDMA) controller performs memory transfer operations independently of the CPU. This has the benefit of reducing the energy consumption and the workload of the CPU, and enables the system to stay in low energy modes while still routing data to memory and peripherals. For example, moving data from the ADC to memory.

### 25.1.1 Features

- Flexible Source and Destination transfers
  - Memory-to-memory
  - Memory-to-peripheral
  - Peripheral-to-memory
  - Peripheral-to-peripheral
- DMA transfers triggered by peripherals, software, or linked list
- Single or multiple data transfers for each peripheral or software request
- Inter-channel and hardware event synchronization via trigger and wait functions
- Supports single or multiple descriptors
  - Single descriptor
  - Linked list of descriptors
  - Circular and ping-pong buffers
  - Scatter-Gather
  - Looping
  - Pause and restart triggered by other channels
  - Sophisticated flow control which can function without CPU interaction
- Channel arbitration includes:
  - Fixed priority
  - Simple round robin
  - Round robin with programmable multiple interleaved entries for higher priority requesters
- Programmable data size and source and destination address strides
- Programmable interrupt generation at the end of each DMA descriptor execution
- Little-endian/big-endian conversion
- DMA write-immediate function

## 25.2 Block Diagram

An overview of the LDMA and the modules it interacts with is shown in [Figure 25.1 LDMA Block Diagram on page 984](#).



**Figure 25.1. LDMA Block Diagram**

The Linked DMA Controller consists of three main parts

- A DMA core that executes transfers and communicates status to the core
- A channel select block that routes peripheral DMA requests and acknowledge signals to the DMA
- A set of internal channel configuration registers for tracking the progress of each DMA channel

The DMA has access to all system memory through the AHB bus and the AHB->APB bridge. It can load channel descriptors from memory with no CPU intervention.

## 25.3 Functional Description

The Linked DMA Controller is highly flexible. It is capable of transferring data between peripherals and memory without involvement from the processor core. This can be used to increase system performance by off-loading the processor from copying large amounts of data or avoiding frequent interrupts to service peripherals needing more data or having available data. It can also be used to reduce the system energy consumption by making the LDMA work autonomously with some EM2/3 peripherals for data transfer without having to wake up the processor core from sleep.

The Linked DMA Controller has 8 independent channels. Each of these channels can be connected to any of the available peripheral DMA transfer request input sources by writing to the channel configuration registers, see [25.3.2 Channel Configuration](#). In addition, each channel can also be triggered directly by software, which is useful for memory-to-memory transfers.

The channel descriptors determine what the Linked DMA Controller will do when it receives DMA transfer request. The initial descriptor is written directly to the LDMA's channel registers. If desired, the initial descriptor can link to additional linked descriptors stored in memory (RAM or Flash). Alternatively, software may also load the initial descriptor by writing the descriptor address to the LDMA\_CHx\_LINK register and then setting the corresponding bit the LDMA\_LINKLOAD register.

Before enabling a channel, the software must take care to properly configure the channel registers including the link address and any linked descriptors. When a channel is triggered, the Linked DMA Controller will perform the memory transfers as specified by the descriptors. A descriptor contains the memory address to read from, the memory address to write to, link address of the next descriptor, the number of bytes to be transferred, etc. The channel descriptor is described in detail in [25.3.7 Channel Descriptor Data Structure](#).

The Linked DMA Controller supports both fixed priority and round robin arbitration. The number of fixed and round robin channels is programmable. For round robin channels, the number of arbitration slots requested for each channel is programmable. Using this scheme, it is possible to ensure that timing-critical transfers are serviced on time.

DMA transfers take place by reading a block of data at a time from the source, storing it in the LDMA's local FIFO, then writing the block out to the destination from the FIFO. Interrupts may optionally be signaled to the CPU's interrupt controller at the end of any DMA transfer or at the completion of a descriptor if the DONEIFSEN bit is set. An AHB error will always generate an interrupt.

### 25.3.1 Channel Descriptor

Each DMA channel has descriptor registers. A transfer can be initialized by software writing to the registers or by the DMA itself copying a descriptor from RAM to memory. When using a linked list of descriptors the first descriptor should be initialized by the CPU. The DMA itself will then copy linked descriptors to its descriptor registers as required. In addition to manually initializing the first transfer, software may also cause the LDMA to load the initial descriptor by writing the descriptor address to the LDMA\_CHx\_LINK register and then setting the corresponding bit the LDMA\_LINKLOAD register.

The contents of the descriptor registers are dynamically updated during the DMA transfer. The contents of descriptors in memory are not edited by the controller.

Some descriptor field values are only used for linked descriptors. For example, the SRCMODE and DSTMODE bits of the LDMA\_CHx\_CTRL registers determine if a linked descriptor is using relative or absolute addressing. Software writes to the address registers will always use absolute addressing and never set these bits. Therefore, these bits are read only.

#### 25.3.1.1 DMA Transfer Size

A DMA transfer is the smallest unit of data that can be transferred by the LDMA. The LDMA supports byte, half-word and word sized transfers. The SIZE field in the LDMA\_CHx\_CTRL register specifies the data width of one DMA transfer.

#### 25.3.1.2 Source/Destination Increments

The SRCINC and DSTINC in the LDMA\_CHx\_CTRL register determines the increment between DMA transfers. The increment is in units of DMA transfers and using an increment size of 1 will transfer contiguous bytes, half-words, or words depending on the value of the SIZE field. Multiple unit increments are useful for transferring or packing/unpacking aligned data. For example using an increment of 4 with a size of BYTE will transfer word aligned bytes. An increment of 2 units with a size of HALFWORD is suitable for the transfer of word aligned half-word data. The LDMA can also pack or unpack data by using a different increment size for source and destination. For example - to convert from word aligned byte data (unpacked) to contiguous byte data (packed), set the SIZE to BYTE, SRCINC to 4, and DSTINC to 1.

SIZE may also be set to NONE which will cause the LDMA to read or write the same location for every DMA transfer. This is useful for accessing peripheral FIFO or data registers.

### 25.3.1.3 Block Size

The block size defines the amount of data transferred in one arbitration. It consists of one or more DMA transfers. See [25.3.6.1 Arbitration Priority](#) for more details.

### 25.3.1.4 Transfer Count

The descriptor transfer count defines how many DMA transfers to perform. The number of bytes transferred by the descriptor will depend on both the transfer count XFERCNT and the SIZE field settings.  $\text{TOTAL\_BYTES} = \text{XFERCNT} * \text{SIZE}$

### 25.3.1.5 Descriptor List

A descriptor list consists of one or more descriptors which are executed serially. This list may be a simple sequence of descriptors, a loop of descriptors, or a combination of the two.

Each descriptor in the list can be one of several types.

- Single Transfer descriptor: Transfers TOTAL\_BYT $E$ S of data and then stops.
- Linked Transfer descriptor: Transfers TOTAL\_BYT $E$ S of data and then loads the next linked descriptor.
- Loop Transfer descriptor: Transfers TOTAL\_BYT $E$ S of data and performs loop control (see [25.3.2.2 Loop Counter](#)).
- Sync descriptor: Handle synchronization of the list with other entities (see [25.3.7.2 SYNC Descriptor Structure](#)).
- WRI descriptor: Writes a value to a location in memory (see [25.3.7.3 WRI Descriptor Structure](#)).

### 25.3.1.6 Addresses

Before initiating a transfer, software should write the source address, destination address, and if applicable the link address to the descriptor registers. Alternatively, software may load a descriptor from memory by writing the descriptor address to the LDMA\_CHx\_LINK register and setting the corresponding bit in the LDMA\_LINKLOAD register.

During a DMA transfer, the DMA source and destination address registers are pointers to the next transfer address. The LDMA will update the SRC and DST addresses after each transfer. If software halts a DMA transfer by clearing the enable bit, the SRC and DST addresses will indicate the next transfer address.

When a descriptor is finished the DMA will either halt or load the next (linked) descriptor depending on the value of the LINK field in the LDMA\_Chx\_LINK register. After loading a linked descriptor, the descriptor registers will reflect the content of the loaded descriptor. Note that the linked descriptor must be word aligned in memory. The two least significant bits of the LDMA\_CHx\_LINK register are used by the LINK and LINKMODE bits. The two least significant bits of the link address are always zero.

### 25.3.1.7 Addressing Modes

The DMA descriptors support absolute addressing or relative addressing. When using relative addressing, the offset is relative to the current contents of the respective address registers. Regardless of the descriptor addressing modes, the address registers always indicate the absolute address. For example, when loading a descriptor using relative SRC addressing, the LDMA will add the descriptor source address (offset) to the contents of the SRCADDR register (base address). After loading, the SRCADDR register will indicate the absolute address of the loaded descriptor.

The initial descriptor must use absolute addressing. The LDMA will ignore the DSTMODE, SRCMODE, and LINKMODE bits for the initial descriptor and interpret the addresses as absolute addresses.

Relative addressing is most useful for the link address. The initial descriptor will indicate the absolute address of the linked descriptors in memory. The linked descriptors might be an array of structures. In this case the offset between descriptors is constant and is always 4 words or 16 bytes (each descriptor has 4 words). The LINK address is not incremented or decremented after each transfer. Thus, a relative offset of 0x10 may be used for all linked descriptors.

The source and destination addresses also support relative addressing. When using relative addressing with the source or destination address registers, the LDMA adds the relative offset to the current contents of the respective address register. Since the source and destination addresses are normally incremented after each transfer, the final address will point to one unit past the last transfer. Thus, an offset of zero will give the next sequential data address.

See the example [25.4.6 2D Copy](#) for a common use of relative addressing.

### 25.3.1.8 Byte Swap

Enabling byte swap reverses the endianness of the incoming source data read into the LDMA's FIFO. Byte swap is only valid for transfer sizes of word and half-word. Note that linked structure reads are not byte swapped.



Figure 25.2. Word and Half-Word Endian Byte Swap Examples

### 25.3.1.9 DMA Size and Source/Destination Increment Programming

The DMA channels' SIZE, SRCINC, and DSTINC bit-fields are programmed to best utilize memory resources. They provide a means for memory packing and unpacking, as well as for matching the size of data being transmitted to or received from an IO peripheral. The following figure shows how 32-bit words of data are read from a memory source into the DMA's internal transfer FIFO, and then written out to the memory destination. The memory organization in bytes is shown as well as the first read to and write from the DMA's FIFO.



**Figure 25.3. Memory-to-Memory Transfer WORD Size Example**

The next example shows four variations of half-word sized transfers, with all possible combinations of half- and full-word source and destination increments. Note that when the size and source/destination increments are all configured for half-word, the resulting DMA transfer organization is equivalent to the full-word sized transfer in the previous example. The difference is that the half-word configuration requires twice as many DMA transfers.



#### Figure 25.4. Memory-to-Memory Transfer HALF Size Examples

Fields SRCINCSIGN and DSTINCSIGN allow for address decrement. These can be used to mirror an image, for example, in the pixel copy application.

### 25.3.2 Channel Configuration

Each DMA channel has associated configuration and loop counter registers for controlling direction of address increment , arbitration slots, and descriptor looping.

#### 25.3.2.1 Address Increment/Decrement

Normally DMA transfers increment the source and destination addresses after each DMA transfer. Each channel is also capable of decrementing the source and/or destination addresses after each DMA transfer. This may be useful for flipping an array or copying data from tail to head. For example, a data packet might be prepared as an array of data with increasing addresses and then transmitted from the highest address to the lowest address, from tail to head.

After reset the SRCINCSIGN and DSTINCSIGN bits in the LDMA\_CHx\_CFG register are cleared causing the source and destination addresses to increment after each transfer. If the SRCINCSIGN bit is set , the DMA will decrement the source address after each transfer. If the DSTINCSIGN bit in the LDMA\_CHx\_CFG register is set , the DMA will decrement the destination address after each transfer. Setting only one of these bits will flip the data. Setting both bits will copy from tail to head, but will not flip the data.

The SRCINCSIGN and DSTINCSIGN bits apply to all descriptors used by that channel. Software should take care to set the starting source and/or destination address to the highest data address when decrementing.

#### 25.3.2.2 Loop Counter

Each channel has a LDMA\_CHx\_LOOP register that includes a loop counter field. To use looping, software should initialize the loop counter with the desired number of repetitions before enabling the transfer. A descriptor with the DECLOOPCNT bit set to TRUE will repeat the loop and decrement the loop counter until LOOPCNT = 0.

For a looping descriptor, with DECLOOPCNT=1, the LINK address in the LDMA\_CHx\_LINK register is used as the loop address. While LOOPCNT is greater than zero, the descriptor will execute and then the LDMA will load the next descriptor using the address specified in the LDMA\_CHx\_LINK register. This feature enables looping of multiple descriptors. To repeat a single descriptor, the LINK address of the descriptor should point to itself.

After LOOPCNT reaches zero, if the LINK bit in the descriptor LINK word is clear the transfer stops. If the LINK bit is set, the LDMA will load the next sequential descriptor located immediately following the looping descriptor. The behavior of the LINK bit is different for a looping descriptor. This is necessary because the LINK address is re-purposed as the loop address for a looping descriptor.

Note that LOOPCNT sets the number of repeats, not the number of iterations. The total number of loop iterations will be LOOPCNT plus 1. Normally, the LOOPCNT should be set to one or more repeats.

Also note that because there is only one LOOPCNT per channel, software intervention is required to update the LOOPCNT if a sequence of transfers contains multiple loops. It is also possible to use a write immediate DMA data transfer to update the LDMA\_CHx\_LOOP register.

### 25.3.3 Channel Select Configuration

The channel select block determines which peripheral request signal connects to each DMA channel.

This configuration is done by software through the SOURCESEL and SIGSEL fields of the LDMA\_CHn\_REQSEL register. SOURCESEL selects the peripheral and SIGSEL picks which DMA request signals to use from the selected peripheral. Please refer to [25.5 LDMA Source Selection Details](#) for more information.

### 25.3.4 Starting a Transfer

A transfer may be started by software, a peripheral request, or a descriptor load.

Software may initiate a transfer by setting the bit for the desired channel in the LDMA\_SWREQ register. In this case the channel should set SOURCESEL to NONE to prevent unintentional triggering of the channel by a peripheral.

A peripheral may trigger the channel by configuring the peripheral source and signal as described in [25.3.3 Channel Select Configuration](#)

The LDMA may also be configured to begin a transfer immediately after a new descriptor is loaded by setting the STRUCTREQ field of the LDMA\_CHx\_CTRL register or descriptor word.

This configuration is done by software through the SOURCESEL and SIGSEL fields of the LDMA\_CHn\_REQSEL register. SOURCESEL selects the peripheral and SIGSEL picks which DMA request signals to use from the selected peripheral.

### 25.3.4.1 Peripheral Transfer Requests

By default peripherals issue a Single Request (SREQ) when any data is present. For peripherals with a data buffer or FIFO this occurs any time the FIFO is not empty. Upon receiving an SREQ the LDMA will perform one DMA transfer and stop till another request is made.

It is generally more efficient to wait for a peripheral to accumulate data and transfer in a burst. This both reduces overhead of the DMA engine and allows EM2 peripherals to save power by using the LDMA less often. To enable this, set the IGNORESREQ bit in the LDMA\_CHx\_CTRL register (or descriptor) which will cause the LDMA to ignore SREQs and wait for a full Request (REQ) signal before any data is transferred. For most peripherals with a FIFO the REQ signal is set when the FIFO is full, or a predetermined threshold has been reached. See the individual peripheral chapters for more information.

### 25.3.5 Managing Transfer Errors

LDMA transfer errors are normally managed using interrupts. Software should clear the ERROR flag in the bit in the LDMA\_IF register and enable error interrupts by setting the ERROR bit in the LDMA\_IEN register before initiating a DMA transfer.

The LDMA interrupt handler should check the ERROR flag bit in the LDMA\_IF register. If the ERROR flag bit is set, it should then read the CHERROR field in the LDMA\_STATUS register to determine the errant channel. The interrupt handler should reset the channel and clear the ERROR flag bit in the LDMA\_IF register before returning.

### 25.3.6 Arbitration

While multiple channels are configured simultaneously the LDMA engine can only be actively copying data for one channel at a time. Arbitration determines which channel is being serviced at any point in time. The LDMA will choose a channel through arbitration, transfer BLOCK\_SIZE elements of that channel and then arbitrate again choosing another channel to service. This allows high priority channels to be serviced while lower priority channels are in the middle of a transfer.

#### 25.3.6.1 Arbitration Priority

There are two modes in determining priority when the controller arbitrates: fixed priority and round robin priority.

In fixed priority mode, channel 0 has the highest priority. As the channel number increases, the priority decreases. When the LDMA controller is idle or when a transfer completes, the highest priority channel with an active request is granted the transfer. This mode guarantees smallest latency for the highest priority requesters. It is best suited for systems where peak bandwidth is well below LDMA controller's maximum ability to serve. The drawback of this mode is the possibility of starvation for lowest priority requesters.

In the round robin priority mode, each active requesting channel is serviced in the order of priority. A late arriving request on a higher priority channel will not get serviced until the next round. This mode minimizes the risk of starving low-priority latency-tolerant requesters. The drawback of this mode is higher risk of starving low-latency requesters.

The NUMFIXED field in the LDMA\_CTRL register determines which channels are fixed priority and which are round robin. Channels lower than NUMFIXED are fixed priority while those above it are round robin. A value of 0x0 implies all channels are round robin. A value of 0x4 implies channels 0 through 3 are fixed priority and 4 through 7 are round robin. A value of 7 implies that channels 0 through 6 are fixed and channel 7 is round robin. This is functionally equivalent to having 8 fixed priority channels.

Fixed priority channels always take priority over round robin. As long as NUMFIXED is greater than 0, there is a possibility that a higher priority channel can starve the remaining channels.

To address the drawbacks of using fixed priority or round robin priority the LDMA implements the concept of arbitration slots. This allows for channels to have high bandwidth and low latency while preventing starvation of latency tolerant low priority channels.

Each channel has a two bit ARBSLOT field in its LDM\_CHx\_CFG register. This field only applies to channels marked as round robin (determined by NUMFIXED). The channels in the same arbitration slot are treated equally with round robin scheduling. Channels marked with a higher arbitration slot will get serviced more frequently. By default all channels are placed in arbitration slot 1.

Every time the channels in slot 1 get serviced the channels in slot 2 get serviced twice, those in slot 4 get serviced 4 times, and those in slot 8 get serviced 7 times. The specific arbitration allocation can be seen by the following table. The highest arbitration slot is serviced every other arbitration cycle, allowing for low latency response. If there are no requests from channels in arbitration slot then that slot is immediately skipped.

**Table 25.1. Arbitration Slot Order**

| Arbslot order | 8 | 4 | 8 | 2 | 8 | 4 | 8 | 1 | 8 | 4 | 8 | 2 | 8 | 4 |
|---------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Arbslot1      |   |   |   |   |   |   |   | 1 |   |   |   |   |   |   |
| Arbslot2      |   |   |   | 1 |   |   |   |   |   |   |   | 1 |   |   |
| Arbslot4      |   | 1 |   |   |   | 1 |   |   |   | 1 |   |   |   | 1 |
| Arbslot8      | 1 |   | 1 |   | 1 |   | 1 |   | 1 |   | 1 |   | 1 |   |

The top row shows the order at which the arbitration slots are executed. The remaining part of the table shows a more visual interpretation of the arbitration order.

For example, if we have one low latency channel (CHNL0) and two latency tolerant channels (CHNL1 and CHNL2). We could use the following settings.

LDMA\_CTRL.NUMFIXED = 0; set round robin for all channels.

CHNL0\_CFG.ARBSLOTS = TWO;

CHNL1\_CFG.ARBSLOTS = ONE;

CHNL2\_CFG.ARBSLOTS = ONE;

If all channels are constantly requesting transfers, then the arbitration order is: CHNL0, CHNL1, CHNL0, CHNL2, CHNL0, CHNL1, CHNL0, CHNL2, CHNL0, etc

Note, there are no channels assigned to arbitration slot four or eight in this example, so those slots are skipped and the final sequence is ARBSLOT2, ARBSLOT1, ARBSLOT2, ARBSLOT1, etc...

Channel 1 and Channel 2 are selected in round robin order when arbitration slot 1 is executed.

If we replace the ARBSLOTS value for channel 0 with EIGHT, then the sequence would look like the following:

CHNL0, CHNL0, CHNL0, CHNL0, CHNL1, CHNL0, CHNL0, CHNL0, CHNL2, CHNL0, CHNL0, CHNL0, CHNL1, etc.

### 25.3.6.2 DMA Transfer Arbitration

In addition to the inter channel arbitration, software can configure when the controller arbitrates during a DMA transfer. This provides reduced latency to higher priority channels when configuring low priority transfers with more arbitration cycles.

The LDMA provides four bits that configure how many DMA transfers occur before it re-arbitrates. These bits are known as the BLOCKSIZE bits and they map to the arbitration rate as shown below. For example, if BLOCKSIZE = 4 then the arbitration rate is 6, that is, the controller arbitrates every 6 DMA transfers.

[Table 25.2 AHB Bus Transfer Arbitration Interval on page 993](#) lists the arbitration rates.

**Table 25.2. AHB Bus Transfer Arbitration Interval**

| BLOCKSIZE | Arbitrate After x DMA transfers |
|-----------|---------------------------------|
| 0         | x = 1                           |
| 1         | x = 2                           |
| 2         | x = 3                           |
| 3         | x = 4                           |
| 4         | x = 6                           |
| 5         | x = 8                           |
| 6         | x = 12                          |
| 7         | x = 16                          |
| 8         | x = 24                          |
| 9         | x = 32                          |
| 10        | x = 64                          |
| 11        | x = 128                         |
| 12        | x = 256                         |
| 13        | x = 512                         |
| 14        | x = 1024                        |
| 15        | x = lock                        |

**Note:** Software must take care not to assign a low-priority channel with a large BLOCKSIZE because this prevents the controller from servicing high-priority requests, until it re-arbitrates.

The number of DMA transfers that need to be done is specified by the user in XFERCNT. When XFERCNT > BLOCKSIZE and is not an integer multiple of BLOCKSIZE then the controller always performs sequences of BLOCKSIZE transfers until XFERCNT < BLOCKSIZE remain to be transferred. The controller performs the remaining XFERCNT transfers at the end of the DMA cycle.

Software must store the value of the BLOCKSIZE bits in the channel control data structure. See [25.3.7.1 XFER Descriptor Structure](#) for more information about the location of the BLOCKSIZE bits in the data structure.

### 25.3.7 Channel Descriptor Data Structure

Each channel descriptor consists of four 32-bit words:

- CTRL - control word contains information like transfer count and block size.
- SRC - source address points to where to copy data from
- DST - destination address points to where to copy data to
- LINK - link address points to where to load the next linked descriptor

These words map directly to the LDMA\_CHx\_CTRL, LDMA\_CHx\_SRC, LDMA\_CHx\_DST, and LDMA\_CHx\_LINK registers. The usage of the SRC and DST fields may differ depending on the structure type

There are three different types of descriptor data structures: **XFER**, **SYNC**, and **WRI**

**25.3.7.1 XFER Descriptor Structure**

This descriptor defines a typical data transfer which may be a Normal, Link, or Loop transfer.

Only this structure type can be written directly into LDMA's registers by the CPU. All descriptors may be linked to. Please refer to the register descriptions for additional information.

For specifying XFER structure type, set STRUCTTYPE to 0. Please see the peripheral register descriptions for information on the fields in this structure.

|      |     | Bit Position |    |         |    |        |    |        |    |      |    |            |    |            |    |         |    |           |    |           |    |          |    |          |    |           |   |      |
|------|-----|--------------|----|---------|----|--------|----|--------|----|------|----|------------|----|------------|----|---------|----|-----------|----|-----------|----|----------|----|----------|----|-----------|---|------|
|      |     | DSTMODE      | 31 | SRCMODE | 30 | DSTINC | 29 | SRCINC | 28 | SIZE | 27 | IGNORESREQ | 23 | DECLOOPCNT | 22 | REQMODE | 21 | DONEIFSEN | 20 | BLOCKSIZE | 18 | BYTESWAP | 15 | XFERCNT  | 10 | STRUCTREQ | 3 | LINK |
| SRC  | DST | SRCADDR      |    |         |    |        |    |        |    |      |    | DSTADDR    |    |            |    |         |    |           |    |           |    | LINKADDR |    | LINKMODE |    |           |   |      |
| LINK |     |              |    |         |    |        |    |        |    |      |    |            |    |            |    |         |    |           |    |           |    |          |    |          |    |           |   |      |

### 25.3.7.2 SYNC Descriptor Structure

This descriptor defines an intra-channel synchronizing structure. It allows the channel to wait for some external stimulus before continuing on to the next descriptor. This structure is also used to provide stimulus to another channel to indicate that it may continue.

For example channel 1 may be configured to transfer a header into a buffer while channel 2 is simultaneously transferring data into the same structure. When channel 1 has completed it can wait for a sync signal from channel 2 before transferring the now complete buffer to a peripheral.

Synch descriptors do nothing until a condition is met. The condition is formed by the SYNCTRIG field in the LDMA\_SYNC register and the MATCHEN and MATCHVAL fields of the descriptor. When  $(\text{SYNCTRIG} \& \text{MATCHEN}) == (\text{MATCHVAL} \& \text{MATCHEN})$  the next descriptor is loaded. In addition to waiting for the condition a Link descriptor can set or clear bits in SYNCTRIG to meet the conditions of another channel and cause it to continue. The CPU also has the ability to set and clear the SYNCTRIG bits from software.

This structure type can only be linked in from memory.

For specifying SYNC structure type, set STRUCTTYPE to 1.

| Name | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |            |   |   |   |   |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|------------|---|---|---|---|
|      | 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 |
| CTRL |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | STRUCTTYPE |   |   |   |   |
| SRC  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | STRUCTTYPE |   |   |   |   |
| DST  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | STRUCTTYPE |   |   |   |   |
| LINK | LINKADDR     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | LINKMODE   |   |   |   |   |

| Bit  | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | STRUCTTYPE | <b>Descriptor Type</b><br>This field indicates which type of descriptor this is. It must be 1 for a SYNC descriptor.                                                                                                                                                                                                                                                                                                                                                   |
| 20   | DONEIFSEN  | <b>Done if Set indicator</b><br>If set the interrupt flag will be set when descriptor completes.                                                                                                                                                                                                                                                                                                                                                                       |
| 15:8 | SYNCCLR    | <b>Sync Trigger Clear</b><br>This bit-field is used to clear corresponding bits within the SYNCTRIG field of the SYNC LDMA_SYNC register. To clear a given bit, a one should be loaded to the corresponding bit. Set is given priority over clear if both corresponding bits are loaded with a one. The sync trigger clear function can only be used when loaded from a linked structure. Alternately, the user can directly write the SYNCTRIG bit-field if required. |
| 7:0  | SYNCSET    | <b>Sync Trigger Set</b><br>This bit-field is used to set corresponding bits within the SYNCTRIG bit-field. To set a given bit, a one should be loaded to the corresponding bit. Set is given priority over clear if both corresponding bits are loaded with a one. The sync trigger set function can only be used when loaded from a linked structure. Alternately, the user can directly write the SYNCTRIG bit-field if required.                                    |
| 15:8 | MATCHEN    | <b>Sync Trigger Match Enable</b><br>This bit-field serves as the SYNCTRIG match enable. A sync match triggers the load of the next linked DMA structure as specified by link_mode, when: $(\text{SYNCTRIG} \& \text{MATCHEN}) == (\text{MATCHVAL} \& \text{MATCHEN})$ .                                                                                                                                                                                                |
| 7:0  | MATCHVAL   | <b>Sync Trigger Match Value</b>                                                                                                                                                                                                                                                                                                                                                                                                                                        |

This bit-field serves as the SYNCTRIG match value. A sync match triggers the load of the next linked DMA structure as specified by link\_mode, when:  $(\text{SYNCTRIG} \& \text{MATCHEN}) == (\text{MATCHVAL} \& \text{MATCHEN})$ .

### 25.3.7.3 WRI Descriptor Structure

This descriptor defines a write-immediate structure. This allows a list of descriptors to write a value to a register or memory location. For example, if a channel wishes to perform two loops in a descriptor sequence a WRI may be used to program the loop count for the second loop.

This structure type can only be linked in from memory.

For specifying WRI structure type, set STRUCTTYPE to 2.

|      |     | Name      | Bit Position |            |
|------|-----|-----------|--------------|------------|
| DST  | SRC |           | IMMVAL       |            |
| LINK |     |           | DSTADDR      |            |
|      |     |           | LINKADDR     |            |
| CTRL |     | DONEIFSEN | 20           | STRUCTTYPE |
|      |     |           | 19           | 1          |
|      |     |           | 18           | 0          |
|      |     |           | 17           |            |
|      |     |           | 16           |            |
|      |     |           | 15           |            |
|      |     |           | 14           |            |
|      |     |           | 13           |            |
|      |     |           | 12           |            |
|      |     |           | 11           |            |
|      |     |           | 10           |            |
|      |     |           | 9            |            |
|      |     |           | 8            |            |
|      |     |           | 7            |            |
|      |     |           | 6            |            |
|      |     |           | 5            |            |
|      |     |           | 4            |            |
|      |     |           | 3            |            |
|      |     |           | 2            |            |
|      |     |           | 1            |            |
|      |     |           | 0            |            |

| Bit  | Name       | Description                                                                                                                                                                                 |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | STRUCTTYPE | <b>Descriptor Type</b><br>This field indicates which type of descriptor this is. It must be 2 for a WRI descriptor.                                                                         |
| 20   | DONEIFSEN  | <b>Done if Set indicator</b><br>If set the interrupt flag will be set when descriptor completes.                                                                                            |
| 31:0 | IMMVAL     | <b>Immediate Value for Write</b><br>This bit-field specifies the immediate data value that is to be written to the address pointed to by DSTADDR. Only one write occurs for WRI structures. |
| 31:0 | DSTADDR    | <b>Address to write</b><br>This bit-field specifies the address the immediate data should be written to.                                                                                    |

### **25.3.8 Interaction with the EMU**

The LDMA interacts with the Energy Management Unit (EMU) to allow transfers from a low energy peripheral while in EM2.

When using the ADC in EM2 or EM3 the EMU can wake up the LDMA as needed to allow data transfers to occur.

### 25.3.9 Interrupts

The LDMA\_IF Interrupt flag register contains one DONE bit for each channel and one combined ERROR bit. When enabled, these interrupts are available as interrupts to the M33 core. They are combined into one interrupt vector, DMA\_INT. If the interrupt for the DMA is enabled in the ARM M33 core, an interrupt will be made if one or more of the interrupt flags in LDMA\_IF and their corresponding bits in LDMA\_IEN are set.

When a descriptor finishes execution the interrupt flag for that channel will be set if the DONEIFSEN field of the LDMA\_CHx\_LOOP register is set. If LINK and DONEIFSEN are both set when the descriptor completes the interrupt and the linked descriptor will be immediately loaded. When the final descriptor in a linked list (LINK = 0) is finished the interrupt flag is always set regardless of the state of DONEIFSEN.

### 25.3.10 Debugging

For a peripheral request DMA transfer, if software sets a bit for a channel in the LDMA\_DBGHALT register then the DMA will halt during a debug halt and the SRC and DST registers in the debug window will show the transfer in progress. Otherwise, during debug halt the DMA will continue to run and complete the entire transfer causing the descriptor registers to indicate the transfer has completed.

## 25.4 Examples

This section provides examples of common LDMA usage. All examples assume the LDMA is in the reset state with the channel being configured disabled and LDAM\_CHx\_CFG, LDMA\_CHx\_LOOP, and LDMA\_CHx\_LINK cleared.

### 25.4.1 Single Direct Register DMA Transfer

This simple example uses only the Channel Descriptor registers directly and does not use linking. Software writes directly to the LDMA channel registers. This example does not use a memory based descriptor list.

This example is suitable for most simple transfers that are limited to transferring one block of data. It supports anything that can be done using a single descriptor. This includes endian conversion and packing/unpacking data. Channel 0 is used for this example.

The LDMA will be used to copy 127 contiguous half words (254 bytes) from 0x0 to 0x1000. It will allow arbitration every 4 transfers and is triggered by a CPU write to the LDMA\_SWREQ register. The CH0 interrupt flag will be set when the transfer completes since the descriptor does not link to another descriptor.

- Configure LDMA\_CH0\_CTRL
  - DSTMODE = 0 (absolute)
  - SRCMODE = 0 (absolute)
  - SIZE = HALFWORD (16 bits)
  - DSTINC = 0 (1 half-word)
  - SRCINC = 0 (1 half-word)
  - DECLOOPCNT=0 (unused)
  - REQMODE = 1 (one request transfers all data)
  - BLOCKSIZE = 3 (4 transfers)
  - BYTESWAP=0 (no byte swap)
  - XFERCNT=127 (transfer 127 half words)
  - STRUCTTPYE=0 (TRANSFER)
- Write source address to LDMA\_CH0\_SRC register
- Write destination address to LDMA\_CH0\_DST register
- Configure the LDMA\_CH0REQSEL register for the desired peripheral or select none for a memory-to-memory transfer
- Clear and enable interrupts.
  - Write a 1 to bit 0 of the LDMA\_IFC register to clear the CH0 DONE flag
  - Write a 1 to bit 0 of the LDMA\_IEN register to enable the CH0 interrupt
- Write a 1 to bit 0 of the LDMA\_CHEN register to enable CH0

The REQMODE field is normally cleared to zero for a peripheral request transfer and will transfer the specified block size for each peripheral request. The REQMODE may be set to 1 for a memory-to-memory transfer or any time it is desired for a single DMA request to initiate complete transfer.

### 25.4.2 Descriptor Linked List

This example shows how to use a Linked List of descriptors. Each descriptor has a link address which points to the next descriptor in the list. A descriptor may be removed from the Linked list by altering the Link address of the one before it to point to the one after it. Descriptor Linked lists are useful when handling an array of buffers for communication data. For example, a bad packet can be removed from a receiver queue by simply removing the descriptor from the linked list.

Software loads the first descriptor into the DMA by writing the descriptor address to LDMA\_CHx\_LINK and setting the bit for that channel in the LDMA\_LINKLOAD register. This method is preferred when using a linked list in memory since it treats the first descriptor just like all the others. However, it is also allowed for software to write the first descriptor directly to the LDMA registers.

In this example 4 descriptors are executed in series. the interrupt flag is set after the 2nd and 4th (last) descriptors have completed.

- Prepare a list of descriptors using the XFER structure type in RAM
- Initialize the CTRL, SRC, and DST members as desired
  - Setting STRUCTREQ in the CTRL word for descriptors 2-4 will cause them to begin transferring data as soon as they are loaded.
- Write 0x00000013 to the LINK member of all but the last descriptor
  - LINKMODE = 1 (relative addressing)
  - LINK = 1 (Link to the next descriptor)
  - LINKADDR = 0x00000010 (size of descriptor)
- Set the DONEIFSEN bit in the CTRL member of the 2nd structure so that the interrupt flag will be set when it completes
- Write 0x00000000 to the LINK member of the last descriptor
  - LINK = 0 (Do not link to the next descriptor)
  - LINKMODE = 0 (don't care)
  - LINKADDR = 0x00000000 (don't care)

Each descriptor now points to the start of the next descriptor as shown on the left in [Figure 25.5 Descriptor Linked List on page 998](#). To remove a descriptor from the linked list modify the LINK address of the descriptor of the one before to point to the one after. For example to remove the third descriptor, add 0x00000010 to the LINK register of the second descriptor. The second descriptor will now point to the forth descriptor and skip over the third descriptor as shown on the right in [Figure 25.5 Descriptor Linked List on page 998](#).



**Figure 25.5. Descriptor Linked List**

To start execution of the linked list of descriptors:

- Write the absolute address of the first descriptor to the LINKADR field of the LDMA\_CH0\_LINK register
- Set the LINK bit of LDMA\_CH0\_LINK register.
- Configure the LDMA\_CH0REQSEL register for the desired peripheral or select none for memory-to-memory
- Clear and enable interrupts as desired
- Set bit 0 in the LDMA\_LINKLOAD register to initiate loading and execution of the first descriptor

Alternatively, software can manually copy the first descriptor contents to the LDMA\_CH0\_CTRL, LDMA\_CH0\_SRC, LDMA\_CH0\_DST, and LDMA\_CH0\_LINK registers and then enable the channel in the LDMA\_CHEN register.

### 25.4.3 Single Descriptor Looped Transfer

This example demonstrates how to use looping using a single descriptor. This method allows a single DMA transfer to be repeated a specified number of times. The looping descriptor is stored in memory and reloaded by hardware. After a specified number of iterations, the transfer stops.

CH0 is setup to copy 4 words from the ADC FIFO into a 15 word buffer at 0x1000. It repeats 4 times to fill the entire 16 word buffer. An interrupt will fire when the entire 16 words have been transferred.

Initialize the Linked descriptor in memory as follows:

- Configure CTRL member
  - DSTMODE = 0 (absolute)
  - SRCMODE = 0 (absolute)
  - SIZE = WORD
  - DSTINC = 0 (1 WORD)
  - SRCINC = 3 (0 WORDS)
  - DECLOOPCNT=1 (decrement loop count)
  - REQMODE=1 (Use XFERCNT)
  - BLOCKSIZE = 4 (4 words)
  - BYTESWAP=0 (no swap)
  - XFERCNT= 4 (4 words)
  - STRUCTTPYE=0 (TRANSFER)
  - IGNOREREQ=1 (ignore single requests)
- Write the address ADC0\_SINGLEDATA register to the SRC member
- Write 0x1000 address to DST member
- Configure the LINK member
  - LINK = 0 (stop after loop)
  - MODE = 1 (relative link address)
  - LINKADDR = 0 (point to ourself)
- Configure the Channel
  - Write the desired number of repeats to the LDMA\_CH0\_LOOP register
  - SOURCESEL in LDMA\_CH0REQSEL = ADC0 (select the ADC)
  - SIG in LDMA\_CH0REQSEL = ADC0SCAN (select the scan conversion request)
- Clear and enable interrupts
- Load the descriptor using LINKLOAD as described in [25.4.2 Descriptor Linked List](#)



**Figure 25.6. Single Descriptor Looped Transfer**

Note that the looping descriptor must be stored in memory, because it must load itself from the link address in memory on each iteration.

#### 25.4.4 Descriptor List with Looping

This example uses a descriptor list in memory with looping over multiple descriptors. This example also uses the looping feature and continues on with the next sequential descriptor after looping completes.

The descriptor list in memory is shown in figure [Figure 25.7 Descriptor List with Looping on page 1001](#). Descriptor A links to descriptor B. Descriptor B has the DECLOOPCNT bit enabled and loops back to the start of descriptor A. The LINK address of descriptor B is used for the loop address. The LINK bit is set to indicate that execution will continue after completion of looping. Once the LOOPCNT reaches zero, the LDMA will load descriptor C. Descriptor C must be located immediately following descriptor B.



**Figure 25.7. Descriptor List with Looping**

Initialization is similar to the single looping descriptor with the following modifications.

- Set the LINK bit in descriptors A and B
- write the address of descriptor A into the LIKADDRESS of descriptor B
- write the address of descriptor B into the LIKADDRESS of descriptor A
- Descriptor C must be located immediately after descriptor B in memory

#### 25.4.5 Simple Inter-Channel Synchronization

The LDMA controller features synchronization structures which allow differing channels and/or hardware events to pause a DMA sequence, and wait for a synchronizing event to restart it.

In this example DMA channel 0 and 1 are tasked with the transfer of different sets of data. Channel 0 has two transfer structures, and channel 1 just one, but channel 0 must wait until channel 1 has completed its transfer before it starts its second transfer structure.

Pausing channel 0 is accomplished by inserting a sync wait structure between the two transfer structures. This sync structure waits on SYNCTRIG[7] to be set by a sync set/clear structure which is controlled by channel 1. Sync structures do not transfer data, they can only set, clear, or wait to match the SYNCTRIG[7:0] bits. Note that sync structures cannot decrement loop counter.

```
LDMA_SYNC
SYNCTRIG=0x0 (at time 0)

LDMA_CH0

Structure A @ 0x00          Structure B @ 0x10          Structure C @ 0x20
CTRL                         CTRL                         CTRL
    STRUCTTYPE=XFER          STRUCTTYPE=SYNC          STRUCTTYPE=XFER
LINK                         LINK                         LINK
    LINKADDR[29:0]=0x00000004  LINKADDR[29:0]=0x00000008  LINKADDR[29:0]=NA
    LINK=1                     LINK=1                     LINK=0
DST
    MATCHEN=0x80
    MATCHVAL=0x80 (waits for SYNCTRIG[7]=1)

LDMA_CH1

Structure Y @ 0x30          Structure Z @ 0x40
CTRL                         CTRL
    STRUCTTYPE=XFER          STRUCTTYPE=SYNC
LINK                         LINK
    LINKADDR[29:0]=0x00000010  LINKADDR=NA
    LINK=1                     LINK=0
SRC
    SRCCLR=0x0
    SRCSET=0x80 (sets SYNCTRIG[7])
```



**Figure 25.8. Simple Intra-channel Synchronization Example**

Both A and Y effectively start at the same time. A finishes earlier, then it links to B, which waits for the SYNCTRIG[7] bit to be set before loading C. Y finishes after B is loaded, and it links to sync structure Z, which sets the SYNCTRIG[7] bit. Channel 0 responds to the trigger set by loading C for the final data transfer.

### 25.4.6 2D Copy

The LDMA can easily perform a 2D copy using a descriptor list with looping. This set up is visualized in [Figure 25.9 2D Copy on page 1004](#).

For an application working with graphics, this would mean the ability to copy a rectangle of a given width and height from one picture to another.



**Figure 25.9. 2D Copy**

The first descriptor will use absolute addressing mode and the source and destination addresses should point to the desired target addresses. The first descriptor will copy only the first row. The XFERCNT of the first descriptor is set to the desired width minus one.

- **CTRL**
  - XFERCNT = WIDTH - 1
  - SRCMD = 0 (absolute)
  - DSTMD = 0 (absolute)
- **SRCADDR** = target source address
- **DSTADDR** = target destination address
- **LINK** = 0x00000013
  - LINK=1
  - LINKMD=1
  - LINKADDR=0x00000010 (point to next descriptor)

The second descriptor will use relative addressing and the source and destination addresses are set to the desired offset. After the completion of the first descriptor, the address registers will point to the last address transferred. Thus, the width must be subtracted from the stride to get the offset. The second descriptor uses looping and the link register has no offset.

- **CTRL**
  - XFERCNT = WIDTH - 1
  - SRCMD = 1 (relative)
  - DSTMD = 1 (relative)
  - DECLOOPCNT = 1
- **SRCADDR** = desired source offset (SRCSTRIDE-WIDTH)
- **DSTADDR** = desired destination offset (DSTSTRIDE-WIDTH)
- **LINK** = 0x00000001
  - LINK=0
  - LINKMD=1 (relative)
  - LINKADDR=0x00000000 (no offset)

Because the first descriptor already transferred one row, the number of looping repeats should be the desired height minus two. Therefore, LOOPCNT should be set to HEIGHT minus two before initiating the transfer.

This same method is easily extended to copy multiple rectangles by linking descriptors together. To initialize the LDMA\_CHx\_LOOP register, precede each descriptor pair described above with a write immediate descriptor which writes the desired value to the LOOPCNT field of the LDMA\_CHx\_LOOP register.

### 25.4.7 Ping-Pong

Communication peripherals often use ping-pong buffers. Ping-pong buffers allow the CPU to process data in one buffer while a peripheral transmits or receives data in the other buffer.

Both transmit and receive ping-pong buffers are easily implemented using the LDMA. In either case, this requires two descriptors as shown in [Figure 25.10 Infinite Ping-Pong Example on page 1006](#). The LINKADDR field of the LINK member should point to the other descriptor. Using two adjacent descriptors and relative link addressing ensures the descriptors are easily reloadable.



Figure 25.10. Infinite Ping-Pong Example

A **receiver** ping-pong buffer controller consists of two buffers and two descriptors stored in memory that point to the two buffers. Once initialized, as the peripheral receives data, it will fill the first buffer. Once the first buffer is full, it will link automatically to the second buffer and generate an interrupt. Software will then process the data in the first buffer while the LDMA is transferring data to the second buffer. For a receiver ping-pong buffer each descriptor should link to the other descriptor. The link bit should be set to provide infinite ping pong between the two buffers. The DONIFS bit in each descriptor should be set to generate an interrupt on the completion of each descriptor.

- Descriptor A
  - CTRL
    - DONEIFS = 1
    - other settings as desired
  - SRCADDR = peripheral source address
  - DSTADDR = memory destination address
  - LINK = 0x00000013
    - LINKADDR = 0x00000010 (next descriptor)
    - LINK = 1 (link to next descriptor)
    - LINKMD = 1 (relative addressing)
- Descriptor B
  - CTRL
    - DONEIFS = 1
    - other settings as desired
  - SRCADDR = peripheral source address
  - DSTADDR = memory destination address
  - LINK = 0xFFFFFFF3
    - LINKADDR = 0xFFFFFFF0 (previous descriptor)
    - LINK = 1 (link to previous descriptor)
    - LINKMD = 1 (relative addressing)

For **transmitter** ping-pong buffer, software will fill the first buffer and then initiate the DMA transfer. The LDMA will transmit the first buffer data while software is filling the second buffer. In this case, the two descriptors should point to each other, but not automatically

continue to the second buffer. The LINK bit should be cleared to zero. Once software has loaded the first buffer, it will use the LINK-LOAD bit to load the first descriptor and transmit the data. The DONIFS need not be set in each descriptor. The DMA will stop and then generate an interrupt at the completion of each descriptor.

- Descriptor A
  - CTRL
    - DONEIFS = 0
    - other settings as desired
  - SRCADDR = memory source address
  - DSTADDR = peripheral destination address
  - LINK = 0x00000013
    - LINKADDR = 0x00000010 (next descriptor)
    - LINK = 0 (link to next descriptor)
    - LINKMD = 1 (relative addressing)
- Descriptor B
  - CTRL
    - DONEIFS = 0
    - other settings as desired
  - SRCADDR = memory source address
  - DSTADDR = peripheral destination address
  - LINK = 0xFFFFFFFF3
    - LINKADDR = 0xFFFFFFFF0 (previous descriptor)
    - LINK = 0 (link to previous descriptor)
    - LINKMD = 1 (relative addressing)

#### 25.4.8 Scatter-Gather

Scatter-Gather in general refers to a process that copies data from multiple locations scattered in memory and gathers the data to a single location in memory, or vice versa. A simple descriptor list allows data gathering. For example, data from a discontiguous list of buffers might be copied to a contiguous sequential array of buffers. The inverse is also possible when a sequential array of buffers is scattered to a discontiguous list of available buffers. See section [25.4.2 Descriptor Linked List](#).

Some DMAs which only have two descriptors implement scatter-gather by using one descriptor to modify the other descriptor. While it is possible to implement this same behavior using the LDMA, it is much more straight-forward to just use a simple descriptor list.

#### 25.5 LDMA Source Selection Details

## 25.5.1 LDMA Source Selection Details

Table 25.3. LDMA Source Selection Details

| SOURCESEL | Source Name | SIGSEL | Request Signal Name |
|-----------|-------------|--------|---------------------|
| 0x1       | LDMAXBAR    | 0x0    | LDMAXBARPRSREQ0     |
|           |             | 0x1    | LDMAXBARPRSREQ1     |
| 0x2       | TIMER0      | 0x0    | TIMER0CC0           |
|           |             | 0x1    | TIMER0CC1           |
|           |             | 0x2    | TIMER0CC2           |
|           |             | 0x3    | TIMER0UFOF          |
| 0x3       | TIMER1      | 0x0    | TIMER1CC0           |
|           |             | 0x1    | TIMER1CC1           |
|           |             | 0x2    | TIMER1CC2           |
|           |             | 0x3    | TIMER1UFOF          |
| 0x4       | USART0      | 0x0    | USART0RXDATAV       |
|           |             | 0x1    | USART0RXDATAVRIGHT  |
|           |             | 0x2    | USART0TXBL          |
|           |             | 0x3    | USART0TXBLRIGHT     |
|           |             | 0x4    | USART0TXEMPTY       |
| 0x5       | I2C0        | 0x0    | I2C0RXDATAV         |
|           |             | 0x1    | I2C0TXBL            |
| 0x6       | I2C1        | 0x0    | I2C1RXDATAV         |
|           |             | 0x1    | I2C1TXBL            |
| 0xA       | IADC0       | 0x0    | IADC0IADC_SCAN      |
|           |             | 0x1    | IADC0IADC_SINGLE    |
| 0xB       | MSC         | 0x0    | MSCWDATA            |
| 0xC       | TIMER2      | 0x0    | TIMER2CC0           |
|           |             | 0x1    | TIMER2CC1           |
|           |             | 0x2    | TIMER2CC2           |
|           |             | 0x3    | TIMER2UFOF          |
| 0xD       | TIMER3      | 0x0    | TIMER3CC0           |
|           |             | 0x1    | TIMER3CC1           |
|           |             | 0x2    | TIMER3CC2           |
|           |             | 0x3    | TIMER3UFOF          |
| 0xE       | TIMER4      | 0x0    | TIMER4CC0           |
|           |             | 0x1    | TIMER4CC1           |
|           |             | 0x2    | TIMER4CC2           |
|           |             | 0x3    | TIMER4UFOF          |

| SOURCESEL | Source Name | SIGSEL | Request Signal Name |
|-----------|-------------|--------|---------------------|
| 0xF       | EUSART0     | 0x0    | EUSART0RXFL         |
|           |             | 0x1    | EUSART0TXFL         |
| 0x10      | EUSART1     | 0x0    | EUSART1RXFL         |
|           |             | 0x1    | EUSART1TXFL         |
| 0x11      | VDAC0       | 0x0    | VDAC0CH0_REQ        |
|           |             | 0x1    | VDAC0CH1_REQ        |
| 0x12      | VDAC1       | 0x0    | VDAC1CH0_REQ        |
|           |             | 0x1    | VDAC1CH1_REQ        |

## 25.6 LDMA Register Map

The offset register address is relative to the registers base address.

| Offset | Name               | Type        | Description                              |
|--------|--------------------|-------------|------------------------------------------|
| 0x000  | LDMA_IPVERSION     | R           | IP Version                               |
| 0x004  | LDMA_EN            | RW          | DMA Module Enable Disable Register       |
| 0x008  | LDMA_CTRL          | RW          | DMA Control Register                     |
| 0x00C  | LDMA_STATUS        | RH          | DMA Status Register                      |
| 0x010  | LDMA_SYNCSET       | W           | DMA Sync Trig Sw Set Register            |
| 0x014  | LDMA_SYNCCLR       | W           | DMA Sync Trig Sw Clear Register          |
| 0x018  | LDMA_SYNCHWEN      | RW          | DMA Sync HW Trigger Enable Register      |
| 0x01C  | LDMA_SYNCHWSEL     | RW          | DMA Sync HW Trigger Selection Register   |
| 0x020  | LDMA_SYNCSTATUS    | RH          | DMA Sync Trigger Status Register         |
| 0x024  | LDMA_CHEN          | W           | DMA Channel Enable Register              |
| 0x028  | LDMA_CHDIS         | W           | DMA Channel Disable Register             |
| 0x02C  | LDMA_CHSTATUS      | RH          | DMA Channel Status Register              |
| 0x030  | LDMA_CHBUSY        | RH          | DMA Channel Busy Register                |
| 0x034  | LDMA_CHDONE        | RWH INTFLAG | DMA Channel Linking Done Register        |
| 0x038  | LDMA_DBGHALT       | RW          | DMA Channel Debug Halt Register          |
| 0x03C  | LDMA_SWREQ         | W           | DMA Channel Software Transfer Request    |
| 0x040  | LDMA_REQDIS        | RW          | DMA Channel Request Disable Register     |
| 0x044  | LDMA_REQPEND       | RH          | DMA Channel Requests Pending Register    |
| 0x048  | LDMA_LINKLOAD      | W           | DMA Channel Link Load Register           |
| 0x04C  | LDMA_REQCLEAR      | W           | DMA Channel Request Clear Register       |
| 0x050  | LDMA_IF            | RWH INTFLAG | Interrupt Flag Register                  |
| 0x054  | LDMA_IEN           | RW          | Interrupt Enable Register                |
| 0x05C  | LDMA_CHx_CFG       | RW          | Channel Configuration Register           |
| 0x060  | LDMA_CHx_LOOP      | RWH         | Channel Loop Counter Register            |
| 0x064  | LDMA_CHx_CTRL      | RWH         | Channel Descriptor Control Word Register |
| 0x068  | LDMA_CHx_SRC       | RWH         | Channel Descriptor Source Address        |
| 0x06C  | LDMA_CHx_DST       | RWH         | Channel Descriptor Destination Address   |
| 0x070  | LDMA_CHx_LINK      | RWH         | Channel Descriptor Link Address          |
| 0x1000 | LDMA_IPVERSION_SET | R           | IP Version                               |
| 0x1004 | LDMA_EN_SET        | RW          | DMA Module Enable Disable Register       |
| 0x1008 | LDMA_CTRL_SET      | RW          | DMA Control Register                     |
| 0x100C | LDMA_STATUS_SET    | RH          | DMA Status Register                      |
| 0x1010 | LDMA_SYNCSET_SET   | W           | DMA Sync Trig Sw Set Register            |
| 0x1014 | LDMA_SYNCCLR_SET   | W           | DMA Sync Trig Sw Clear Register          |
| 0x1018 | LDMA_SYNCHWEN_SET  | RW          | DMA Sync HW Trigger Enable Register      |

| Offset | Name                | Type        | Description                              |
|--------|---------------------|-------------|------------------------------------------|
| 0x101C | LDMA_SYNCHWSEL_SET  | RW          | DMA Sync HW Trigger Selection Register   |
| 0x1020 | LDMA_SYNCSTATUS_SET | RH          | DMA Sync Trigger Status Register         |
| 0x1024 | LDMA_CHEN_SET       | W           | DMA Channel Enable Register              |
| 0x1028 | LDMA_CHDIS_SET      | W           | DMA Channel Disable Register             |
| 0x102C | LDMA_CHSTATUS_SET   | RH          | DMA Channel Status Register              |
| 0x1030 | LDMA_CHBUSY_SET     | RH          | DMA Channel Busy Register                |
| 0x1034 | LDMA_CHDONE_SET     | RWH INTFLAG | DMA Channel Linking Done Register        |
| 0x1038 | LDMA_DBGHALT_SET    | RW          | DMA Channel Debug Halt Register          |
| 0x103C | LDMA_SWREQ_SET      | W           | DMA Channel Software Transfer Request    |
| 0x1040 | LDMA_REQDIS_SET     | RW          | DMA Channel Request Disable Register     |
| 0x1044 | LDMA_REQPEND_SET    | RH          | DMA Channel Requests Pending Register    |
| 0x1048 | LDMA_LINKLOAD_SET   | W           | DMA Channel Link Load Register           |
| 0x104C | LDMA_REQCLEAR_SET   | W           | DMA Channel Request Clear Register       |
| 0x1050 | LDMA_IF_SET         | RWH INTFLAG | Interrupt Flag Register                  |
| 0x1054 | LDMA_IEN_SET        | RW          | Interrupt Enable Register                |
| 0x105C | LDMA_CHx_CFG_SET    | RW          | Channel Configuration Register           |
| 0x1060 | LDMA_CHx_LOOP_SET   | RWH         | Channel Loop Counter Register            |
| 0x1064 | LDMA_CHx_CTRL_SET   | RWH         | Channel Descriptor Control Word Register |
| 0x1068 | LDMA_CHx_SRC_SET    | RWH         | Channel Descriptor Source Address        |
| 0x106C | LDMA_CHx_DST_SET    | RWH         | Channel Descriptor Destination Address   |
| 0x1070 | LDMA_CHx_LINK_SET   | RWH         | Channel Descriptor Link Address          |
| 0x2000 | LDMA_IPVERSION_CLR  | R           | IP Version                               |
| 0x2004 | LDMA_EN_CLR         | RW          | DMA Module Enable Disable Register       |
| 0x2008 | LDMA_CTRL_CLR       | RW          | DMA Control Register                     |
| 0x200C | LDMA_STATUS_CLR     | RH          | DMA Status Register                      |
| 0x2010 | LDMA_SYNCSET_CLR    | W           | DMA Sync Trig Sw Set Register            |
| 0x2014 | LDMA_SYNCCLR_CLR    | W           | DMA Sync Trig Sw Clear Register          |
| 0x2018 | LDMA_SYNCHWEN_CLR   | RW          | DMA Sync HW Trigger Enable Register      |
| 0x201C | LDMA_SYNCHWSEL_CLR  | RW          | DMA Sync HW Trigger Selection Register   |
| 0x2020 | LDMA_SYNCSTATUS_CLR | RH          | DMA Sync Trigger Status Register         |
| 0x2024 | LDMA_CHEN_CLR       | W           | DMA Channel Enable Register              |
| 0x2028 | LDMA_CHDIS_CLR      | W           | DMA Channel Disable Register             |
| 0x202C | LDMA_CHSTATUS_CLR   | RH          | DMA Channel Status Register              |
| 0x2030 | LDMA_CHBUSY_CLR     | RH          | DMA Channel Busy Register                |
| 0x2034 | LDMA_CHDONE_CLR     | RWH INTFLAG | DMA Channel Linking Done Register        |
| 0x2038 | LDMA_DBGHALT_CLR    | RW          | DMA Channel Debug Halt Register          |
| 0x203C | LDMA_SWREQ_CLR      | W           | DMA Channel Software Transfer Request    |

| Offset | Name                | Type        | Description                              |
|--------|---------------------|-------------|------------------------------------------|
| 0x2040 | LDMA_REQDIS_CLR     | RW          | DMA Channel Request Disable Register     |
| 0x2044 | LDMA_REQPEND_CLR    | RH          | DMA Channel Requests Pending Register    |
| 0x2048 | LDMA_LINKLOAD_CLR   | W           | DMA Channel Link Load Register           |
| 0x204C | LDMA_REQCLEAR_CLR   | W           | DMA Channel Request Clear Register       |
| 0x2050 | LDMA_IF_CLR         | RWH INTFLAG | Interrupt Flag Register                  |
| 0x2054 | LDMA_IEN_CLR        | RW          | Interrupt Enable Register                |
| 0x205C | LDMA_CHx_CFG_CLR    | RW          | Channel Configuration Register           |
| 0x2060 | LDMA_CHx_LOOP_CLR   | RWH         | Channel Loop Counter Register            |
| 0x2064 | LDMA_CHx_CTRL_CLR   | RWH         | Channel Descriptor Control Word Register |
| 0x2068 | LDMA_CHx_SRC_CLR    | RWH         | Channel Descriptor Source Address        |
| 0x206C | LDMA_CHx_DST_CLR    | RWH         | Channel Descriptor Destination Address   |
| 0x2070 | LDMA_CHx_LINK_CLR   | RWH         | Channel Descriptor Link Address          |
| 0x3000 | LDMA_IPVERSION_TGL  | R           | IP Version                               |
| 0x3004 | LDMA_EN_TGL         | RW          | DMA Module Enable Disable Register       |
| 0x3008 | LDMA_CTRL_TGL       | RW          | DMA Control Register                     |
| 0x300C | LDMA_STATUS_TGL     | RH          | DMA Status Register                      |
| 0x3010 | LDMA_SYNC_SWSET_TGL | W           | DMA Sync Trig Sw Set Register            |
| 0x3014 | LDMA_SYNC_SWCLR_TGL | W           | DMA Sync Trig Sw Clear Register          |
| 0x3018 | LDMA_SYNC_HWEN_TGL  | RW          | DMA Sync HW Trigger Enable Register      |
| 0x301C | LDMA_SYNC_HWSEL_TGL | RW          | DMA Sync HW Trigger Selection Register   |
| 0x3020 | LDMA_SYNCSTATUS_TGL | RH          | DMA Sync Trigger Status Register         |
| 0x3024 | LDMA_CHEN_TGL       | W           | DMA Channel Enable Register              |
| 0x3028 | LDMA_CHDIS_TGL      | W           | DMA Channel Disable Register             |
| 0x302C | LDMA_CHSTATUS_TGL   | RH          | DMA Channel Status Register              |
| 0x3030 | LDMA_CHBUSY_TGL     | RH          | DMA Channel Busy Register                |
| 0x3034 | LDMA_CHDONE_TGL     | RWH INTFLAG | DMA Channel Linking Done Register        |
| 0x3038 | LDMA_DBGHALT_TGL    | RW          | DMA Channel Debug Halt Register          |
| 0x303C | LDMA_SWREQ_TGL      | W           | DMA Channel Software Transfer Request    |
| 0x3040 | LDMA_REQDIS_TGL     | RW          | DMA Channel Request Disable Register     |
| 0x3044 | LDMA_REQPEND_TGL    | RH          | DMA Channel Requests Pending Register    |
| 0x3048 | LDMA_LINKLOAD_TGL   | W           | DMA Channel Link Load Register           |
| 0x304C | LDMA_REQCLEAR_TGL   | W           | DMA Channel Request Clear Register       |
| 0x3050 | LDMA_IF_TGL         | RWH INTFLAG | Interrupt Flag Register                  |
| 0x3054 | LDMA_IEN_TGL        | RW          | Interrupt Enable Register                |
| 0x305C | LDMA_CHx_CFG_TGL    | RW          | Channel Configuration Register           |
| 0x3060 | LDMA_CHx_LOOP_TGL   | RWH         | Channel Loop Counter Register            |
| 0x3064 | LDMA_CHx_CTRL_TGL   | RWH         | Channel Descriptor Control Word Register |

| Offset | Name              | Type | Description                            |
|--------|-------------------|------|----------------------------------------|
| 0x3068 | LDMA_CHx_SRC_TGL  | RWH  | Channel Descriptor Source Address      |
| 0x306C | LDMA_CHx_DST_TGL  | RWH  | Channel Descriptor Destination Address |
| 0x3070 | LDMA_CHx_LINK_TGL | RWH  | Channel Descriptor Link Address        |

## 25.7 LDMA Register Description

### 25.7.1 LDMA\_IPVERSION - IP Version

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |           |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|-----------|---|---|---|
|        | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | 0x0 |           |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | R   |           |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     | IPVERSION |   |   |   |

| Bit  | Name      | Reset                                                                                                                                                                             | Access | Description                                                                                                                                                                           |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                       |
| 7:0  | IPVERSION | 0x0                                                                                                                                                                               | R      | <b>IPVERSION</b><br><br>The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |

### 25.7.2 LDMA\_EN - DMA Module Enable Disable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|
|        | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | 0x0 |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | RW  |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | EN  |   |   |   |   |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                                                                                                                                                                                                            |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                                                                                        |
| 0    | EN       | 0x0                                                                                                                                                                               | RW     | <b>LDMA module enable and disable register</b><br><br>The ENABLE bit enables the module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit. |

## 25.7.3 LDMA\_CTRL - DMA Control Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x008  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | CORERST      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|        | NUMFIXED     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset                                                                                                                                                                             | Access | Description                                                                                                                                                                                                                                                                             |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | CORERST  | 0x0                                                                                                                                                                               | RW     | <b>Reset DMA controller</b><br><br>Trigger a reset of the LDMA controller core without losing register configuration                                                                                                                                                                    |
| 30:29 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                                                                                                                         |
| 28:24 | NUMFIXED | 0x1E                                                                                                                                                                              | RW     | <b>Number of Fixed Priority Channels</b><br><br>This field defines the number of Fixed Priority Arbitration channels. Channels CH0 through CH(n-1) are fixed, and channels CH(n) through CH7 are round robin, where n is the field value. The reset value will give all fixed channels. |
| 23:0  | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                                                                                                                                                                                                         |

## 25.7.4 LDMA\_STATUS - DMA Status Register

| Offset | Bit Position |    |    |    |       |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |         |    |   |   |         |     |   |     |   |     |   |   |
|--------|--------------|----|----|----|-------|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|---------|----|---|---|---------|-----|---|-----|---|-----|---|---|
| 0x00C  | 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 |
| Reset  |              |    |    |    | 0x8   |    |    |    |    |    |    |    | 0x10      |    |    |    |    |    |    |    | 0x0     |    |   |   |         | 0x0 |   | 0x0 |   | 0x0 |   |   |
| Access |              |    |    |    | R     |    |    |    |    |    |    |    | R         |    |    |    |    |    |    |    | R       |    |   |   |         | R   |   | R   |   | R   |   |   |
| Name   |              |    |    |    | CHNUM |    |    |    |    |    |    |    | FIFOLEVEL |    |    |    |    |    |    |    | CHERROR |    |   |   | CHGRANT |     |   |     |   |     |   |   |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                                                    |
|-------|-----------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 28:24 | CHNUM     | 0x8   | R      | <b>Number of Channels</b><br><br>The value of CHNUM always reads the total number of channels present for this instance of the DMA controller module.                                                          |
| 23:21 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 20:16 | FIFOLEVEL | 0x10  | R      | <b>FIFO Level</b><br><br>The value of FIFOLEVEL indicates the number of entries currently in the FIFO. (Note when all channels are disabled, this register will read the total number of entries in the FIFO.) |
| 15:13 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 12:8  | CHERROR   | 0x0   | R      | <b>Errant Channel Number</b><br><br>When the ERROR flag is set in the LDMA_IF register, the CHERROR field will indicate the most recent channel to have a transfer error.                                      |
| 7:3   | CHGRANT   | 0x0   | R      | <b>Granted Channel Number</b><br><br>The value of this field indicates the currently active channel or last active channel. Note that the reset value for this field is zero.                                  |
| 2     | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 1     | ANYREQ    | 0x0   | R      | <b>Any DMA Channel Request Pending</b><br><br>The value of this bit will be TRUE (1) if any requests are pending                                                                                               |
| 0     | ANYBUSY   | 0x0   | R      | <b>Any DMA Channel Busy</b><br><br>The value of this bit will be TRUE (1) if one or more DMA channels are actively transferring data                                                                           |

**25.7.5 LDMA\_SYNCSWSET - DMA Sync Trig Sw Set Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |           |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|-----------|---|---|---|---|---|---|
| 0x010         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |           |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W   |           |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | SYNCSWSET |   |   |   |   |   |   |

| Bit  | Name             | Reset | Access | Description                                                                                                                                                                       |
|------|------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i>  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | <b>SYNCSWSET</b> | 0x0   | W      | <b>DMA SYNC Software Trigger Set</b>                                                                                                                                              |

Sets the corresponding bit in the SYNCSTATUS.SYNCTRIG field to value 1.

**25.7.6 LDMA\_SYNCSWCLR - DMA Sync Trig Sw Clear Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |           |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|-----------|---|---|---|---|---|---|
| 0x014         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |           |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W   |           |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | SYNCSWCLR |   |   |   |   |   |   |

| Bit  | Name             | Reset | Access | Description                                                                                                                                                                       |
|------|------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i>  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | <b>SYNCSWCLR</b> | 0x0   | W      | <b>DMA SYNC Software Trigger Clear</b>                                                                                                                                            |

Clears the corresponding bit in the SYNCSTATUS.SYNCTRIG field to value 0.

## 25.7.7 LDMA\_SYNCHWEN - DMA Sync HW Trigger Enable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|----|----|---|---|-----------|---|---|---|---|---|---|---|
| 0x018  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    | 0x0       |    |    |    |    |    |    |    |    |    |   |   | 0x0       |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    | RW        |    |    |    |    |    |    |    |    |    |   |   | RW        |   |   |   |   |   |   |   |
| Name   | SYNCCCLREN   |    |    |    |    |    |    |    |    |    |    |    | SYNCSETEN |    |    |    |    |    |    |    |    |    |   |   | SYNCSETEN |   |   |   |   |   |   |   |

| Bit   | Name       | Reset | Access | Description                                                                                                                                                                       |
|-------|------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:16 | SYNCCCLREN | 0x0   | RW     | <b>Hardware Sync Trigger Clear Enable</b><br><br>Enables the corresponding bit in the SYNCSTATUS.SYNCTRIG field to be cleared by PRS channel 7-0, mapping to bits [23:16].        |
| 15:8  | Reserved   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0   | SYNCSETEN  | 0x0   | RW     | <b>Hardware Sync Trigger Set Enable</b><br><br>Enables the corresponding bit in the SYNCSTATUS.SYNCTRIG field to be set by PRS channel 7-0, mapping to bits [7:0].                |

## 25.7.8 LDMA\_SYNCHWSEL - DMA Sync HW Trigger Selection Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|----|---|---|-------------|---|---|---|---|---|---|---|
| 0x01C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    | 0x0         |    |    |    |    |    |    |    |    |    |   |   | 0x0         |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    | RW          |    |    |    |    |    |    |    |    |    |   |   | RW          |   |   |   |   |   |   |   |
| Name   | SYNCCLREDGE  |    |    |    |    |    |    |    |    |    |    |    | SYNCSETEDGE |    |    |    |    |    |    |    |    |    |   |   | SYNCSETEDGE |   |   |   |   |   |   |   |

| Bit   | Name         | Reset | Access | Description                                                                                                                                                                       |
|-------|--------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 23:16 | SYNCCCLREDGE | 0x0   | RW     | <b>Hardware Sync Trigger Clear Edge Select</b><br><br>Select rising or falling edge detection on PRS to clear trigger.                                                            |
|       | Value        | Mode  |        | Description                                                                                                                                                                       |
|       | 0            | RISE  |        | Use rising edge detection                                                                                                                                                         |
|       | 1            | FALL  |        | Use falling edge detection                                                                                                                                                        |
| 15:8  | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0   | SYNCSETEDGE  | 0x0   | RW     | <b>Hardware Sync Trigger Set Edge Select</b><br><br>Select rising or falling edge detection on PRS to set trigger.                                                                |
|       | Value        | Mode  |        | Description                                                                                                                                                                       |
|       | 0            | RISE  |        | Use rising edge detection                                                                                                                                                         |
|       | 1            | FALL  |        | Use falling edge detection                                                                                                                                                        |

**25.7.9 LDMA\_SYNCSTATUS - DMA Sync Trigger Status Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |          |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|----------|
| 0x020  | 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   |          |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0 |          |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R   |          |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     | SYNCTRIG |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                     |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                               |
| 7:0  | SYNCTRIG | 0x0   | R      | <b>sync trig status</b><br><br>Reflects the status of setting and clearing by software (SYNCSWSET/SYNCSWCLR), hardware (PRS), and loading SYNC structures. Setting a bit always takes precedence over clearing. |

**25.7.10 LDMA\_CHEN - DMA Channel Enable Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|------|
| 0x024  | 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   |      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0 |      |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | W   |      |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     | CHEN |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | CHEN     | 0x0   | W      | <b>Channel Enables</b><br><br>Setting one of these bits will enable the respective DMA channel, writing zeros has no effect                                                       |

**25.7.11 LDMA\_CHDIS - DMA Channel Disable Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |       |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------|---|---|---|---|---|---|---|
| 0x028         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0   |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W     |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CHDIS |   |   |   |   |   |   |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | CHDIS           | 0x0   | W      | <b>DMA Channel disable</b>                                                                                                                                                        |

Setting one of these bits will disable the respective DMA channel. Writing zeros has no effect. If set while a transfer is in progress, the current transfer block will complete. The remaining blocks will pause until resumed later by setting corresponding CHEN bit.

**25.7.12 LDMA\_CHSTATUS - DMA Channel Status Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 <td data-kind="ghost"></td> |          |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------------|----------|---|---|---|---|---|---|
| 0x02C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R                               |          |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CHSTATUS                        |          |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                 | CHSTATUS |   |   |   |   |   |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | CHSTATUS        | 0x0   | R      | <b>DMA Channel Status</b>                                                                                                                                                         |

The value of this bit will be TRUE (1) if one or more DMA channels are enabled

**25.7.13 LDMA\_CHBUSY - DMA Channel Busy Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |      |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|------|
| 0x030  | 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   |      |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0 |      |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R |     |      |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     | BUSY |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | BUSY     | 0x0   | R      | <b>Channels Busy</b><br><br>The bits of this field read 1 when the corresponding channel is busy.                                                                                 |

## 25.7.14 LDMA\_CHDONE - DMA Channel Linking Done Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|
| 0x034         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                                                                                     |
|------|----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                               |
| 7    | CHDONE7  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |
| 6    | CHDONE6  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |
| 5    | CHDONE5  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |
| 4    | CHDONE4  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |
| 3    | CHDONE3  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |
| 2    | CHDONE2  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |
| 1    | CHDONE1  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |
| 0    | CHDONE0  | 0x0   | RW     | <b>DMA Channel Link done intr flag</b><br><br>Each DMA channel sets the corresponding bit in this register when the entire linked transfer is done. The interrupt service routine should clear these bits. For non-link structures this will be set once the structure is done. |

**25.7.15 LDMA\_DBGHALT - DMA Channel Debug Halt Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| 0x038         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW      |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DBGHALT |   |   |   |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                              |
|------|----------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                        |
| 7:0  | DBGHALT  | 0x0   | RW     | <b>DMA Debug Halt</b><br><br>Setting one of these bits will mask the corresponding DMA channel's peripheral request when debugging and the CPU is halted. This may be useful for debugging DMA software. |

**25.7.16 LDMA\_SWREQ - DMA Channel Software Transfer Request**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 <td data-kind="ghost"></td> |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------------|---|---|---|---|---|---|---|
| 0x03C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W                               |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | SWREQ                           |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                 |   |   |   |   |   |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | SWREQ    | 0x0   | W      | <b>Software Transfer Requests</b><br><br>Setting one of these bits will trigger a DMA transfer for the corresponding channel. Writing zeros has no effect.                        |

**25.7.17 LDMA\_REQDIS - DMA Channel Request Disable Register**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |        |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--------|
| 0x040         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |        |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0    |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RW     |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | REQDIS |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                 |
|------|----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>           |
| 7:0  | REQDIS   | 0x0   | RW     | <b>DMA Request Disables</b><br><br>Setting one of these bits will disable peripheral requests for the corresponding channel. When cleared any pending peripheral requests will be serviced. |

**25.7.18 LDMA\_REQPEND - DMA Channel Requests Pending Register**

| Offset        | Bit Position                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |
|---------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---------|
| 0x044         | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0     |
| <b>Reset</b>  |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | R       |
| <b>Access</b> |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | REQPEND |
| <b>Name</b>   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |         |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 7:0  | REQPEND  | 0x0   | R      | <b>DMA Requests Pending</b><br><br>When a DMA channel has a pending peripheral request the corresponding REQPEND bit will read 1.                                                 |

**25.7.19 LDMA\_LINKLOAD - DMA Channel Link Load Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |          |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|----------|
| 0x048  | 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 |          |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |   |          |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | W   |   |          |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   | LINKLOAD |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                              |
|------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                        |
| 7:0  | LINKLOAD | 0x0   | W      | <b>DMA Link Loads</b><br><br>Setting one of these bits will force the corresponding DMA channel to load the next DMA structure and enable the channel. This empowers software to step through a sequence of descriptors. |

**25.7.20 LDMA\_REQCLEAR - DMA Channel Request Clear Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |          |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|----------|
| 0x04C  | 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        |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |          |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | W   |          |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | REQCLEAR |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                       |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 7:0  | REQCLEAR | 0x0   | W      | <b>DMA Request Clear</b><br><br>Setting one of these bits will clear any internally registered transfer requests for the corresponding channel.                   |

## 25.7.21 LDMA\_IF - Interrupt Flag Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  |       |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--|--|--|-------|--|
| 0x050  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |  |       |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | 0x0   |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | RW    |  |
| Name   | ERROR        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE7 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE6 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE5 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE4 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE3 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE2 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE1 |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |  |  |  | DONE0 |  |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                       |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | ERROR    | 0x0   | RW     | <b>Error Flag</b><br><br>Set to 1 on an Error                                                                                                                     |
| 30:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 7    | DONE7    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |
| 6    | DONE6    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |
| 5    | DONE5    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |
| 4    | DONE4    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |
| 3    | DONE3    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |
| 2    | DONE2    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |
| 1    | DONE1    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |
| 0    | DONE0    | 0x0   | RW     | <b>DMA Structure Operation Done</b><br><br>When a channel completes a transfer or sync operation, the corresponding DONE bit is set in the LDMA_IF register.      |

## 25.7.22 LDMA\_IEN - Interrupt Enable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------|---|---|---|
| 0x054  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0    |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RW     |   |   |   |
| Name   | ERROR        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | CHDONE |   |   |   |

| Bit  | Name     | Reset                                                                                                                                                             | Access | Description                                                                             |
|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------|
| 31   | ERROR    | 0x0                                                                                                                                                               | RW     | <b>Enable or disable the error interrupt</b><br><br>Enables the AHB bus error interrupt |
| 30:8 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                                                                         |
| 7:0  | CHDONE   | 0x0                                                                                                                                                               | RW     | <b>Enable or disable the done interrupt</b><br><br>Enables done interrupts              |

## 25.7.23 LDMA\_CHx\_CFG - Channel Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x05C  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 0x0 | 21 | 0x0 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reset  |              |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name       | Reset    | Access | Description                                                                                                                                                             |
|-------|------------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved   |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>       |
| 21    | DSTINCSIGN | 0x0      | RW     | <b>Destination Address Increment Sign</b><br><br>0: Increment destination address, 1: Decrement destination address                                                     |
|       | Value      | Mode     |        | Description                                                                                                                                                             |
|       | 0          | POSITIVE |        | Increment destination address                                                                                                                                           |
|       | 1          | NEGATIVE |        | Decrement destination address                                                                                                                                           |
| 20    | SRCINCSIGN | 0x0      | RW     | <b>Source Address Increment Sign</b><br><br>0: Increment source address, 1: Decrement source address                                                                    |
|       | Value      | Mode     |        | Description                                                                                                                                                             |
|       | 0          | POSITIVE |        | Increment source address                                                                                                                                                |
|       | 1          | NEGATIVE |        | Decrement source address                                                                                                                                                |
| 19:18 | Reserved   |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>       |
| 17:16 | ARBSLOTS   | 0x0      | RW     | <b>Arbitration Slot Number Select</b><br><br>For channels using round robin arbitration, this bit-field is used to select the number of slots in the round robin queue. |
|       | Value      | Mode     |        | Description                                                                                                                                                             |
|       | 0          | ONE      |        | One arbitration slot selected                                                                                                                                           |
|       | 1          | TWO      |        | Two arbitration slots selected                                                                                                                                          |
|       | 2          | FOUR     |        | Four arbitration slots selected                                                                                                                                         |
|       | 3          | EIGHT    |        | Eight arbitration slots selected                                                                                                                                        |
| 15:0  | Reserved   |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>       |

**25.7.24 LDMA\_CHx\_LOOP - Channel Loop Counter Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    |         |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|----|---------|
| 0x060         | 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  |         |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |    |         |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | RW |         |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |    | LOOPCNT |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                |
|------|----------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                          |
| 7:0  | LOOPCNT  | 0x0   | RW     | <b>Linked Structure Sequence Loop Counter</b><br><br>This bit-field specifies the number of iterations when using looping descriptors. Software should write to LOOPCNT before using a looping descriptor. |

### 25.7.25 LDMA\_CHx\_CTRL - Channel Descriptor Control Word Register

| Offset     | Bit Position |        |    |  |
|------------|--------------|--------|----|--|
| Name       | Reset        | Access |    |  |
| 0x064      |              |        |    |  |
| DSTMODE    | R            | 0x0    | 31 |  |
| SRCMODE    | R            | 0x0    | 30 |  |
| DSTINC     | RW           | 0x0    | 28 |  |
| SIZE       | RW           | 0x0    | 27 |  |
| SRCINC     | RW           | 0x0    | 26 |  |
| IGNORESREQ | RW           | 0x0    | 24 |  |
| DECLOOPCNT | RW           | 0x0    | 23 |  |
| REQMODE    | RW           | 0x0    | 22 |  |
| DONEEN     | RW           | 0x0    | 21 |  |
| BLOCKSIZE  | RW           | 0x0    | 20 |  |
| BYTESWAP   | RW           | 0x0    | 19 |  |
| XFERCNT    | RW           | 0x0    | 18 |  |
| STRUCTREQ  | R            | 0x0    | 17 |  |
| STRUCTTYPE | RW           | 0x0    | 16 |  |

| Bit                                                                                                                                                                                                                                                                            | Name    | Reset    | Access | Description                                                                                                              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|--------|--------------------------------------------------------------------------------------------------------------------------|
| 31                                                                                                                                                                                                                                                                             | DSTMODE | 0x0      | R      | <b>Destination Addressing Mode</b>                                                                                       |
| This field specifies the destination addressing mode of linked descriptors. After loading a linked descriptor, reading this field will indicate the destination addressing mode of the linked descriptor. Note that the first descriptor always uses absolute addressing mode. |         |          |        |                                                                                                                          |
|                                                                                                                                                                                                                                                                                | Value   | Mode     |        | Description                                                                                                              |
|                                                                                                                                                                                                                                                                                | 0       | ABSOLUTE |        | The DSTADDR field of LDMA_CHx_DST contains the absolute address of the destination data.                                 |
|                                                                                                                                                                                                                                                                                | 1       | RELATIVE |        | The DSTADDR field of LDMA_CHx_DST contains the relative offset of the destination data.                                  |
| 30                                                                                                                                                                                                                                                                             | SRCMODE | 0x0      | R      | <b>Source Addressing Mode</b>                                                                                            |
| This field specifies the source addressing mode of linked descriptors. After loading a linked descriptor, reading this field will indicate the source addressing mode of the linked descriptor. Note that the first descriptor always uses absolute addressing mode.           |         |          |        |                                                                                                                          |
|                                                                                                                                                                                                                                                                                | Value   | Mode     |        | Description                                                                                                              |
|                                                                                                                                                                                                                                                                                | 0       | ABSOLUTE |        | The SRCADDR field of LDMA_CHx_SRC contains the absolute address of the source data.                                      |
|                                                                                                                                                                                                                                                                                | 1       | RELATIVE |        | The SRCADDR field of LDMA_CHx_SRC contains the relative offset of the source data.                                       |
| 29:28                                                                                                                                                                                                                                                                          | DSTINC  | 0x0      | RW     | <b>Destination Address Increment Size</b>                                                                                |
| This bit-field specifies the stride or number of unit data addresses to increment the destination address after each unit of data is transferred. The unit data width is controlled by the SIZE bit-field and can be a byte, half-word or word.                                |         |          |        |                                                                                                                          |
|                                                                                                                                                                                                                                                                                | Value   | Mode     |        | Description                                                                                                              |
|                                                                                                                                                                                                                                                                                | 0       | ONE      |        | Increment destination address by one unit data size after each write                                                     |
|                                                                                                                                                                                                                                                                                | 1       | TWO      |        | Increment destination address by two unit data sizes after each write                                                    |
|                                                                                                                                                                                                                                                                                | 2       | FOUR     |        | Increment destination address by four unit data sizes after each write                                                   |
|                                                                                                                                                                                                                                                                                | 3       | NONE     |        | Do not increment the destination address. Writes are made to a fixed destination address, for example writing to a FIFO. |

| Bit   | Name       | Reset    | Access | Description                                                                                                                                                                                                                                                                            |
|-------|------------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:26 | SIZE       | 0x0      | RW     | <b>Unit Data Transfer Size</b><br><br>This field specifies the size of data transferred.                                                                                                                                                                                               |
|       | Value      | Mode     |        | Description                                                                                                                                                                                                                                                                            |
|       | 0          | BYTE     |        | Each unit transfer is a byte                                                                                                                                                                                                                                                           |
|       | 1          | HALFWORD |        | Each unit transfer is a half-word                                                                                                                                                                                                                                                      |
|       | 2          | WORD     |        | Each unit transfer is a word                                                                                                                                                                                                                                                           |
| 25:24 | SRCINC     | 0x0      | RW     | <b>Source Address Increment Size</b><br><br>This bit-field specifies the stride or number of unit data addresses to increment the source address after each unit of data is transferred. The unit data width is controlled by the SIZE bit-field and can be a byte, half-word or word. |
|       | Value      | Mode     |        | Description                                                                                                                                                                                                                                                                            |
|       | 0          | ONE      |        | Increment source address by one unit data size after each read                                                                                                                                                                                                                         |
|       | 1          | TWO      |        | Increment source address by two unit data sizes after each read                                                                                                                                                                                                                        |
|       | 2          | FOUR     |        | Increment source address by four unit data sizes after each read                                                                                                                                                                                                                       |
|       | 3          | NONE     |        | Do not increment the source address. In this mode reads are made from a fixed source address, for example reading FIFO.                                                                                                                                                                |
| 23    | IGNORESREQ | 0x0      | RW     | <b>Ignore Sreq</b><br><br>The channel arbiter will ignore single requests (SREQ) and only respond to multiple requests (REQ) when this bit is set.                                                                                                                                     |
| 22    | DECLOOPCNT | 0x0      | RW     | <b>Decrement Loop Count</b><br><br>When using looping, setting this bit will decrement the LOOPCNT field in the LDMA_CHx_LOOP register after each descriptor execution.                                                                                                                |
| 21    | REQMODE    | 0x0      | RW     | <b>DMA Request Transfer Mode Select</b><br><br>Selects the DMA Request Transfer mode.                                                                                                                                                                                                  |
|       | Value      | Mode     |        | Description                                                                                                                                                                                                                                                                            |
|       | 0          | BLOCK    |        | The LDMA transfers one BLOCKSIZE per transfer request.                                                                                                                                                                                                                                 |
|       | 1          | ALL      |        | One transfer request transfers all units as defined by the XFRCNT field.                                                                                                                                                                                                               |
| 20    | DONEIEN    | 0x0      | RW     | <b>DMA Operation Done Interrupt Flag Set En</b><br><br>Setting this bit will set the interrupt flag when the transfer is done, or linked in the case where the LINK bit is set, or synchronized in the case of a SYNC transfer.                                                        |
| 19:16 | BLOCKSIZE  | 0x0      | RW     | <b>Block Transfer Size</b><br><br>This bit-field controls the number of unit data transfers per arbitration cycle                                                                                                                                                                      |
|       | Value      | Mode     |        | Description                                                                                                                                                                                                                                                                            |
|       | 0          | UNIT1    |        | One unit transfer per arbitration                                                                                                                                                                                                                                                      |
|       | 1          | UNIT2    |        | Two unit transfers per arbitration                                                                                                                                                                                                                                                     |
|       | 2          | UNIT3    |        | Three unit transfers per arbitration                                                                                                                                                                                                                                                   |
|       | 3          | UNIT4    |        | Four unit transfers per arbitration                                                                                                                                                                                                                                                    |

| Bit  | Name                                                                                                                                                                            | Reset                                                                                                                                                                             | Access                                         | Description                                         |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-----------------------------------------------------|
| 4    | UNIT6                                                                                                                                                                           |                                                                                                                                                                                   |                                                | Six unit transfers per arbitration                  |
| 5    | UNIT8                                                                                                                                                                           |                                                                                                                                                                                   |                                                | Eight unit transfers per arbitration                |
| 7    | UNIT16                                                                                                                                                                          |                                                                                                                                                                                   |                                                | Sixteen unit transfers per arbitration              |
| 9    | UNIT32                                                                                                                                                                          |                                                                                                                                                                                   |                                                | 32 unit transfers per arbitration                   |
| 10   | UNIT64                                                                                                                                                                          |                                                                                                                                                                                   |                                                | 64 unit transfers per arbitration                   |
| 11   | UNIT128                                                                                                                                                                         |                                                                                                                                                                                   |                                                | 128 unit transfers per arbitration                  |
| 12   | UNIT256                                                                                                                                                                         |                                                                                                                                                                                   |                                                | 256 unit transfers per arbitration                  |
| 13   | UNIT512                                                                                                                                                                         |                                                                                                                                                                                   |                                                | 512 unit transfers per arbitration                  |
| 14   | UNIT1024                                                                                                                                                                        |                                                                                                                                                                                   |                                                | 1024 unit transfers per arbitration                 |
| 15   | ALL                                                                                                                                                                             |                                                                                                                                                                                   |                                                | Transfer all units as specified by the XFRCNT field |
| 15   | BYTESWAP                                                                                                                                                                        | 0x0                                                                                                                                                                               | RW                                             | <b>Endian Byte Swap</b>                             |
|      |                                                                                                                                                                                 | For word and half-word transfers, setting this bit will swap all bytes of each word or half-word.                                                                                 |                                                |                                                     |
| 14:4 | XFERCNT                                                                                                                                                                         | 0x0                                                                                                                                                                               | RW                                             | <b>DMA Unit Data Transfer Count</b>                 |
|      | Specifies number of unit data (words, half-words, or bytes) to transfer, as determined by the SIZE field. The value written should be one less than the desired transfer count. |                                                                                                                                                                                   |                                                |                                                     |
| 3    | STRUCTREQ                                                                                                                                                                       | 0x0                                                                                                                                                                               | R                                              | <b>Structure DMA Transfer Request</b>               |
|      | Structure Transfer Request                                                                                                                                                      |                                                                                                                                                                                   |                                                |                                                     |
| 2    | Reserved                                                                                                                                                                        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |                                                |                                                     |
| 1:0  | STRUCTTYPE                                                                                                                                                                      | 0x0                                                                                                                                                                               | RW                                             | <b>DMA Structure Type</b>                           |
|      | DMA Structure type                                                                                                                                                              |                                                                                                                                                                                   |                                                |                                                     |
|      | Value                                                                                                                                                                           | Mode                                                                                                                                                                              | Description                                    |                                                     |
|      | 0                                                                                                                                                                               | TRANSFER                                                                                                                                                                          | DMA transfer structure type selected.          |                                                     |
|      | 1                                                                                                                                                                               | SYNCHRONIZE                                                                                                                                                                       | Synchronization structure type selected.       |                                                     |
|      | 2                                                                                                                                                                               | WRITE                                                                                                                                                                             | Write immediate value structure type selected. |                                                     |

**25.7.26 LDMA\_CHx\_SRC - Channel Descriptor Source Address**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x068  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | SRCADDR      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                            | Name    | Reset | Access | Description                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|----------------------------|
| 31:0                                                                                                                                                                                                                           | SRCADDR | 0x0   | RW     | <b>Source Data Address</b> |
| Writing to this register sets the source address. Reading from this register during a DMA transfer will indicate the next source read address. The value of this register is incremented or decremented with each source read. |         |       |        |                            |

**25.7.27 LDMA\_CHx\_DST - Channel Descriptor Destination Address**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x06C  | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DSTADDR      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                                                                                                              | Name    | Reset | Access | Description                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|---------------------------------|
| 31:0                                                                                                                                                                                                                                             | DSTADDR | 0x0   | RW     | <b>Destination Data Address</b> |
| Writing to this register sets the destination address. Reading from this register during a DMA transfer will indicate the next destination write address. This value of this register is incremented or decremented with each destination write. |         |       |        |                                 |

**25.7.28 LDMA\_CHx\_LINK - Channel Descriptor Link Address**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| 0x070         | 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 |  |  |  |  |  |
| <b>Reset</b>  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>Access</b> | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>Name</b>   | LINKADDR     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |

| Bit  | Name     | Reset | Access                                                                                      | Description                                                                                                                                                                                                                                                                                                |
|------|----------|-------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | LINKADDR | 0x0   | RW                                                                                          | <b>Link Structure Address</b><br><br>To use linking, write the address of the the first linked descriptor to this register. When a linked descriptor is loaded, it may also be linked to another descriptor. Reading this register will reflect the address of the next linked descriptor.                 |
| 1    | LINK     | 0x0   | RW                                                                                          | <b>Link Next Structure</b><br><br>After completing the initial transfer, if this bit is set, the DMA will load the next linked descriptor. If the next linked descriptor also has this bit set, the DMA will load the next linked descriptor.                                                              |
| 0    | LINKMODE | 0x0   | R                                                                                           | <b>Link Structure Addressing Mode</b><br><br>This field specifies the addressing mode of linked descriptors. After loading a linked descriptor, reading this field will indicate the addressing mode of the loaded linked descriptor. Note that the first descriptor always uses absolute addressing mode. |
|      | Value    | Mode  |                                                                                             | Description                                                                                                                                                                                                                                                                                                |
| 0    | ABSOLUTE |       | The LINKADDR field of LDMA_CHx_LINK contains the absolute address of the linked descriptor. |                                                                                                                                                                                                                                                                                                            |
| 1    | RELATIVE |       | The LINKADDR field of LDMA_CHx_LINK contains the relative offset of the linked descriptor.  |                                                                                                                                                                                                                                                                                                            |

**25.8 LDMAXBAR Register Map**

The offset register address is relative to the registers base address.

| Offset | Name                          | Type | Description                              |
|--------|-------------------------------|------|------------------------------------------|
| 0x000  | LDMAXBAR_IPVERSION            | R    | IP Version ID                            |
| 0x004  | LDMAXBAR_CHx_REQSEL           | RW   | Channel Peripheral Request Select Reg... |
| 0x1000 | LDMAXBAR_IPVERSION_SET        | R    | IP Version ID                            |
| 0x1004 | LDMAXBAR_CHx REQ-<br>QSEL_SET | RW   | Channel Peripheral Request Select Reg... |
| 0x2000 | LDMAXBAR_IPVERSION_CLR        | R    | IP Version ID                            |
| 0x2004 | LDMAXBAR_CHx REQ-<br>QSEL CLR | RW   | Channel Peripheral Request Select Reg... |
| 0x3000 | LDMAXBAR_IPVERSION_TGL        | R    | IP Version ID                            |
| 0x3004 | LDMAXBAR_CHx REQ-<br>QSEL_TGL | RW   | Channel Peripheral Request Select Reg... |

## 25.9 LDMAXBAR Register Description

### 25.9.1 LDMAXBAR\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description                 |
|------|-----------|-------|--------|-----------------------------|
| 31:0 | IPVERSION | 0x3   | R      | <b>IP Version ID</b>        |
|      |           |       |        | ID indicating version of IP |

### 25.9.2 LDMAXBAR\_CHx\_REQSEL - Channel Peripheral Request Select Reg...

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x004  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name      | Reset                                                                                                                                                             | Access | Description          |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------|
| 31:22 | Reserved  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                      |
| 21:16 | SOURCESEL | 0x0                                                                                                                                                               | RW     | <b>Source Select</b> |
|       |           | Select input source to DMA channel.                                                                                                                               |        |                      |
| 15:4  | Reserved  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                      |
| 3:0   | SIGSEL    | 0x0                                                                                                                                                               | RW     | <b>Signal Select</b> |
|       |           | Select input signal to DMA channel.                                                                                                                               |        |                      |

## 26. WDOG - Watch Dog Timer



### Quick Facts

#### What?

The WDOG (Watchdog Timer) resets the system in case of a fault condition, and can be enabled in all energy modes as long as the low frequency clock source is available.

#### Why?

If a software failure or external event renders the MCU unresponsive, a Watchdog timeout will reset the system to a known, safe state.

#### How?

An enabled Watchdog Timer implements a configurable timeout period. If the CPU fails to re-start the Watchdog Timer before it times out, a full system reset will be triggered. The Watchdog consumes insignificant power, and allows the device to remain safely in low energy modes for up to 256 seconds at a time.

### 26.1 Introduction

The purpose of the watchdog timer is to generate a reset in case of a system failure to increase application reliability. The failure can be caused by a variety of events, such as an ESD pulse or a software failure.

### 26.2 Features

- Clock input from selectable oscillators
  - Internal 32 kHz LFRCO oscillator
  - Internal 1 kHz ULFRCO oscillator
  - External 32.768 kHz LFXO XTAL oscillator
  - HCLK divided by 1024
- Configurable timeout period from 9 to 256k watchdog clock cycles
- Individual selection to keep running or freeze when entering EM1 Sleep, EM2 DeepSleep, or EM3 Stop
- Selection to keep running or freeze when entering debug mode
- Selection to block the CPU from entering Energy Mode 4
- Configurable warning interrupt at 25%, 50%, or 75% of the timeout period
- Configurable window interrupt at 12.5%, 25%, 37.5%, 50%, 62.5%, 75%, 87.5% of the timeout period
- Timeout interrupt
- PRS as a watchdog clear
- Interrupt for the event where a PRS rising edge is absent before a software reset

## 26.3 Functional Description

The watchdog is enabled by setting the EN bit in WDOGn\_EN. When enabled, the watchdog counts up to the period value configured through the PERSEL field in WDOGn\_CFG. If the watchdog timer is not cleared to 0 (by writing a 1 to the CLEAR bit in WDOGn\_CMD) before the period is reached, the chip is reset. If a timely clear command is issued, the timer starts counting up from 0 again. The watchdog can optionally be locked by writing anything other than UNLOCK code in WDOGn\_LOCK. Once locked, it cannot be disabled or reconfigured by software.

**Note:** If the WDOG is configured to halt during EM1, EM2, or EM3 and EM1/EM2/EM3 is entered on the clock cycle before the specified timeout, a timeout event will occur upon the EM1/EM2/EM3 wake event.

When the EN bit in WDOGn\_EN is cleared to 0, the watchdog counter is reset. Any pending interrupt flags will remain active until cleared.

### 26.3.1 Clock Source

Four clock sources are available for use with the watchdog, through the CLKSEL field in CMU\_WDOGn\_CFG. The selected oscillator source automatically starts when the watchdog is enabled. To prevent accidental change of the clock selection, CMU\_WDOGLOCK can be written anything other than UNLOCK code. Also, respective oscillator has locks to prevent accidental disabling of oscillators. The PERSEL field in WDOGn\_CFG is used to divide the selected watchdog clock, and the timeout for the watchdog timer can be calculated with the formula:

$$T_{TIMEOUT} = [2^{(PERSEL+3)} + 1] / f$$

where f is the frequency of the selected clock.

Users must clear EM2RUN and EM3RUN when the selected clock source is HCLKDIV1024.

### 26.3.2 Debug Functionality

The watchdog timer can either keep running or be frozen when the device is halted by a debugger. This configuration is done through the DEBUGRUN bit in WDOGn\_CFG. When code execution is resumed, the watchdog will continue counting where it left off.

### 26.3.3 Energy Mode Handling

The watchdog timer can be configured to either keep on running or freeze when entering EM1 Sleep, EM2 DeepSleep, or EM3 Stop. The configuration is done individually for each energy mode in the EM1RUN, EM2RUN, and EM3RUN bits in WDOGn\_CFG. When the watchdog has been frozen and is re-entering an energy mode where it is running, the watchdog timer will continue counting where it left off. The watchdog does not run in EM4. If EM4BLOCK in WDOGn\_CFG is set, the CPU will be prevented from entering EM4 by software request.

### 26.3.4 Warning Interrupt

The watchdog implements a warning interrupt which can be configured to occur at approximately 25%, 50%, or 75% of the timeout period through the WARNSEL field of the WDOGn\_CFG register. This interrupt can be used to wake up the cpu for clearing the watchdog. The warning point for the watchdog timer can be calculated with the formula:

$$T_{WARNING} = [2^{(PERSEL+3)} + 1] * WARNSEL / 4 / f$$

where f is the frequency of the selected clock.

When the watchdog is enabled, it is recommended to clear the watchdog before changing WARNSEL.

### 26.3.5 Window Interrupt

This interrupt occurs when the watchdog is cleared below a certain threshold. This threshold is given by the formula:

$$T_{WINDOW} = [2^{(PERSEL+3)} + 1] * WARNSEL / 8 / f$$

where  $f$  is the frequency of the selected clock.

This value will be approximately 12.5%, 25%, 37.5%, 50%, 62.5%, 75%, or 87.5% of the timeout value based on the WINSEL field of the WDOGn\_CFG. [Figure 26.1 WDOG Warning, Window, and Timeout on page 1038](#) illustrates the warning, the window, and the timeout interrupts. Also, it shows where the PRS rising edge needs to happen. The PRS edge detection feature is discussed later.



**Figure 26.1. WDOG Warning, Window, and Timeout**

### 26.3.6 PRS as Watchdog Clear

A PRS channel (selected by register PRS\_CONSUMER\_WDOGn\_SRC0) can be used to clear the watchdog counter. To enable this feature, CLRSRC must be set to 1. [Figure 26.2 PRS Clearing WDOG on page 1039](#) shows how the PRS channel takes over the WDOG clear function. Clearing the WDOG with the PRS is mutually exclusive of clearing the WDT by software.



**Figure 26.2. PRS Clearing WDOG**

### 26.3.7 PRS Rising Edge Monitoring

PRS channels can be used to monitor multiple processes. The first and second channel are selected by PRS\_CONSUMER\_WDOGn\_SRC0 and PRS\_CONSUMER\_WDOGn\_SRC1, respectively. If enabled, every time the watch dog timer is cleared the PRS channels are checked and any channel which has not seen an event can trigger an interrupt.



**Figure 26.3. PRS Edge Monitoring in WDOG**

## 26.4 WDOG Register Map

The offset register address is relative to the registers base address.

| Offset | Name               | Type        | Description                   |
|--------|--------------------|-------------|-------------------------------|
| 0x000  | WDOG_IPVERSION     | R           | IP Version Register           |
| 0x004  | WDOG_EN            | RW ENABLE   | Enable Register               |
| 0x008  | WDOG_CFG           | RW CONFIG   | Configuration Register        |
| 0x00C  | WDOG_CMD           | W LFSYNC    | Command Register              |
| 0x014  | WDOG_STATUS        | RH          | Status Register               |
| 0x018  | WDOG_IF            | RWH INTFLAG | Interrupt Flag Register       |
| 0x01C  | WDOG_IEN           | RW          | Interrupt Enable Register     |
| 0x020  | WDOG_LOCK          | W           | Lock Register                 |
| 0x024  | WDOG_SYNCBUSY      | RH          | Synchronization Busy Register |
| 0x1000 | WDOG_IPVERSION_SET | R           | IP Version Register           |
| 0x1004 | WDOG_EN_SET        | RW ENABLE   | Enable Register               |
| 0x1008 | WDOG_CFG_SET       | RW CONFIG   | Configuration Register        |
| 0x100C | WDOG_CMD_SET       | W LFSYNC    | Command Register              |
| 0x1014 | WDOG_STATUS_SET    | RH          | Status Register               |
| 0x1018 | WDOG_IF_SET        | RWH INTFLAG | Interrupt Flag Register       |
| 0x101C | WDOG_IEN_SET       | RW          | Interrupt Enable Register     |
| 0x1020 | WDOG_LOCK_SET      | W           | Lock Register                 |
| 0x1024 | WDOG_SYNCBUSY_SET  | RH          | Synchronization Busy Register |
| 0x2000 | WDOG_IPVERSION_CLR | R           | IP Version Register           |
| 0x2004 | WDOG_EN_CLR        | RW ENABLE   | Enable Register               |
| 0x2008 | WDOG_CFG_CLR       | RW CONFIG   | Configuration Register        |
| 0x200C | WDOG_CMD_CLR       | W LFSYNC    | Command Register              |
| 0x2014 | WDOG_STATUS_CLR    | RH          | Status Register               |
| 0x2018 | WDOG_IF_CLR        | RWH INTFLAG | Interrupt Flag Register       |
| 0x201C | WDOG_IEN_CLR       | RW          | Interrupt Enable Register     |
| 0x2020 | WDOG_LOCK_CLR      | W           | Lock Register                 |
| 0x2024 | WDOG_SYNCBUSY_CLR  | RH          | Synchronization Busy Register |
| 0x3000 | WDOG_IPVERSION_TGL | R           | IP Version Register           |
| 0x3004 | WDOG_EN_TGL        | RW ENABLE   | Enable Register               |
| 0x3008 | WDOG_CFG_TGL       | RW CONFIG   | Configuration Register        |
| 0x300C | WDOG_CMD_TGL       | W LFSYNC    | Command Register              |
| 0x3014 | WDOG_STATUS_TGL    | RH          | Status Register               |
| 0x3018 | WDOG_IF_TGL        | RWH INTFLAG | Interrupt Flag Register       |
| 0x301C | WDOG_IEN_TGL       | RW          | Interrupt Enable Register     |
| 0x3020 | WDOG_LOCK_TGL      | W           | Lock Register                 |

| Offset | Name              | Type | Description                   |
|--------|-------------------|------|-------------------------------|
| 0x3024 | WDOG_SYNCBUSY_TGL | RH   | Synchronization Busy Register |

## 26.5 WDOG Register Description

### 26.5.1 WDOG\_IPVERSION - IP Version Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|        | 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 |
| Reset  | 0x1          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

| Bit                                                                                                                                                           | Name      | Reset | Access | Description       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------|--------|-------------------|
| 31:0                                                                                                                                                          | IPVERSION | 0x1   | R      | <b>IP Version</b> |
| The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION. |           |       |        |                   |

### 26.5.2 WDOG\_EN - Enable Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|        | 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 |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Name   | DISABLING EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

| Bit  | Name                                                                                                                                                                                                                  | Reset                                                                                                                                                             | Access | Description                  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------|
| 31:2 | Reserved                                                                                                                                                                                                              | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                              |
| 1    | DISABLING                                                                                                                                                                                                             | 0x0                                                                                                                                                               | R      | <b>Disabling busy status</b> |
|      | When EN is cleared, DISABLING status is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS and FIFO |                                                                                                                                                                   |        |                              |
| 0    | EN                                                                                                                                                                                                                    | 0x0                                                                                                                                                               | RW     | <b>Module Enable</b>         |
|      | The ENABLE bit enables the module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit.                      |                                                                                                                                                                   |        |                              |

## 26.5.3 WDOG\_CFG - Configuration Register

| Offset        | Bit Position |        |    |     |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
|---------------|--------------|--------|----|-----|---------|----|----|-----|----|----|----|----|--------|-----|----|----|----|----|----|----|----|---|--|--|--|--|--|--|--|--|--|--|
| 0x008         | 31           | 30     | 29 | 28  | 27      | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19     | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 6 |  |  |  |  |  |  |  |  |  |  |
| Reset         |              |        | RW | 0x0 |         |    | RW | 0x0 |    |    |    |    | RW     | 0xF |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| Access        |              |        | RW |     |         |    | RW |     |    |    |    |    | RW     |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| Name          |              | WINSEL |    |     | WARNSEL |    |    |     |    |    |    |    | PERSEL |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
|               |              |        |    |     |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| PRS1MISSRSTEN |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| PRS0MISSRSTEN |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| WDOGRSTDIS    |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| DEBUGRUN      |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| EM4BLOCK      |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| EM3RUN        |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| EM2RUN        |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| EM1RUN        |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |
| CLRSRC        |              |        | RW | 0x0 |         |    |    |     |    |    |    |    |        |     |    |    |    |    |    |    |    |   |  |  |  |  |  |  |  |  |  |  |

| Bit   | Name                                | Reset | Access | Description                                                                                                                                                       |
|-------|-------------------------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved                            |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 30:28 | WINSEL                              | 0x0   | RW     | <b>WDOG Illegal Window Select</b>                                                                                                                                 |
|       | Select WDOG illegal limit.          |       |        |                                                                                                                                                                   |
|       | Value                               | Mode  |        | Description                                                                                                                                                       |
|       | 0                                   | DIS   |        | Disabled.                                                                                                                                                         |
|       | 1                                   | SEL1  |        | Window timeout is 12.5% of the Timeout.                                                                                                                           |
|       | 2                                   | SEL2  |        | Window timeout is 25% of the Timeout.                                                                                                                             |
|       | 3                                   | SEL3  |        | Window timeout is 37.5% of the Timeout.                                                                                                                           |
|       | 4                                   | SEL4  |        | Window timeout is 50% of the Timeout.                                                                                                                             |
|       | 5                                   | SEL5  |        | Window timeout is 62.5% of the Timeout.                                                                                                                           |
|       | 6                                   | SEL6  |        | Window timeout is 75.5% of the Timeout.                                                                                                                           |
|       | 7                                   | SEL7  |        | Window timeout is 87.5% of the Timeout.                                                                                                                           |
| 27:26 | Reserved                            |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 25:24 | WARNSEL                             | 0x0   | RW     | <b>WDOG Warning Period Select</b>                                                                                                                                 |
|       | Select WDOG warning timeout period. |       |        |                                                                                                                                                                   |
|       | Value                               | Mode  |        | Description                                                                                                                                                       |
|       | 0                                   | DIS   |        | Disable                                                                                                                                                           |
|       | 1                                   | SEL1  |        | Warning timeout is 25% of the Timeout.                                                                                                                            |
|       | 2                                   | SEL2  |        | Warning timeout is 50% of the Timeout.                                                                                                                            |
|       | 3                                   | SEL3  |        | Warning timeout is 75% of the Timeout.                                                                                                                            |
| 23:20 | Reserved                            |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 19:16 | PERSEL                              | 0xF   | RW     | <b>WDOG Timeout Period Select</b>                                                                                                                                 |
|       | Select WDOG timeout period.         |       |        |                                                                                                                                                                   |

| Bit   | Name          | Reset   | Access | Description                                                                                                                                                                       |
|-------|---------------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Value         | Mode    |        | Description                                                                                                                                                                       |
| 0     | SEL0          |         |        | Timeout period of 9 wdog cycles                                                                                                                                                   |
| 1     | SEL1          |         |        | Timeout period of 17 wdog cycles                                                                                                                                                  |
| 2     | SEL2          |         |        | Timeout period of 33 wdog cycles                                                                                                                                                  |
| 3     | SEL3          |         |        | Timeout period of 65 wdog cycles                                                                                                                                                  |
| 4     | SEL4          |         |        | Timeout period of 129 wdog cycles                                                                                                                                                 |
| 5     | SEL5          |         |        | Timeout period of 257 wdog cycles                                                                                                                                                 |
| 6     | SEL6          |         |        | Timeout period of 513 wdog cycles                                                                                                                                                 |
| 7     | SEL7          |         |        | Timeout period of 1k wdog cycles                                                                                                                                                  |
| 8     | SEL8          |         |        | Timeout period of 2k wdog cycles                                                                                                                                                  |
| 9     | SEL9          |         |        | Timeout period of 4k wdog cycles                                                                                                                                                  |
| 10    | SEL10         |         |        | Timeout period of 8k wdog cycles                                                                                                                                                  |
| 11    | SEL11         |         |        | Timeout period of 16k wdog cycles                                                                                                                                                 |
| 12    | SEL12         |         |        | Timeout period of 32k wdog cycles                                                                                                                                                 |
| 13    | SEL13         |         |        | Timeout period of 64k wdog cycles                                                                                                                                                 |
| 14    | SEL14         |         |        | Timeout period of 128k wdog cycles                                                                                                                                                |
| 15    | SEL15         |         |        | Timeout period of 256k wdog cycles                                                                                                                                                |
| 15:11 | Reserved      |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 10    | PRS1MISSRSTEN | 0x0     | RW     | <b>PRS Src1 Missing Event WDOG Reset</b><br><br>When set, a PRS Source 1 missing event will trigger a WDOG reset.                                                                 |
| 9     | PRS0MISSRSTEN | 0x0     | RW     | <b>PRS Src0 Missing Event WDOG Reset</b><br><br>When set, a PRS Source 0 missing event will trigger a WDOG reset.                                                                 |
| 8     | WDOGRSTDIS    | 0x0     | RW     | <b>WDOG Reset Disable</b><br><br>Disable WDOG reset output.                                                                                                                       |
|       | Value         | Mode    |        | Description                                                                                                                                                                       |
|       | 0             | EN      |        | A timeout will cause a WDOG reset                                                                                                                                                 |
|       | 1             | DIS     |        | A timeout will not cause a WDOG reset                                                                                                                                             |
| 7:6   | Reserved      |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5     | DEBUGRUN      | 0x0     | RW     | <b>Debug Mode Run</b><br><br>Set to keep WDOG running in debug mode.                                                                                                              |
|       | Value         | Mode    |        | Description                                                                                                                                                                       |
|       | 0             | DISABLE |        | WDOG timer is frozen in debug mode                                                                                                                                                |
|       | 1             | ENABLE  |        | WDOG timer is running in debug mode                                                                                                                                               |
| 4     | EM4BLOCK      | 0x0     | RW     | <b>EM4 Block</b>                                                                                                                                                                  |

| Bit | Name                                   | Reset   | Access                                                            | Description              |
|-----|----------------------------------------|---------|-------------------------------------------------------------------|--------------------------|
|     | Set to disallow EM4 entry by software. |         |                                                                   |                          |
|     | Value                                  | Mode    | Description                                                       |                          |
|     | 0                                      | DISABLE | EM4 can be entered by software. See EMU for detailed description. |                          |
|     | 1                                      | ENABLE  | EM4 cannot be entered by software.                                |                          |
| 3   | EM3RUN                                 | 0x0     | RW                                                                | <b>EM3 Run</b>           |
|     | Set to keep WDOG running in EM3.       |         |                                                                   |                          |
|     | Value                                  | Mode    | Description                                                       |                          |
|     | 0                                      | DISABLE | WDOG timer is frozen in EM3.                                      |                          |
|     | 1                                      | ENABLE  | WDOG timer is running in EM3.                                     |                          |
| 2   | EM2RUN                                 | 0x0     | RW                                                                | <b>EM2 Run</b>           |
|     | Set to keep WDOG running in EM2.       |         |                                                                   |                          |
|     | Value                                  | Mode    | Description                                                       |                          |
|     | 0                                      | DISABLE | WDOG timer is frozen in EM2.                                      |                          |
|     | 1                                      | ENABLE  | WDOG timer is running in EM2.                                     |                          |
| 1   | EM1RUN                                 | 0x0     | RW                                                                | <b>EM1 Run</b>           |
|     | Set to keep WDOG running in EM1.       |         |                                                                   |                          |
|     | Value                                  | Mode    | Description                                                       |                          |
|     | 0                                      | DISABLE | WDOG timer is frozen in EM1.                                      |                          |
|     | 1                                      | ENABLE  | WDOG timer is running in EM1.                                     |                          |
| 0   | CLRSRC                                 | 0x0     | RW                                                                | <b>WDOG Clear Source</b> |
|     | Select WDOG clear source.              |         |                                                                   |                          |
|     | Value                                  | Mode    | Description                                                       |                          |
|     | 0                                      | SW      | A write to the clear bit will clear the WDOG counter              |                          |
|     | 1                                      | PRSSRC0 | A rising edge on the PRS Source 0 will clear the WDOG counter     |                          |

#### 26.5.4 WDOG\_CMD - Command Register

| Bit                                                                         | Name      | Reset | Access                      | Description                                                                                                                                                                       |
|-----------------------------------------------------------------------------|-----------|-------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1                                                                        | Reserved  |       |                             | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0                                                                           | CLEAR     | 0x0   | W(nB)                       | <b>WDOG Timer Clear</b>                                                                                                                                                           |
| Clear WDOG timer. The bit must be written 4 WDOG cycles before the timeout. |           |       |                             |                                                                                                                                                                                   |
| Value                                                                       | Mode      |       | Description                 |                                                                                                                                                                                   |
| 0                                                                           | UNCHANGED |       | WDOG timer is unchanged.    |                                                                                                                                                                                   |
| 1                                                                           | CLEARED   |       | WDOG timer is cleared to 0. |                                                                                                                                                                                   |

### **26.5.5 WDOG\_STATUS - Status Register**

| Bit                                    | Name     | Reset                                                                                                                                                             | Access | Description                           |
|----------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------|
| 31                                     | LOCK     | 0x0                                                                                                                                                               | R      | <b>WDOG Configuration Lock Status</b> |
| Status of all lockable WDOG registers. |          |                                                                                                                                                                   |        |                                       |
| <hr/>                                  |          |                                                                                                                                                                   |        |                                       |
| Value                                  | Mode     | Description                                                                                                                                                       |        |                                       |
| 0                                      | UNLOCKED | All WDOG lockable registers are unlocked.                                                                                                                         |        |                                       |
| 1                                      | LOCKED   | All WDOG lockable registers are locked.                                                                                                                           |        |                                       |
| <hr/>                                  |          |                                                                                                                                                                   |        |                                       |
| 30:0                                   | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |        |                                       |

## 26.5.6 WDOG\_IF - Interrupt Flag Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|
| 0x018         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 4 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 3 |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 2 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 1 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | PEM1            | 0x0   | RW     | <b>PRS Src1 Event Missing Interrupt Flag</b><br><br>Set when a WDOG clear happens before a prs event has been detected on PRS Source one.                                         |
| 3    | PEM0            | 0x0   | RW     | <b>PRS Src0 Event Missing Interrupt Flag</b><br><br>Set when a WDOG clear happens before a prs event has been detected on PRS Source zero.                                        |
| 2    | WIN             | 0x0   | RW     | <b>WDOG Window Interrupt Flag</b><br><br>Set when a WDOG clear happens below the window limit value.                                                                              |
| 1    | WARN            | 0x0   | RW     | <b>WDOG Warning Timeout Interrupt Flag</b><br><br>Set when a WDOG warning timeout has occurred.                                                                                   |
| 0    | TOUT            | 0x0   | RW     | <b>WDOG Timeout Interrupt Flag</b><br><br>Set when a WDOG timeout has occurred.                                                                                                   |

## 26.5.7 WDOG\_IEN - Interrupt Enable Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|
| 0x01C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 4 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 3 |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 2 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 1 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |   |

| Bit  | Name            | Reset                                                                                                                                                                             | Access | Description                                                                              |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------|
| 31:5 | <i>Reserved</i> | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                          |
| 4    | PEM1            | 0x0                                                                                                                                                                               | RW     | <b>PRS Src1 Event Missing Interrupt Enable</b><br><br>Enable/disable the PEM1 interrupt. |
| 3    | PEM0            | 0x0                                                                                                                                                                               | RW     | <b>PRS Src0 Event Missing Interrupt Enable</b><br><br>Enable/disable the PEM0 interrupt. |
| 2    | WIN             | 0x0                                                                                                                                                                               | RW     | <b>WDOG Window Interrupt Enable</b><br><br>Enable/disable the WIN interrupt.             |
| 1    | WARN            | 0x0                                                                                                                                                                               | RW     | <b>WDOG Warning Timeout Interrupt Enable</b><br><br>Enable/disable the WARN interrupt.   |
| 0    | TOUT            | 0x0                                                                                                                                                                               | RW     | <b>WDOG Timeout Interrupt Enable</b><br><br>Enable/disable the TOUT interrupt.           |

#### 26.5.8 WDOG\_LOCK - Lock Register

| Bit   | Name     | Reset  | Access | Description                                                                                                                                                         |
|-------|----------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>   |
| 15:0  | LOCKKEY  | 0xABE8 | W      | <b>WDOG Configuration Lock</b><br><br>Write any other value than the unlock code to lock WDOG_EN, WDOD_CFG registers from editing. Write the unlock code to unlock. |

  

| Value | Mode   | Description                    |
|-------|--------|--------------------------------|
| 0     | LOCK   | Lock WDOG lockable registers   |
| 44008 | UNLOCK | Unlock WDOG lockable registers |

#### 26.5.9 WDOG\_SYNCBUSY - Synchronization Busy Register

| Bit  | Name     | Reset | Access | Description                                                                                                                                                       |
|------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 0    | CMD      | 0x0   | R      | <b>Sync Busy for Cmd Register</b><br><br>CMD bitfield sync is busy when set.                                                                                      |

## 27. PCNT - Pulse Counter



### Quick Facts

#### What?

The Pulse Counter (PCNT) decodes incoming pulses. The module has a quadrature mode which may be used to decode the speed and direction of a mechanical shaft. PCNT can operate in EM0 down to EM3.

#### Why?

The PCNT generates an interrupt after a specific number of pulses (or rotations), eliminating the need for timing or I/O interrupts and CPU processing to measure pulse widths, etc.

#### How?

PCNT uses the EM23GRPACLK or may be externally clocked from a pin. The module incorporates a 16-bit up/down-counter to keep track of incoming pulses or rotations.

### 27.1 Introduction

The Pulse Counter (PCNT) can be used for counting incoming pulses on a single input or to decode quadrature encoded inputs in EM0 down to EM3. It can run from the internal EM23GRPACLK clock source while counting pulses on the PCNTn\_S0IN pin. Alternatively, the PCNTn\_S0IN pin or a PRS signal may be used as an external clock source that runs the PCNT counter and register access.

### 27.2 Features

- 16-bit counter with reload register
- Auxiliary counter for counting a single direction
- Single input oversampling up/down counter mode
- Externally clocked single input pulse up/down counter mode
- Quadrature decoder modes
  - Externally clocked quadrature decoder 1X mode
  - Oversampling quadrature decoder 1X, 2X and 4X modes
- Interrupt on counter underflow and overflow
- Interrupt when a direction change is detected (quadrature decoder mode only)
- Optional pulse width filter
- Optional input inversion/edge detect select
- Optional inputs from PRS

## 27.3 Functional Description

An overview of the PCNT module is shown in [Figure 27.1 PCNT Overview on page 1050](#).



**Figure 27.1. PCNT Overview**

### 27.3.1 Pulse Counter Modes

The pulse counter can operate in single input oversampling mode (OVSSINGLE), externally clocked single input counter mode (EXTCLKSINGLE), externally clocked quadrature decoder mode (EXTCLKQUAD) and oversampling quadrature decoder modes(OVSQUAD1X, OVSQUAD2X and OVSQUAD4X). The following sections describe operation of each of these modes and how they are enabled.

#### 27.3.1.1 Single Input Oversampling Mode

This mode is selected by writing OVSSINGLE to the MODE field in the PCNTn\_CFG register. The STARTCNT bit in PCNTn\_CMD is used to start the counter, and STOPCNT can be used to stop the counter. The EM23GRPACLK clock source to the pulse counter is selected by setting CLKSEL in the CMU\_PCNT0CLKCTRL register to EM23GRPACLK. In this mode the maximum input toggle frequency should be 2 times slower than the frequency of the selected EM23GRPACLK clock source.

The optional pulse width filter is enabled by setting the FILTEN bit in the PCNTn\_CFG register. Additionally, the PCNTn\_S0IN input may be inverted, so that falling edges are counted, by setting the EDGE bit in the PCNTn\_CTRL register.

If S1CDIR in the PCNTn\_CTRL register is cleared, PCNTn\_S0IN is the only observed input in this mode. The PCNTn\_S0IN input is sampled by the PCNTnCLK and the number of detected positive or negative edges on PCNTn\_S0IN appears in PCNTn\_CNT. By default the counter will count up, but the counter may be configured to count down by setting the CNTDIR bit in PCNTn\_CTRL.

The counting direction can also be controlled externally in this mode, by setting S1CDIR. This will make the input value on PCNTn\_S1IN decide the direction counted for each PCNTn\_S0IN edge. When PCNTn\_S1IN is high, the count is done according to CNTDIR in PCNTn\_CTRL. When PCNTn\_S1IN is low, the count direction is opposite.

#### 27.3.1.2 Externally Clocked Single Input Counter Mode

This mode is enabled by writing EXTCLKSINGLE to the MODE field in the PCNTn\_CFG register. The STARTCNT bit in PCNTn\_CMD is used to start the counter, and STOPCNT can be used to stop the counter. The external pin clock source is selected by setting CLKSEL in the CMU\_PCNT0CLKCTRL register to PCNTS0.

Positive edges on PCNTn\_S0IN are used to clock the counter. Similar to the oversampled mode, PCNTn\_S1IN is used to determine the count direction if S1CDIR is set. If not, CNTDIR in PCNTn\_CTRL solely defines count direction.

The digital pulse width filter is not available in this mode. The analog de-glitch filter in the GPIO pads is capable of removing some unwanted noise. However, this mode may be susceptible to spikes and unintended pulses from devices such as mechanical switches, and is therefore most suited to take input from electronic sensors etc. that generate single wire pulses.

### 27.3.1.3 Quadrature Decoder Modes

Two different types of quadrature decoding are supported in the pulse counter: the externally clocked (Asynchronous) quadrature decoding and the oversampling (Synchronous) quadrature decoding. The externally clocked mode supports 1X quadrature decoding whereas the oversampling mode supports 1X, 2X and 4X quadrature decoding. These modes are described in detail in [27.3.1.4 Externally Clocked Quadrature Decoder Mode](#) and [27.3.1.5 Oversampling Quadrature Decoder Mode](#).

### 27.3.1.4 Externally Clocked Quadrature Decoder Mode

This mode is enabled by writing EXTCLKQUAD to the MODE field in PCNTn\_CFG. The STARTCNT bit in PCNTn\_CMD is used to start the counter, and STOPCNT can be used to stop the counter. The external pin clock source is selected by setting CLKSEL in the CMU\_PCNT0CLKCTRL register to PCNTS0.

In this mode, both edges on PCNTn\_S0IN pin are used to sample the PCNTn\_S1IN pin, in order to decode the quadrature code. A quadrature coded signal contains information about the relative speed and direction of a rotating shaft as illustrated by [Figure 27.2 PCNT Quadrature Coding on page 1052](#), hence the direction of the counter register PCNTn\_CNT is controlled automatically.



**Figure 27.2. PCNT Quadrature Coding**

If PCNTn\_S0IN leads PCNTn\_S1IN in phase, the direction is clockwise, and if it lags in phase the direction is counter-clockwise. Default behavior is illustrated by [Figure 27.2 PCNT Quadrature Coding on page 1052](#).

The counter direction may be read from the DIR bit in the PCNTn\_STATUS register. Additionally, the DIRCNG interrupt in the PCNTn\_IF register is generated when a direction change is detected. When a change is detected, the DIR bit in the PCNTn\_STATUS register must be read to determine the current new direction.

**Note:** The sector disc illustrated in the figure may be finer grained in some systems. Typically, they may generate 2-4 PCNTn\_S0IN wave periods per 360° rotation.

The direction of the quadrature code and control of the counter is generated by the simple binary function outlined by [Table 27.1 PCNT QUAD Mode Counter Control Function on page 1052](#). Note that this function also filters some invalid inputs that may occur when the shaft changes direction or temporarily toggles direction.

**Table 27.1. PCNT QUAD Mode Counter Control Function**

| Inputs       |              | Control/Status |                   |
|--------------|--------------|----------------|-------------------|
| S1IN posedge | S1IN negedge | Count Enable   | CNTDIR status bit |
| 0            | 0            | 0              | 0                 |

| Inputs       |              | Control/Status |                   |
|--------------|--------------|----------------|-------------------|
| S1IN posedge | S1IN negedge | Count Enable   | CNTDIR status bit |
| 0            | 1            | 1              | 0                 |
| 1            | 0            | 1              | 1                 |
| 1            | 1            | 0              | 0                 |

**Note:** PCNTn\_S1IN is sampled on both edges of PCNTn\_S0IN.

### 27.3.1.5 Oversampling Quadrature Decoder Mode

There are three Oversampling Quadrature Decoder Modes supported: 1X , 2X and 4X. These modes are enabled by writing OVSQUAD1X, OVSQUAD2X and OVSQUAD4X, respectively, to the MODE field in PCNTn\_CFG. The STARTCNT bit in PCNTn\_CMD is used to start the counter, and STOPCNT can be used to stop the counter. The EM23GRPACLK clock source to the pulse counter must be selected by setting CLKSEL in the CMU\_PCNT0CLKCTRL register to EM23GRPACLK.

The optional pulse width filter is enabled by setting the FILTEN bit in the PCNTn\_CFG register. The filter applies to both inputs PCNTn\_S0IN and PCNTn\_S1IN. The filter length is configured by FILTLEN in PCNTn\_OVSCTRL register.

Based on the modes selected, the decoder updates the counter on different events. In the OVSQUAD1X mode, the counter is updated on the rising edge of the PCNTn\_S0IN input when counting up, and on the negedge of the PCNTn\_S0IN input when counting down. In the OVSQUAD2X mode, the counter is updated on both edges of PCNTn\_S0IN input. In the OVSQUAD4X mode the counter is updated on both edges of both inputs PCNTn\_S0IN and PCNTn\_S1IN. [Table 27.2 PCNT OVSQUAD 1X, 2X and 4X Mode Counter Control Function on page 1054](#) outlines the increment or decrement of the counter based on the Quadrature Mode selected.

**Note:** The decoding behavior of OVSQUAD1X mode is slightly different compared to EXTCLKQUAD mode(also 1X mode). In the EXTCLKQUAD mode, the counter is updated only on the posedge of S0IN input. However, in the OVSQUAD1X mode, the counter is updated on the posedge of S0IN when counting up and on the negedge of S0IN when counting down.

**Table 27.2. PCNT OVSQUAD 1X, 2X and 4X Mode Counter Control Function**

| Direction          | Previous State |      | Next State |      | OVSQUAD MODE |    |    |
|--------------------|----------------|------|------------|------|--------------|----|----|
|                    | S1IN           | S0IN | S1IN       | S0IN | 1X           | 2X | 4X |
| Clockwise          | 0              | 0    | 0          | 1    | +1           | +1 | +1 |
|                    | 0              | 1    | 1          | 1    |              |    | +1 |
|                    | 1              | 1    | 1          | 0    |              | +1 | +1 |
|                    | 1              | 0    | 0          | 0    |              |    | +1 |
| Counter Clock-wise | 1              | 0    | 1          | 1    |              | -1 | -1 |
|                    | 1              | 1    | 0          | 1    |              |    | -1 |
|                    | 0              | 1    | 0          | 0    | -1           | -1 | -1 |
|                    | 0              | 0    | 1          | 0    |              |    | -1 |

[Figure 27.3 PCNT State Transitions for Different Oversampling Quadrature Decoder Modes on page 1055](#) illustrates the different states of the quadrature input and the state transitions that updates the counter for the different modes. Each cycle of the input states results in 1 update, 2 updates and 4 updates of the counter for OVSQUAD1X, OVSQUAD2X and OVSQUAD4X modes respectively.

**Figure 27.3. PCNT State Transitions for Different Oversampling Quadrature Decoder Modes**

The counter direction can be read from the DIR bit in PCNTn\_STATUS register. Additionally, the DIRCNG interrupt in the PCNTn\_IF is generated when the direction change is detected. When a change is detected, the DIR bit in the PCNTn\_STATUS register must be read to determine the new direction.

In the oversampling quadrature decoder modes, the maximum input toggle frequency supported is PCNTnCLK / 4. For frequencies above PCNTnCLK / 4, incorrect decoding occurs. The different decoding modes and the counter updates are further illustrated by [Figure 27.4 PCNT Oversampling Quadrature Decoder 1X Mode on page 1055](#), [Figure 27.5 PCNT Oversampling Quadrature Decoder 2X Mode on page 1056](#) and [Figure 27.6 PCNT Oversampling Quadrature Decoder 4X Mode on page 1056](#).

**Figure 27.4. PCNT Oversampling Quadrature Decoder 1X Mode**



Figure 27.5. PCNT Oversampling Quadrature Decoder 2X Mode



Figure 27.6. PCNT Oversampling Quadrature Decoder 4X Mode

The above modes, by default, are prone to flutter effects in the inputs PCNTn\_S0IN and PCNTn\_S1IN. When this occurs, the counter changes directions rapidly causing DIRCNG interrupts and unnecessarily waking the core. To prevent this, set FLUTTERRM in the PCNTn\_OVSCTRL register. When enabled, flutter is removed, thus preventing unnecessary wakeup of the core. The flutter removal logic works by preventing update of the counter value if the wheel keeps changing direction as a result of flutter. The counter is only updated if the current and previous state transition of the rotation are in the same direction. These state transitions are quadrature decoder mode specific. The highlighted state transitions in [Figure 27.3 PCNT State Transitions for Different Oversampling Quadrature Decoder Modes on page 1055](#) are the ones considered for the different quadrature decoder modes. [Figure 27.7 PCNT Oversampling Quadrature Decoder with Flutter Removal on page 1056](#) shows how the counter is updated for the different quadrature decoder modes with flutter removal FLUTTERRM enabled in PCNTn\_OVSCTRL.



Figure 27.7. PCNT Oversampling Quadrature Decoder with Flutter Removal

### 27.3.2 Hysteresis

By default the pulse counter wraps to 0 when passing the configured top value, and wraps to the top value when counting down from 0. On these events, a system will likely want to wake up to store and track the overflow count. This is fine if the pulse counter is tracking a monotonic value or a value that does not change directions frequently. In the latter scenario, if the counter changes directions around the overflow/underflow point, the system will have to wake up frequently to keep track of the rotations, resulting in higher current consumption.

To solve this, the pulse counter has a way of introducing hysteresis to the counter. When HYST in PCNTn\_CFG is set, the pulse counter will always wrap to TOP/2 on underflows and overflows. This takes the counter away from the area where it might overflow or underflow, removing the problem. [Figure 27.8 PCNT Hysteresis behavior of Counter on page 1057](#) illustrates the hysteresis behavior.



**Figure 27.8. PCNT Hysteresis behavior of Counter**

Given a starting value of 0 for the counter, the absolute count value when hysteresis is enabled can be calculated with the equations [Figure 27.9 Absolute Position With Hysteresis and Even TOP Value on page 1057](#) or [Figure 27.10 Absolute Position With Hysteresis and Odd TOP Value on page 1057](#), depending on whether the TOP value is even or odd.

$$CNT_{abs} = CNT - UF_{CNT} \times (TOP/2+1) + OF_{CNT} \times (TOP/2+1)$$

**Figure 27.9. Absolute Position With Hysteresis and Even TOP Value**

$$CNT_{abs} = CNT - UF_{CNT} \times (TOP/2+1) + OF_{CNT} \times (TOP/2+2)$$

**Figure 27.10. Absolute Position With Hysteresis and Odd TOP Value**

### 27.3.3 Auxiliary Counter

To be able to keep explicit track of counting in one direction in addition to the regular counter which counts both up and down, the auxiliary counter can be used. The pulse counter can, for instance, be configured to keep track of the absolute rotation of the wheel, while at the same time the auxiliary counter can keep track of how much the wheel has reversed.

The auxiliary counter is enabled by configuring AUXCNTEV in PCNTn\_CTRL. It will always count up, but it can be configured whether it should count up on up-events, down-events or both, keeping track of rotation either way or general movement. The value of the auxiliary counter can be read from the PCNTn\_AUXCNT register.

Overflows on the auxiliary counter happen when the auxiliary counter passes the top value of the pulse counter, configured in PCNTn\_TOP. In that event, the AUXOF interrupt flag is set, and the auxiliary counter wraps to 0.

The auxiliary counter is started and stopped in a similar way to the main counter, using commands in the PCNTn\_CMD register. The STARTAUXCNT bit in PCNTn\_CMD is used to start the auxiliary counter, and STOPAUXCNT can be used to stop the auxiliary counter.

As the auxiliary counter, the main counter can be configured to count only on certain events. This is done through CNTEV in PCNTn\_CTRL, and it is possible like for the auxiliary counter, to make the main counter count on only up and down events. The difference between the counters is that where the auxiliary counter will only count up, the main counter will count up or down depending on the direction of the count event.

### 27.3.4 Register Access

The counter-clock domain may be clocked externally. To update the counter-clock domain registers from software in this mode, 2-3 clock pulses on the external clock are needed to synchronize accesses to the externally clocked domain. Clock source switching is controlled from the registers in the CMU.

When the CORERST bit in the PCNTn\_CMD register is set by software, the PCNT clock domain is synchronously reset and released two PCNT clock edges later. This synchronous reset restores the reset values in PCNTn\_TOP, PCNTn\_CNT and other core registers in the PCNT clock domain.

CNTRST works in a similar manner as CORERST, but only resets the counter, CNT. Note that the counter is also reset by CORERST.

AUXCNTRST works in a similar manner as CORERST, but only resets the auxiliary counter, PCNTn\_AUXCNT. Note that the auxiliary counter is also reset by CORERST.

**Note:** PCNTn\_CNT is a read-only register. When writing to PCNTn\_TOP, make sure that the counter value, PCNTn\_CNT, can not exceed the value written to PCNTn\_TOP within two clock cycles.

**Note:** To ensure reset during SWRST, if the counter-clock domain is clocked externally, it is advisable to switch the counter-clock to the internal clock before performing the software reset. The clock pulses from an external source cannot be relied upon. By switching to an internal clock the software reset operation completion will be guaranteed.

### 27.3.5 Clock Sources

The pulse counter may be clocked from two possible clock sources: EM23GRPACLK or an external clock. The clock selection is configured by setting the CLKSEL field in the CMU\_PCNTnCLKCTRL register. The default clock source is the EM23GRPACLK.

This PCNT module may also use PCNTn\_S0IN as an external clock to clock the counter (EXTCLKSINGLE mode) and to sample PCNTn\_S1IN (EXTCLKQUAD mode). Setup, hold and max frequency constraints for PCNTn\_S0IN and PCNTn\_S1IN for these modes are specified in the device data sheet.

**Note:** If changing PCNT to an external clock source, either through the PCNTn\_S0IN or S0PRS input, the CMU clock switch will need at least 2 external clocks to sync over to that new clock source. Register will not load and counting will not begin until there are few external clocks.

**Note:** Switching external clock source to the S0PRS input can cause a clock glitch. So S0PRSEN in PCNTn\_CFG should be configured before configuring the CLKSEL field in CMU\_PCNTnCLKCTRL.

### 27.3.6 Input Filter

An optional pulse width filter is available in OVSSINGLE and OVSQUAD modes, when EM23GRPACLK is selected as a clock source for the Pulse Counter. The filter is enabled by writing 1 to the FILTEN bit in the PCNTn\_CTRL register. When enabled, the high and low periods of PCNTn\_S0IN and PCNTn\_S1IN must be stable for a programmable number of consecutive clock cycles before the edge is passed to the edge detector. The filter length should be programmed in FILTLEN field of the PCNTn\_OVSCTRL register.

The filter length is given by [Figure 27.11 PCNT Input Filter Length Equation on page 1059](#):

$$\text{Filter length} = (\text{FILTLEN} + 5) \text{ EM23GRPACLK cycles}$$

**Figure 27.11. PCNT Input Filter Length Equation**

The maximum filter length configured is 260 EM23GRPACLK cycles.

In EXTCLKSINGLE and EXTCLKQUAD mode, there is no digital pulse width filter available.

### 27.3.7 Edge Polarity

The edge polarity can be set by configuring the EDGE bit in the PCNTn\_CTRL register. When this bit is cleared, the pulse counter counts positive edges of PCNTn\_S0IN input. When this bit is set, the pulse counter counts negative edges in OVSSINGLE mode. Also, when the EDGE bit is set in the OVSSINGLE and EXTCLKSINGLE modes, the PCNTn\_S1IN input is inverted. In OVSQUAD 1X-4X modes the EDGE bit inverts both inputs.

**Note:** The EDGE bit in PCNTn\_CTRL has no effect in EXTCLKQUAD mode.

### 27.3.8 PRS and PCNTn\_S0IN,PCNTn\_S1IN Inputs

It is possible to receive input from a PRS signal on both PCNTn\_S0IN (or PCNTn\_S1IN) by setting S0PRSEN (or S1PRSEN) in PCNTn\_CFG. Routing of PRS channels to the inputs is performed using the PRS\_CONSUMER\_PCNTn\_S0IN and PRS\_CONSUMER\_PCNTn\_S1IN registers.

In the Oversampling quadrature decoder modes, the input frequency should be less than 4 times slower than the sampling clock PCNTnCLK to ensure correct functionality.

In the Single Input Oversampling Mode, the input toggle frequency should be 2 times slower than the sampling clock PCNTnCLK to ensure correct functionality.

In the externally clocked modes (where S0IN or S0PRS is used as PCNTnCLK clock source), the input frequency should be less than 1 MHz to ensure correct functionality.

The PCNT module generates two PRS signals, the PCNTn\_UFOF signal and the PCNTn\_DIR signal. The PCNTn\_UFOF signal is generated when the counter overflows or underflows. The PCNTn\_DIR signal is a level, and indicates the current direction of count of counter CNT.

### 27.3.9 Interrupts

The interrupt generated by PCNT uses the PCNTn\_INT interrupt vector. Software must read the PCNTn\_IF register to determine which module interrupt that generated the vector invocation.

#### 27.3.9.1 Underflow and Overflow Interrupts

The underflow interrupt flag (UF) is set when the counter counts down from 0 (i.e. when the value of the counter is 0 and a new pulse is received). The PCNTn\_CNT register is loaded with the PCNTn\_TOP value after this event.

The overflow interrupt flag (OF) is set when the counter counts up from the PCNTn\_TOP (reload) value (i.e. if PCNTn\_CNT = PCNTn\_TOP and a new pulse is received). The PCNTn\_CNT register is loaded with the value 0 after this event.

### 27.3.9.2 Direction Change Interrupt

The PCNTn\_PCNT module sets the DIRCNG interrupt flag (PCNTn\_IF register) for EXTCLKQUAD and OVSQUAD1X-4X modes when the direction of the quadrature code changes. The behavior of this interrupt in the EXTCLKQUAD mode is illustrated by Figure 27.12 PCNT Direction Change Interrupt (DIRCNG) Generation on page 1060.



Figure 27.12. PCNT Direction Change Interrupt (DIRCNG) Generation

## 27.4 PCNT Register Map

The offset register address is relative to the registers base address.

| Offset | Name               | Type        | Description                       |
|--------|--------------------|-------------|-----------------------------------|
| 0x000  | PCNT_IPVERSION     | R           | IP Version ID                     |
| 0x004  | PCNT_EN            | RW ENABLE   | Module Enable Register            |
| 0x008  | PCNT_SWRST         | RW SWRST    | Software Reset Register           |
| 0x00C  | PCNT_CFG           | RW CONFIG   | Configuration Register            |
| 0x010  | PCNT_CTRL          | RW LFSYNC   | Control Register                  |
| 0x014  | PCNT_CMD           | W LFSYNC    | Command Register                  |
| 0x018  | PCNT_STATUS        | RH          | Status Register                   |
| 0x01C  | PCNT_IF            | RWH INTFLAG | Interrupt Flag Register           |
| 0x020  | PCNT_IEN           | RW          | Interrupt Enable Register         |
| 0x024  | PCNT_CNT           | RH          | Counter Value Register            |
| 0x028  | PCNT_AUXCNT        | RH          | Auxiliary Counter Value Register  |
| 0x02C  | PCNT_TOP           | RWH LFSYNC  | Top Value Register                |
| 0x030  | PCNT_TOPB          | RW LFSYNC   | Counter Top Value Buffer Register |
| 0x034  | PCNT_OVSCTRL       | RW LFSYNC   | Oversampling Control Register     |
| 0x038  | PCNT_SYNCBUSY      | RH          | Synchronization Busy Register     |
| 0x03C  | PCNT_LOCK          | W           | Configuration Lock Register       |
| 0x1000 | PCNT_IPVERSION_SET | R           | IP Version ID                     |
| 0x1004 | PCNT_EN_SET        | RW ENABLE   | Module Enable Register            |
| 0x1008 | PCNT_SWRST_SET     | RW SWRST    | Software Reset Register           |
| 0x100C | PCNT_CFG_SET       | RW CONFIG   | Configuration Register            |
| 0x1010 | PCNT_CTRL_SET      | RW LFSYNC   | Control Register                  |
| 0x1014 | PCNT_CMD_SET       | W LFSYNC    | Command Register                  |
| 0x1018 | PCNT_STATUS_SET    | RH          | Status Register                   |
| 0x101C | PCNT_IF_SET        | RWH INTFLAG | Interrupt Flag Register           |
| 0x1020 | PCNT_IEN_SET       | RW          | Interrupt Enable Register         |
| 0x1024 | PCNT_CNT_SET       | RH          | Counter Value Register            |
| 0x1028 | PCNT_AUXCNT_SET    | RH          | Auxiliary Counter Value Register  |
| 0x102C | PCNT_TOP_SET       | RWH LFSYNC  | Top Value Register                |
| 0x1030 | PCNT_TOPB_SET      | RW LFSYNC   | Counter Top Value Buffer Register |
| 0x1034 | PCNT_OVSCTRL_SET   | RW LFSYNC   | Oversampling Control Register     |
| 0x1038 | PCNT_SYNCBUSY_SET  | RH          | Synchronization Busy Register     |
| 0x103C | PCNT_LOCK_SET      | W           | Configuration Lock Register       |
| 0x2000 | PCNT_IPVERSION_CLR | R           | IP Version ID                     |
| 0x2004 | PCNT_EN_CLR        | RW ENABLE   | Module Enable Register            |
| 0x2008 | PCNT_SWRST_CLR     | RW SWRST    | Software Reset Register           |

| Offset | Name               | Type        | Description                       |
|--------|--------------------|-------------|-----------------------------------|
| 0x200C | PCNT_CFG_CLR       | RW CONFIG   | Configuration Register            |
| 0x2010 | PCNT_CTRL_CLR      | RW LFSYNC   | Control Register                  |
| 0x2014 | PCNT_CMD_CLR       | W LFSYNC    | Command Register                  |
| 0x2018 | PCNT_STATUS_CLR    | RH          | Status Register                   |
| 0x201C | PCNT_IF_CLR        | RWH INTFLAG | Interrupt Flag Register           |
| 0x2020 | PCNT_IEN_CLR       | RW          | Interrupt Enable Register         |
| 0x2024 | PCNT_CNT_CLR       | RH          | Counter Value Register            |
| 0x2028 | PCNT_AUXCNT_CLR    | RH          | Auxiliary Counter Value Register  |
| 0x202C | PCNT_TOP_CLR       | RWH LFSYNC  | Top Value Register                |
| 0x2030 | PCNT_TOPB_CLR      | RW LFSYNC   | Counter Top Value Buffer Register |
| 0x2034 | PCNT_OVSCTRL_CLR   | RW LFSYNC   | Oversampling Control Register     |
| 0x2038 | PCNT_SYNCBUSY_CLR  | RH          | Synchronization Busy Register     |
| 0x203C | PCNT_LOCK_CLR      | W           | Configuration Lock Register       |
| 0x3000 | PCNT_IPVERSION_TGL | R           | IP Version ID                     |
| 0x3004 | PCNT_EN_TGL        | RW ENABLE   | Module Enable Register            |
| 0x3008 | PCNT_SWRST_TGL     | RW SWRST    | Software Reset Register           |
| 0x300C | PCNT_CFG_TGL       | RW CONFIG   | Configuration Register            |
| 0x3010 | PCNT_CTRL_TGL      | RW LFSYNC   | Control Register                  |
| 0x3014 | PCNT_CMD_TGL       | W LFSYNC    | Command Register                  |
| 0x3018 | PCNT_STATUS_TGL    | RH          | Status Register                   |
| 0x301C | PCNT_IF_TGL        | RWH INTFLAG | Interrupt Flag Register           |
| 0x3020 | PCNT_IEN_TGL       | RW          | Interrupt Enable Register         |
| 0x3024 | PCNT_CNT_TGL       | RH          | Counter Value Register            |
| 0x3028 | PCNT_AUXCNT_TGL    | RH          | Auxiliary Counter Value Register  |
| 0x302C | PCNT_TOP_TGL       | RWH LFSYNC  | Top Value Register                |
| 0x3030 | PCNT_TOPB_TGL      | RW LFSYNC   | Counter Top Value Buffer Register |
| 0x3034 | PCNT_OVSCTRL_TGL   | RW LFSYNC   | Oversampling Control Register     |
| 0x3038 | PCNT_SYNCBUSY_TGL  | RH          | Synchronization Busy Register     |
| 0x303C | PCNT_LOCK_TGL      | W           | Configuration Lock Register       |

## 27.5 PCNT Register Description

### **27.5.1 PCNT\_IPVERSION - IP Version ID**

| Bit                                    | Name      | Reset | Access | Description       |
|----------------------------------------|-----------|-------|--------|-------------------|
| 31:0                                   | IPVERSION | 0x1   | R      | <b>IP VERSION</b> |
| Gives access to the IP VERSION of PCNT |           |       |        |                   |

### **27.5.2 PCNT\_EN - Module Enable Register**

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                                                                  |
|------|-----------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                            |
| 1    | DISABLING | 0x0   | R      | <b>Disablement busy status</b><br><br>When EN is cleared, DISABLING status is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except the INTFLAG register. |
| 0    | EN        | 0x0   | RW     | <b>PCNT Module Enable</b><br><br>Enable the PCNT module. When EN is cleared(disablement), it halts module operation immediately, and initialize the core domain such that when the is re-enabled, it starts cleanly.         |

## 27.5.3 PCNT\_SWRST - Software Reset Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |       |           |       |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----------|-------|-----------|-------|---|
| 0x008  | 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         |       | 0 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0       | 1     | 0         |       |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | R         | W     | V         |       |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RESETTING | SWRST | RESETTING | SWRST |   |

| Bit  | Name      | Reset | Access | Description                                                                                                                                                                    |
|------|-----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>              |
| 1    | RESETTING | 0x0   | R      | <b>Software reset busy status</b><br><br>When SWRST command is issued, resetting logic sets RESETTING status immediately, and later it is cleared when reset process finishes. |
| 0    | SWRST     | 0x0   | W      | <b>Software reset command</b><br><br>A software reset command field resets the module back to the initial condition, similar to a power on reset condition                     |

## 27.5.4 PCNT\_CFG - Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |         |         |      |        |           |      |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---------|---------|------|--------|-----------|------|---|
| 0x00C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0x0     | 0x0     | 0x0  | 0x0    |           |      |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | RW      | RW      | RW   | RW     | RW        |      |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | S1PRSEN | S0PRSEN | HYST | FILTEN | DEBUGHALT | MODE |   |

| Bit   | Name      | Reset        | Access | Description                                                                                                                                                       |
|-------|-----------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved  |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9     | S1PRSEN   | 0x0          | RW     | <b>S1IN PRS Enable</b>                                                                                                                                            |
|       |           |              |        | When set, the PRS channel is selected as input to S1IN.                                                                                                           |
| 8     | S0PRSEN   | 0x0          | RW     | <b>S0IN PRS Enable</b>                                                                                                                                            |
|       |           |              |        | When set, the PRS channel is selected as input to S0IN.                                                                                                           |
| 7     | Reserved  |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 6     | HYST      | 0x0          | RW     | <b>Enable Hysteresis</b>                                                                                                                                          |
|       |           |              |        | When hysteresis is enabled, the PCNT will always overflow and underflow to TOP/2.                                                                                 |
| 5     | FILTEN    | 0x0          | RW     | <b>Enable Digital Pulse Width Filter</b>                                                                                                                          |
|       |           |              |        | The filter passes all high and low periods that are at least (FILTLEN+5) clock cycles wide. This filter is only available in OVSSINGLE,OVSQUAD1X-4X modes.        |
| 4     | DEBUGHALT | 0x0          | RW     | <b>Debug Mode Halt Enable</b>                                                                                                                                     |
|       |           |              |        | Set to halt the PCNT in debug mode only in OVSSINGLE and OVSQUAD modes. When in EXTCLKSINGLE or EX-TCLKQUAD modes, DEBUGHALT does not halt the Pulse Counter.     |
|       | Value     | Mode         |        | Description                                                                                                                                                       |
|       | 0         | DISABLE      |        | PCNT is running in debug mode.                                                                                                                                    |
|       | 1         | ENABLE       |        | PCNT is frozen in debug mode.                                                                                                                                     |
| 3     | Reserved  |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 2:0   | MODE      | 0x0          | RW     | <b>Mode Select</b>                                                                                                                                                |
|       |           |              |        | Selects the mode of operation. The corresponding clock source must be selected from the CMU.                                                                      |
|       | Value     | Mode         |        | Description                                                                                                                                                       |
|       | 0         | OVSSINGLE    |        | Single input EM23GRPACLK oversampling mode (available in EM0-EM3).                                                                                                |
|       | 1         | EXTCLKSINGLE |        | Externally clocked single input counter mode (available in EM0-EM3).                                                                                              |
|       | 2         | EXTCLKQUAD   |        | Externally clocked quadrature decoder mode (available in EM0-EM3).                                                                                                |

| Bit | Name      | Reset | Access | Description                                                                 |
|-----|-----------|-------|--------|-----------------------------------------------------------------------------|
| 3   | OVSQUAD1X |       |        | EM23GRPACLK oversampling quadrature decoder 1X mode (available in EM0-EM3). |
| 4   | OVSQUAD2X |       |        | EM23GRPACLK oversampling quadrature decoder 2X mode (available in EM0-EM3). |
| 5   | OVSQUAD4X |       |        | EM23GRPACLK oversampling quadrature decoder 4X mode (available in EM0-EM3). |

## 27.5.5 PCNT\_CTRL - Control Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|
| 0x010         | 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        |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0      |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0      |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | AUXCNTEV |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CNTEV    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | EDGE     |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CNTDIR   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | S1CDIR   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                                                                 |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | <b>Reserved</b> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |
| 7:6  | AUXCNTEV        | 0x0   | RW     | <b>Controls When the Aux Counter Counts</b><br><br>Selects whether the auxiliary counter responds to up-count events, down-count events or both                                                                             |
|      | Value           | Mode  |        | Description                                                                                                                                                                                                                 |
|      | 0               | BOTH  |        | Counts up on both up-count and down-count events.                                                                                                                                                                           |
|      | 1               | UP    |        | Counts up on up-count events.                                                                                                                                                                                               |
|      | 2               | DOWN  |        | Counts up on down-count events.                                                                                                                                                                                             |
| 5:4  | CNTEV           | 0x0   | RW     | <b>Controls When the Counter Counts</b><br><br>Selects whether the regular counter responds to up-count events, down-count events or both                                                                                   |
|      | Value           | Mode  |        | Description                                                                                                                                                                                                                 |
|      | 0               | BOTH  |        | Counts up on up-count and down on down-count events.                                                                                                                                                                        |
|      | 1               | UP    |        | Only counts up on up-count events.                                                                                                                                                                                          |
|      | 2               | DOWN  |        | Only counts down on down-count events.                                                                                                                                                                                      |
| 3    | <b>Reserved</b> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |
| 2    | EDGE            | 0x0   | RW     | <b>Edge Select</b><br><br>Determines the polarity of the incoming edges. This bit used only in OVSSINGLE, EXTCLKSINGLE and OVS-QUAD1X-4X modes.                                                                             |
|      | Value           | Mode  |        | Description                                                                                                                                                                                                                 |
|      | 0               | POS   |        | Positive edges on the PCNTn_S0IN inputs are counted in OVS-SINGLE mode. Does not invert PCNTn_S1IN input in OVSSINGLE and EXTCLKSINGLE modes                                                                                |
|      | 1               | NEG   |        | Negative edges on the PCNTn_S0IN inputs are counted in OVSSINGLE mode. Inverts the PCNTn_S1IN input in OVSSINGLE and EXTCLKSINGLE modes                                                                                     |
| 1    | CNTDIR          | 0x0   | RW     | <b>Non-Quadrature Mode Counter Direction Co</b><br><br>The direction of the counter must be set in the OVSSINGLE and EXTCLKSINGLE modes. This bit is ignored in EXTCLKQUAD mode as the direction is automatically detected. |

| Bit | Name                                                                                                                                                                                                               | Reset | Access | Description                             |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-----------------------------------------|
|     | Value                                                                                                                                                                                                              | Mode  |        | Description                             |
|     | 0                                                                                                                                                                                                                  | UP    |        | Up counter mode.                        |
|     | 1                                                                                                                                                                                                                  | DOWN  |        | Down counter mode.                      |
| 0   | S1CDIR                                                                                                                                                                                                             | 0x0   | RW     | <b>Count Direction Determined By S1</b> |
|     | Allows S1 give the direction of counting when in the OVSSINGLE or EXTCLKSINGLE modes. When S1 is high, the count direction is given by CNTDIR. When S1 is low, the count direction is the opposite given by CNTDIR |       |        |                                         |

## 27.5.6 PCNT\_CMD - Command Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |         |             |          |        |           |        |         |       |       |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|---------|-------------|----------|--------|-----------|--------|---------|-------|-------|
| 0x014  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15         | 14      | 13          | 12       |        |           |        |         |       |       |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0        | 11      | 0x0         | 10       | 0x0    | 9         | 0x0    | 8       | 0x0   | 7     |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | W          | W       | W           | W        | W      | W         | W      | W       | W     | W     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | STOPAUXCNT | STOPCNT | STARTAUXCNT | STARTCNT | LCNTIM | AUXCNTRST | CNTRST | CORERST | W(nB) | W(nB) |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                                 |
|-------|-------------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>           |
| 11    | STOPAUXCNT  | 0x0   | W      | <b>Stop Aux Counter</b><br><br>Write a 1 to stop the aux counter                                                                                                                            |
| 10    | STOPCNT     | 0x0   | W      | <b>Stop Main Counter</b><br><br>Write a 1 to stop the main counter                                                                                                                          |
| 9     | STARTAUXCNT | 0x0   | W      | <b>Start Aux Counter</b><br><br>Write a 1 to start the aux counter                                                                                                                          |
| 8     | STARTCNT    | 0x0   | W      | <b>Start Main Counter</b><br><br>Write a 1 to start the main counter                                                                                                                        |
| 7:5   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>           |
| 4     | LCNTIM      | 0x0   | W(nB)  | <b>Load CNT Immediately</b><br><br>Load PCNTn_TOP into PCNTn_CNT on the next counter clock cycle.                                                                                           |
| 3     | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>           |
| 2     | AUXCNTRST   | 0x0   | W(nB)  | <b>AUXCNT Reset</b><br><br>The auxiliary counter, AUXCNT, is synchronously reset when this bit is set. This action clears the auxiliary counter to its reset value                          |
| 1     | CNTRST      | 0x0   | W(nB)  | <b>CNT Reset</b><br><br>The counter, CNT, is synchronously reset when this bit is set. This action clears the counter to its reset value                                                    |
| 0     | CORERST     | 0x0   | W(nB)  | <b>PCNT Clock Domain Reset</b><br><br>The PCNT clock domain logic is synchronously reset when this bit is set. This action clears the all the PCNT logic and registers to their reset value |

## 27.5.7 PCNT\_STATUS - Status Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |               |            |                |       |     |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---------------|------------|----------------|-------|-----|
| 0x018  | 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   |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |               |            |                |       |     |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |               |            |                |       |     |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | AUXCNTRUNNING | CNTRUNNING | PCNTLOCKSTATUS | TOPBV | DIR |

| Bit  | Name           | Reset                                                                                                                                                                  | Access | Description                                                                                                                                                       |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved       |                                                                                                                                                                        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 4    | AUXCNTRUNNING  | 0x0                                                                                                                                                                    | R      | <b>Aux Counter running status</b>                                                                                                                                 |
|      |                | Indicates the current status of PCNT auxiliary counter running. The counter status will continue to indicate as Running even when it is halted during debug assertion. |        |                                                                                                                                                                   |
| 3    | CNTRUNNING     | 0x0                                                                                                                                                                    | R      | <b>Main Counter running status</b>                                                                                                                                |
|      |                | Indicates the current status of PCNT main counter running. The counter status will continue to indicate as Running even when it is halted during debug assertion.      |        |                                                                                                                                                                   |
| 2    | PCNTLOCKSTATUS | 0x0                                                                                                                                                                    | R      | <b>Lock Status</b>                                                                                                                                                |
|      |                | Indicates the current status of PCNT Lock                                                                                                                              |        |                                                                                                                                                                   |
|      | Value          | Mode                                                                                                                                                                   |        | Description                                                                                                                                                       |
|      | 0              | UNLOCKED                                                                                                                                                               |        | PCNT registers are unlocked                                                                                                                                       |
|      | 1              | LOCKED                                                                                                                                                                 |        | PCNT registers are locked                                                                                                                                         |
| 1    | TOPBV          | 0x0                                                                                                                                                                    | R      | <b>TOP Buffer Valid</b>                                                                                                                                           |
|      |                | This indicates that PCNTn_TOPB contains valid data that has not been written to PCNTn_TOP. This bit is also cleared when PCNTn_TOP is written.                         |        |                                                                                                                                                                   |
| 0    | DIR            | 0x0                                                                                                                                                                    | R      | <b>Current Counter Direction</b>                                                                                                                                  |
|      |                | Current direction status of the counter. This bit is valid in EXTCLKQUAD mode only.                                                                                    |        |                                                                                                                                                                   |
|      | Value          | Mode                                                                                                                                                                   |        | Description                                                                                                                                                       |
|      | 0              | UP                                                                                                                                                                     |        | Up counter mode (clockwise in EXTCLKQUAD mode with the EDGE bit in PCNTn_CTRL set to 0).                                                                          |
|      | 1              | DOWN                                                                                                                                                                   |        | Down counter mode.                                                                                                                                                |

## 27.5.8 PCNT\_IF - Interrupt Flag Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |        |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|--------|----|
| 0x01C         | 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  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 4      |    |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 0      |    |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | OQSTERR | RW     |    |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         | AUXOF  | RW |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         | DIRCNG | RW |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         | OF     | RW |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         | UF     | RW |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                       |
|------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | OQSTERR  | 0x0   | RW     | <b>Oversampling Quad State Err Int Flag</b>                                                                                                                                       |
|      |          |       |        | Set in the Oversampling Quadrature Mode when incorrect state transition occurs                                                                                                    |
| 3    | AUXOF    | 0x0   | RW     | <b>Auxiliary Overflow Interrupt Read Flag</b>                                                                                                                                     |
|      |          |       |        | Set when an Auxiliary CNT overflow occurs                                                                                                                                         |
| 2    | DIRCNG   | 0x0   | RW     | <b>Direction Change Detect Interrupt Flag</b>                                                                                                                                     |
|      |          |       |        | Set when the count direction changes. Set in EXTCLKQUAD mode only.                                                                                                                |
| 1    | OF       | 0x0   | RW     | <b>Overflow Interrupt Read Flag</b>                                                                                                                                               |
|      |          |       |        | Set when a CNT overflow occurs                                                                                                                                                    |
| 0    | UF       | 0x0   | RW     | <b>Underflow Interrupt Read Flag</b>                                                                                                                                              |
|      |          |       |        | Set when a CNT underflow occurs                                                                                                                                                   |

**27.5.9 PCNT\_IEN - Interrupt Enable Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |    |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|----|---|
| 0x020         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 4  |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 3  |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | OQSTERR | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | AUXOF   | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DIRCNG  | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | OF      | RW |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | UF      | RW |   |

| Bit  | Name                                  | Reset | Access | Description                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|---------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:5 | Reserved                              |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4    | OQSTERR                               | 0x0   | RW     | <b>Oversampling Quad State Err Int Flag</b>                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      | Set to enable the OQSTERRIF Interrupt |       |        |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3    | AUXOF                                 | 0x0   | RW     | <b>Auxiliary Overflow Interrupt Read Flag</b>                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      | Set to enable the AUXOFIF Interrupt   |       |        |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2    | DIRCNG                                | 0x0   | RW     | <b>Direction Change Detect Interrupt Flag</b>                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      | Set to enable the DIRCNGIF Interrupt  |       |        |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1    | OF                                    | 0x0   | RW     | <b>Overflow Interrupt Read Flag</b>                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      | Set to enable the OFIF Interrupt      |       |        |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0    | UF                                    | 0x0   | RW     | <b>Underflow Interrupt Read Flag</b>                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      | Set to enable the UEIF Interrupt      |       |        |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**27.5.10 PCNT\_CNT - Counter Value Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|-----|---|
| 0x024         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     | 0x0 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CNT | R   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |     |   |

| Bit   | Name                              | Reset | Access | Description                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|-----------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31:16 | Reserved                          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15:0  | CNT                               | 0x0   | R      | <b>Counter Value</b>                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|       | Gives read access to the counter. |       |        |                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**27.5.11 PCNT\_AUXCNT - Auxiliary Counter Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x028  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AUXCNT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                       |
|-------|----------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 15:0  | AUXCNT   | 0x0   | R      | <b>Auxiliary Counter Value</b><br><br>Gives read access to the auxiliary counter.                                                                                 |

**27.5.12 PCNT\_TOP - Top Value Register**

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x02C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0xFF |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TOP  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                             |
|-------|----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                       |
| 15:0  | TOP      | 0xFF  | RW     | <b>Counter Top Value</b><br><br>When counting down, this value is reloaded into PCNTn_CNT when counting past 0. When counting up, 0 is written to the PCNTn_CNT register when counting past this value. |

**27.5.13 PCNT\_TOPB - Counter Top Value Buffer Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 0x030         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0xFF |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW   |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | TOPB |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                                                                                                         |
|-------|----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                   |
| 15:0  | TOPB     | 0xFF  | RW     | <b>Counter Top Buffer Register</b><br><br>These bits hold the TOP buffer value. Hardware updates the TOP value from TOPB whenever there is Underflow or Overflow event on main counter. The update to TOP wont happen for Overflow event if PCNTn_CTRL.CNTEV = BOTH |

**27.5.14 PCNT\_OVSCTRL - Oversampling Control Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| 0x034         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW      |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | FILTLEN |   |   |   |   |   |   |   |

| Bit   | Name      | Reset | Access | Description                                                                                                                                                                                             |
|-------|-----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                       |
| 12    | FLUTTERRM | 0x0   | RW     | <b>Flutter Remove</b><br><br>When set, removes flutter from Quaddecoder inputs S0IN and S1IN. Available only in OVSQUAD1X-4X modes                                                                      |
| 11:8  | Reserved  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                       |
| 7:0   | FILTLEN   | 0x0   | RW     | <b>Configure Filter Length for Inputs S0IN</b><br><br>Used only in OVSINGLE,OVSQUAD1X-4X modes. To use this first enable FILTEN in PCNTn_CFG register. Filter length = (FILTLEN + 5) EM23GRPACLK cycles |

## 27.5.15 PCNT\_SYNCBUSY - Synchronization Busy Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|---|---|
| 0x038         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 4 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 0 |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | OVSCTRL | R |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | TOPB    | R |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | TOP     | R |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CMD     | R |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | CTRL    | R |   |

| Bit  | Name     | Reset                                                                                                                                                                             | Access | Description                                                                                              |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                                                          |
| 4    | OVSCTRL  | 0x0                                                                                                                                                                               | R      | <b>OVSCTRL Register Busy</b><br><br>Set when the value written to OVSCTRL register is being synchronized |
| 3    | TOPB     | 0x0                                                                                                                                                                               | R      | <b>TOPB Register Busy</b><br><br>Set when the value written to TOPB register is being synchronized       |
| 2    | TOP      | 0x0                                                                                                                                                                               | R      | <b>TOP Register Busy</b><br><br>Set when the value written to TOP register is being synchronized         |
| 1    | CMD      | 0x0                                                                                                                                                                               | R      | <b>CMD Register Busy</b><br><br>Set when the value written to CMD register is being synchronized         |
| 0    | CTRL     | 0x0                                                                                                                                                                               | R      | <b>CTRL Register Busy</b><br><br>Set when the value written to CTRL register is being synchronized       |

## 27.5.16 PCNT\_LOCK - Configuration Lock Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |             |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|-------------|
| 0x03C  | 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 |             |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0x0 |   |             |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     | W |             |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   | PCNTLOCKKEY |

| Bit                                                                                                                                                                                                            | Name        | Reset                                   | Access | Description                                                                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16                                                                                                                                                                                                          | Reserved    |                                         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 15:0                                                                                                                                                                                                           | PCNTLOCKKEY | 0x0                                     | W      | <b>Configuration Lock Key</b>                                                                                                                                                     |
| Write any other value than the unlock code to lock PCNT_CFG, PCNT_EN, PCNT_SWRST, PCNT_CMD, PCNT_CTRL, PCNT_OVSCTRL, PCNT_CNT, PCNT_TOP and PCNT_TOPB registers from editing. Write the unlock code to unlock. |             |                                         |        |                                                                                                                                                                                   |
| Value                                                                                                                                                                                                          | Mode        | Description                             |        |                                                                                                                                                                                   |
| 42976                                                                                                                                                                                                          | UNLOCK      | Write to unlock PCNT lockable registers |        |                                                                                                                                                                                   |

## 28. VDAC - Digital to Analog Converter



### Quick Facts

#### What?

The VDAC is designed for low energy consumption, but can also provide very good performance. It can convert digital values to analog signals at up to 500 ksamples/second with 12-bit accuracy.

#### Why?

The VDAC can be used to generate accurate analog signals for sound, sensors and other applications, using only a limited amount of energy.

#### How?

The VDAC can generate high-resolution analog signals while the MCU is operating at low frequencies and with low total power consumption. Using the LDMA, the VDAC can be used to generate waveforms without any CPU intervention. The VDAC is available down to Energy Mode 3.

### 28.1 Introduction

The Voltage Digital to Analog Converter (VDAC) converts a digital value to an analog output voltage. It is useful in a number of different applications such as sensor excitation or low/medium frequency sound output. The VDAC has two rail-to-rail output channels that may act as independent DACs or be combined into a differential pair. The output buffers support high or low power operation as well as a high capacitance mode for driving loads up to 50 pF. Both channels have a 4-word FIFO for efficient throughput and minimum CPU intervention. Flexible conversion trigger sources allow for accurate AC and DC waveform timing, and a special sample-off mode can be used in conjunction with periodic output refresh to reduce energy consumption or act as a temporary excitation source.

## 28.2 Features

Each VDAC instance in a device supports the following features:

- Up to 500 ksps operation
- Two output channels
  - Can be combined into one differential output
- Integrated 7-bit clock prescaler with division factors ranging from 1 to 128
- Selectable voltage reference
  - Internal 2.5 V (effective full-scale)
  - Internal 1.25 V (effective full-scale)
  - AVDD supply
  - External VREFP pin
- Outputs available for internal and external use
  - Main low-impedance outputs to dedicated GPIO
  - Auxiliary outputs routable through ABUS to any ABUS-capable GPIO (higher impedance)
  - Internal routing of auxiliary outputs to other analog blocks
- Data conversion modes selectable per channel
  - Continuous Mode for high speed conversion or constant DC output
  - Sample-off Mode for per-sample conversion followed by channel disable
- Independent FIFO per channel
  - 4 word (12bit) depth for each channel
  - Programmable data valid level
  - Supports software flush
- Conversion trigger sources
  - Data write (software)
  - PRS input (synchronous and asynchronous)
  - Internal timer with power-of-2 selection from 2-64 prescaled clock cycles
- Refresh trigger sources
  - Refresh timer with power-of-2 selection from 2-256 low-frequency clock cycles
  - PRS input (synchronous or asynchronous)
- PRS Communication
  - Separate line for each channel
  - Sync and async PRS output pulse on finished conversion
  - PRS Level Output till channel is warmed
  - Async PRS Output Pulse on Refresh Timer Overflow and Internal Timer Overflow
- LDMA request on FIFO data valid level
  - Independent requests for each DAC channel
- Sine generation mode with differential support

## 28.3 Functional Description

An overview of the VDAC module is shown [Figure 28.1 VDAC Block Overview Diagram on page 1079](#)



Figure 28.1. VDAC Block Overview Diagram

### 28.3.1 Power Supply

The VDAC module power ( $V_{VDAC}$ ) is derived from the AVDD supply pin.

### 28.3.2 I/O Pin Considerations

The maximum usable analog signal that can be seen on external VDAC outputs depends on both the AVDD and IOVDD supplies. Specifically, the VDAC output will be limited to the lower of the two supply voltages on AVDD and IOVDD.

### 28.3.3 Enabling and Disabling a Channel

The VDAC module is enabled by writing 1 to EN in VDAC\_EN.

A VDAC channel is enabled by writing 1 to the CHxEN and disabled by writing 1 to CHxDIS using in the CMD register. The channel status (enabled or disabled) can be read using the CHxENS bits in the STATUS register. The CHxENS bit will go high after a synchronization delay following a write to CHxEN. When disabling a channel the CHxENS bit will stay high until the VDAC channel is completely disabled.

Software should configure the VDAC before enabling a channel. The following registers are used to configure all the available features of the VDAC:

- VDAC\_CFG
- VDAC\_CH0CFG
- VDAC\_CH1CFG
- VDAC\_OUTTICKERCFG

A VDAC channel will not begin driving its output before it is enabled *and* has received a conversion trigger or refresh trigger. After a channel is enabled, it will listen for either conversion trigger sources specified in TRIGMODE in VDAC\_CHxCFG or refresh trigger sources specified in REFRESHSOURCE in VDAC\_CHxCFG. If TRIGMODE is set to SW and the CHxF FIFO is not empty, a conversion will start immediately when the channel is enabled. When disabling a channel, any pending triggers are flushed.

When disabling the VDAC module, user code must poll the status bit VDAC\_EN.DISABLING to ensure that the module is cleanly reset and back to its initial condition.

#### 28.3.4 Clock Selection

The VDAC logic accepts three clock sources from the CMU: LSPCLK, VDACn\_CLK, and VDACn\_REFRESH\_CLK. The APB register interface and FIFO write logic are clocked from the LSPCLK. The rest of the VDAC state machine is clocked mainly by a prescaled version of VDACn\_CLK. VDACn\_DAC from the CMU can be up to 80 MHz. The PRESC bit field in the CFG register should be set to scale VDACn\_CLK to no more than 1 MHz. The VDACn\_REFRESH\_CLK is a low-frequency clock source which only clocks the dedicated refresh timer.

The clock request for VDACn\_CLK to the CMU from VDAC is on-demand by default. This means the VDAC core clock is gated off most of the time except:

- New Conversion or Refresh Trigger
- Sine Generation Active Window
- VDAC\_CHxCFG.TRIGMODE = SYNCPRS
- VDAC\_CHxCFG.REFRESHSOURCE = SYNCPRS
- VDAC\_CHxCFG.TRIGMODE = SW and the VDAC CHx FIFO is not empty
- VDAC\_CHxCFG.TRIGMODE = INTTIMER

In some cases it is necessary or preferred to have the VDAC clock active all the time. To turn off on-demand clocking, the VDAC\_CFG.ONDEMANDCLK bit can be set to '1', which always requests VDACn\_CLK from the CMU. On-demand clocking should be disabled if EM23GRPACLK is selected for VDACn\_CLK.

If the VDAC will only perform conversions in EM0 and EM1, any clock source for the VDAC may be used.

If the VDAC is to be operated in EM2 or EM3, VDACn\_CLK must be configured to use either HFRCOEM23, EM23GRPACLK or FSRCO instead of the EM01GRPACLK clock. FSRCO is the fast start oscillator which starts quickly but is not as accurate as the other oscillators. HFRCOEM23 is generally recommended for EM2/EM3 operation. When using FSRCO or HFRCOEM23, the clock source can be selected to be "on demand" so as not to waste current when the DAC is not doing a conversion. On demand clocking is configured by setting VDAC\_CFG.ONDEMANDCLK to 0.

EM23GRPACLK is recommended only when VDAC is expected to do very slow sample conversions/refresh. VDAC\_CFG.ONDEMANDCLK should be set to 1 if EM23GRPACLK is selected as the VDAC clock source.

**Note:** When HFRCOEM23 is selected as a clock source to VDAC and clocking is on-demand (CFG.ONDEMANDCLK = 0), HFRCOEM23 on-demand clocking must be enabled. This allows the power domain which powers HFRCOEM23 to be ON during EM2 and the clock request to HFRCOEM23 can be honored.



Figure 28.2. VDAC Block Clocks Diagram

#### 28.3.4.1 Internal Clock Prescaler

The VDAC has an internal clock prescaler, which can divide the VDACn\_CLK input clock by any factor between 1 and 128, by setting the PRESC field in the CFG register. The resulting prescaled clock is 50% duty cycle and is used by the converter core. The frequency is given by [Figure 28.3 VDAC Clock Prescaling on page 1082](#):

$$f_{CLK\_DAC\_PRESC} = f_{VDACn\_CLK} / (\text{PRESC} + 1)$$

**Figure 28.3. VDAC Clock Prescaling**

where  $f_{VDACn\_CLK}$  is the input clock frequency coming from the CMU. The  $f_{CLK\_DAC\_PRESC}$  must be programmed to be at most 1 MHz.

The prescaler runs continuously when the VDAC is enabled or when VDAC\_SWRST.SWRST is set. When running with a prescaler setting higher than 0, there can be an unpredictable delay from the time a conversion was triggered to the time the actual conversion takes place. This is because the conversions are controlled by the prescaled time base, and the conversion can arrive at any time during a prescaled clock (CLK\_DAC\_PRESC) period. A second reason for unpredictable delay between a trigger and the associated conversion is that the activity on one channel can impact whether the VDAC reference is warm or not - when two channels are used independently with warmup, it can impact whether a warmup is required on a trigger.

The uncertainty related to the clock prescaler can be addressed by using CH0PRECSRST. If the CH0PRECSRST bit in VDAC\_CFG is set, the prescaler will be reset every time a conversion is triggered on channel 0. This leads to a predictable latency between channel 0 triggers and conversions (assuming the warmup sequence is deterministic as well). If channel x is used in continuous mode, the warmup sequence will only apply once when the channel is enabled and software can use the VDAC\_STATUS.CHxWARM bit to determine if the VDAC has warmed up.

#### 28.3.4.2 VDACn\_REFRESH\_CLK

VDAC also has another clock coming in from the CMU, VDACn\_REFRESH\_CLK. This clock is asynchronous to the VDACn\_CLK and is used to clock the internal refresh timer. VDACn\_REFRESH\_CLK is connected directly to the EM23GRPACLK source in the CMU and hence it is a low-frequency clock source with a maximum frequency of ~32 kHz. The refresh timer inside VDAC is a slow running, low power timer. When this refresh timer is used as a refresh trigger source and the timer overflows, it will trigger a VDACn\_CLK on-demand request from the CMU.

#### 28.3.5 Conversions

The VDAC consists of two channels (channel 0 and 1) with separate 4 deep FIFOs with 12-bits data elements (VDAC\_CHxF.DATA). These can be used to produce two independent single ended outputs or the channel 0 register can be used to drive both outputs in a differential mode. The VDAC supports two conversion modes: **continuous** and **sample-off**.

##### Continuous Mode

In continuous mode the VDAC buffers will remain on, and channels will drive their outputs continuously till the channel is disabled with the data in the VDAC\_CHxF.DATA register. A channel is configured in continuous mode by programming the CONVMODE bitfield in VDAC\_CHxCFG to CÖNTINUOUS. This mode will maintain the output voltage from a conversion indefinitely, until a new output is triggered or until the channel is disabled.

In continuous mode the CHxOUTHOLDTIME field in VDAC\_OUTTIMERCFG should be programmed to zero to achieve the maximum update rate. Both these settings need to be configured before VDAC module is enabled.

##### Sample-off Mode

In sample-off mode the VDAC will only drive the output for a limited time per conversion. A channel is configured in sample-off mode by programming the CONVMODE bitfield in VDAC\_CHxCFG to SAMPLEOFF. The CHxOUTHOLDTIME field in the VDAC\_OUTTIMERCFG register determines how long the output will be driven after a conversion or refresh trigger occurs. The VDAC will drive the output for CHxOUTHOLDTIME number of CLK\_DAC\_PRESC cycles before tri-stating the output again (and therefore if CHxOUTHOLDTIME is set to zero, the output will never be driven when using sample-off mode). Both these settings need to be configured before VDAC module is enabled.

### 28.3.6 Conversion Trigger

Conversions can only be performed while a channel is enabled and the CHxF FIFO is not empty, see [28.3.3 Enabling and Disabling a Channel](#).

- If CHxCFG.TRIGMODE is programmed to SW, a conversion can be started automatically when the CHxF.DATA is not empty. Writing to the FIFO will trigger a conversion on the specified channel.
- If CHxCFG.TRIGMODE is programmed to SYNCPRS or ASYNCPRS, a conversion can be started by an incoming pulse on the selected PRS channel. VDAC expects a PRS pulse coming from both synchronous and asynchronous PRS producers. Depending on the TRIGMODE and channel enable, the VDAC will process the PRS pulse from the respective producer.
- If CHxCFG.TRIGMODE is programmed to INTERNALTIMER, the internal timer is used to start conversions, and a new conversion will start on any overflow of the internal timer. See [28.3.13 Internal Timers](#).

### 28.3.7 Refresh Trigger

The refresh mechanism can be used to periodically refresh the output with the most recent conversion result. A refresh trigger can only happen while a channel is enabled, see [28.3.3 Enabling and Disabling a Channel](#).

- If CHxCFG.REFRESHSOURCE is programmed to SYNCPRS or ASYNCPRS, a refresh can be started by an incoming pulse on the selected PRS channel. The VDAC refresh mechanism requires a PRS pulse for either configuration of CHxCFG.REFRESHSOURCE. Depending on the REFRESHSOURCE and channel enable, VDAC processes the PRS pulse from the respective producer.
- If CHxCFG.REFRESHSOURCE is programmed to REFRESHTIMER, a conversion will start on an overflow of the refresh timer. See [28.3.13 Internal Timers](#).

Note: The refresh mechanism never pops a new conversion from the FIFO. It just re-triggers the conversion based on the last data converted by the conversion trigger to generate the same voltage output at the load. A periodic refresh of the output voltage into a suitable RC filter (to reduce ripple) may be a way to establish a low-energy DC bias in some applications.

#### Conversion Trigger and Refresh Trigger co-existence

- Conversion triggers are given preference over refresh triggers. During a conversion trigger sample conversion, if a refresh trigger occurs it is ignored.
- Refresh triggers are served only when the conversion trigger sample conversion is completely finished.
- During a refresh trigger sample conversion, if a conversion trigger occurs, it is held by the VDAC and served once the refresh trigger conversion is finished. The VDAC never ignores conversion triggers.

### 28.3.8 PRS Communication

PRS triggers can be used to set a constant sample frequency, for instance by using a TIMER, or to synchronize conversion events with other hardware. In order to get a jitter-free sample rate from a PRS source, set CHxCFG.TRIGMODE to SYNCPRS and set the CFG.CH0PRESRST bit to ensure the prescaler is reset on trigger. Note that because the prescaler is shared between channels, this is only possible for channel 0.

For CHxCFG.TRIGMODE / CHxCFG.REFRESHSOURCE of ASYNCPRS, the sample frequency cannot be guaranteed to be jitter-free with respect to the PRS pulses. The CH0PRESRST bit in VDAC\_CFG can still be set to reset the clock prescaler on every PRS trigger for better predictability. Note, this can be set only on channel 0.

The Input PRS frequency should never be higher than 0.5 MHz (the fastest possible sample rate). In addition, the input PRS frequency should not be higher than  $f_{VDACn\_CLK} / 4$  (in synchronous mode). If the PRS frequency is set too high, some PRS pulses may be dropped and the output can jitter.

VDAC also sends out the following list of output signals as a PRS producer:

- CHxDONEASYNC - CHx Conversion Done Asynchronous PRS Pulse Output
- CHxWARM - CHx Output Valid Async PRS Level Output
- CHxDONESYNC - CHx Conversion Done Sync PRS Pulse Output
- REFRESHTIMEROF - Refresh Timer Overflow Async PRS Pulse Output
- INTERNALTIMEROF - Internal Timer Overflow Async PRS Pulse Output

### 28.3.9 Reference Selection

The VDAC supports four voltage reference options:

- Internal 1.25 V Reference (effective full scale)
- Internal 2.5 V Reference (effective full scale)
- AVDD
- External IADC0.VREFP Pin

The voltage reference is selected by programming the REFRSEL field in VDAC\_CFG, and is shared for both VDAC channels. The selected voltage reference sets the full scale output voltage of the VDAC. In the case of the internal 1.25 V and 2.5 V reference options, the VDAC uses a lower internal voltage as the reference, and scaling techniques to produce an effective full scale voltage of 1.25 V or 2.5 V respectively. The 2.5 V internal reference can still be used over the entire supply voltage range of the device without any dropout. However, the output will be limited by the supply rail(s) and VDAC will not be able to drive above the supply.

### 28.3.10 Power Modes

The VDAC supports independently-selectable high power and low power modes per channel. Each has a maximum load capacitance of 50 pF. The power mode for each channel is configured by setting VDAC\_CHxCFG.POWERMODE. By default, the VDAC starts in HIGHPOWER mode.

VDAC also supports an additional high capacitance load mode in conjunction with the HIGHPOWER power mode. High capacitance mode is enabled by setting VDAC\_CHxCFG.HIGHCAPLOADEN to 1. The minimum load capacitance on the pin is 25 nF for this mode.



Figure 28.4. VDAC Block Power Modes Diagram

### 28.3.11 Warmup Time and Initial Conversion

When a channel is enabled, it needs to warm up. This is performed automatically when the channel is enabled if the CONVMODE in VDAC\_CHxCFG is set to Continuous mode.

If the CONVMODE in VDAC\_CHxCFG is set to Sample-off mode, then every sample conversion is preceded by warmup of the VDAC. Hence, the sample conversion time in case of sample-off mode includes the WARMUPTIME of the VDAC too.

The time allocated for warmup depends on the WARMUPTIME field in VDAC\_CFG. WARMUPTIME is specified in prescaled VDACn\_CLK cycles and should be set to a minimum of 3 us (3 clocks if CLK\_DAC\_PRESC = 1 MHz). Software is responsible for programming the correct value to WARMUPTIME before enabling a channel. If the time is programmed too short, an undefined voltage may be output until the analog portion of VDAC settles.

The CHxWARM bits in VDAC\_STATUS are set when the warmup period has completed. A consequence of the warmup period is that in continuous mode, the recommended programming model is to either wait for CHxWARM status before starting conversions in order to make sure all samples have the same timing, or perform a dummy conversion to make the VDAC settle to a known voltage first.

### 28.3.12 Output Mode

The two VDAC channels can act as two separate single-ended channels or be combined into one differential channel. This is selected through the DIFF bit in VDAC\_CFG.

- **Single Ended Output**

When operating in single ended mode, the channel 0 output is on VDAC\_OUT0 and the channel 1 output is on VDAC\_OUT1. The output voltage can be calculated using [Figure 28.5 VDAC Single Ended Output Voltage on page 1085](#)

$$V_{OUT} = V_{VDACn\_OUTx} - V_{SS} = V_{ref} \times CHxDATA/4096$$

**Figure 28.5. VDAC Single Ended Output Voltage**

where CHxDATA is a 12-bit unsigned integer.

- **Differential Output**

When operating in differential mode, both VDAC outputs are used to produce a differential output. The conversion uses the VDAC\_CH0DATA buffer as the data source. The data written to VDAC\_CH0DATA is interpreted as a two's complement number, with the MSB of the 12-bit value being the sign bit. Conceptually, a 'positive' and 'negative' output, with a common-mode voltage of  $V_{ref}/2$  are generated from this information.

The positive output appears on VDAC\_CH1 and the negative output appears on VDAC\_CH0. The output voltage can be calculated using [Figure 28.6 VDAC Differential Output Voltage on page 1085](#):

$$V_{OUT} = V_{VDACn\_CH1} - V_{VDACn\_CH0} = V_{ref} \times CH0DATA/2048$$

**Figure 28.6. VDAC Differential Output Voltage**

where CH0DATA is a 12-bit signed integer. The common mode voltage is  $V_{ref}/2$ .

When using differential mode, the user needs to program only CH0 settings to reflect to both channels. Any programmed settings in CH1 will be ignored in differential mode.

### 28.3.13 Internal Timers

VDAC has two internal timers that run independently of each other:

#### Conversion Timer

VDAC includes an internal conversion timer. This conversion timer is automatically started if a channel selects INTERNALTIMER as TRIGMODE in VDAC\_CHxCFG register and the channel is enabled. The conversion timer will count the number of prescaled VDACn\_CLK cycles programmed in VDAC\_CFG.TIMEROVERFLOWPERIOD before wrapping and generating a conversion trigger. The timer overflow period is from 2-64 prescaled VDACn\_CLK cycles. The conversion timer overflow automatically initiates the sample conversion if the CHxF FIFO is not empty.

INTERNALTIMEROF is also available as an asynchronous PRS signal, generating a pulse that lasts for 1 prescaled VDACn\_CLK cycle. Note that since this timer runs off prescaled VDACn\_CLK, the VDACn\_CLK is always requested from the CMU when the internal conversion timer is used.

#### Refresh Timer

VDAC includes an internal low power refresh timer. This refresh timer is automatically started if a channel selects REFRESHTIMER as REFRESHSOURCE in VDAC\_CHxCFG register and the channel is enabled. The refresh timer will count the number of VDACn\_REFRESH\_CLK cycles programmed in VDC\_CFG.REFRESHPERIOD before wrapping and generating a refresh trigger. The refresh period is from 2-256 VDACn\_REFRESH\_CLK cycles. The refresh timer overflow automatically initiates the refresh.

REFRESHTIMEROF is also available as an asynchronous PRS signal, generating a pulse that lasts for 1 VDACn\_REFRESH\_CLK cycle. Note that since this timer runs off VDACn\_REFRESH\_CLK, which is asynchronous to VDACn\_CLK, VDACn\_CLK is only requested from the CMU when the refresh timer overflows. Also, as discussed in [28.3.4 Clock Selection](#), this timer always runs off a slow clock, hence this refresh conversion is low power.

### 28.3.14 FIFO

VDAC has two FIFOs, one for each channel. Each FIFO is 4 samples deep. Data is pushed into the FIFO by either the CPU or LDMA, and happens on the bus clock. Samples are popped from the FIFO on the VDACn\_CLK domain by the VDAC core whenever there is a new conversion trigger. Both FIFOs support a data flush from the CPU.

#### CHxF FIFO Programming Model

Before enabling VDAC, set the low threshold Data Valid Level for each channel by programming VDAC\_CHxCFG.FIFODVL Bit. If in DIFF Mode, the channel 1 DVL settings are ignored. Fill the VDAC\_CHxF.DATA with the number of entries greater than programmed DVL to avoid triggering of DVL Interrupt. Details of the DVL Interrupt are explained in [28.3.18 Interrupts and Wakeup](#). The number of valid entries per channel can be read from VDAC\_STATUS.CHxFIFO\_CNT (only if VDAC\_CFG.ONDEMANDCLK is set to 1). The status of whether the FIFO is full or empty can be read from VDAC\_STATUS.CHxFIFO\_FULL and VDAC\_STATUS.CHxFIFO\_EMPTY respectively.

#### CHxF FIFO Flush Programming Model

In case there is incorrect data programmed in the FIFO or in the event of a FIFO overflow, the CPU can issue a flush by programming VDAC\_CMD.CHxFIFO\_FLUSH. This flush bit resets both the write pointer (in the bus clock domain) and the read pointer (in the CLK\_DAC domain) together. During a flush, new conversions should not be triggered on the channel whose FIFO contents are flushed. The flush status is reported with the VDAC\_STATUS.CHxFIFO\_BUSY bit, which will remain high during the flush operation and return low when it is complete. Since the CPU issues flush to the CHx FIFO, there are several steps that should be followed in order to avoid any spurious voltage at VDAC Output:

- Disable the channel using VDAC\_CMD.CHxDIS = 1
- Disable the VDAC channel in the LDMA to avoid any new CHxFIFO writes during flushing
- Issue the flush command and poll the VDAC\_STATUS.CHxFIFO\_BUSY status bit
- After flushing is complete, re-enable the VDAC channel and optionally re-program the LDMA

### 28.3.15 Keepwarm Sub-modes

VDAC has two keepwarm modes that can be used with Sample-off Conversion Mode to define the behaviour of the analog portion of the VDAC between sample conversions. The keepwarm mode needs to be set along with Sample-off Conversion Mode before enabling the VDAC module. The two options are:

#### Bias Keepwarm

Bias Keepwarm Mode is primarily used to reduce kickback to the reference bias, in case it is shared with IADC. This mode can be activated by setting the VDAC\_CFG.BIASKEEPWARM Bit to 1. During this mode, the VDAC Analog Bias remains ON in between sample conversions instead of shutting down after the hold time expires.

This mode is only relevant when using the internal 1.25 V or 2.5 V reference selections. This mode does not reduce the required warm-up time of the VDAC. Enabling this mode will typically cost about 4 uA of additional current when the VDAC is idle. The VDAC analog bias remains on irrespective of the channel enable/disable, until the VDAC module is disabled.

#### Channel Keepwarm

Channel Keepwarm Mode is primarily used to reduce kickback between the two channels, or to reduce the start-up time of the VDAC in-between sample conversions. This mode is activated per channel by setting the VDAC\_CHxCFG.KEEPWARM bit to 1. During this mode, the VDAC remains warmed up in-between sample conversions and can convert new samples without incurring a warm up delay. This mode can only be used with Sample-off conversion mode. Setting this mode typically costs about 10-20 uA of additional current when the VDAC is idle.

### 28.3.16 LDMA Interface

The VDAC has two FIFOs (one per channel) which can be filled using the LDMA whenever there is space available in the FIFO. To facilitate this, the VDAC generates a DMA request per channel to the LDMA when the FIFO count reaches the lower threshold Data Valid Level (DVL). DVL is set by programming VDAC\_CHxCFG.FIFODVL to set the watermark.

#### DMA REQ and SREQ

Both Channel 0 and 1 generate DMA requests in the bus clock domain only when the VDAC\_CMD.CHxEN bit is set. In the case of DIFF mode, Channel 1 will not generate LDMA requests. The FIFOs are initially empty, hence as soon as the channels are enabled, each channel will send out a DMA REQ. The request is cleared when FIFO is filled beyond DVL+1.

If there is at least 1 valid space in the FIFO and the DMA channel is not active, each VDAC channel will also send a SREQ to LDMA. This SREQ is also gated with the channel enable.

## EM2 Operation

When the system is in EM2, the VDAC can generate new DMA requests as well. This feature can be enabled by setting the VDAC\_CFG.DMAWU bit to 1 before enabling VDAC. When enabled and the FIFO count in the read domain falls below the programmed DVL setting, the VDAC will generate a request to the EMU to enter an EM1 state. Once the EMU enters this state and the bus clock is available, VDAC generates the DMA REQ/SREQ per channel to request new data for conversion.

The VDAC keeps the request for data high until the FIFO count is above the programmed DVL setting. Once the condition is met, VDAC automatically pulls the request low and the system can return fully to EM2.

### 28.3.17 Sine Generation Mode

The VDAC contains an automatic sine-generation mode, which is enabled by setting the SINEMODE bit in VDAC\_CFG. In this mode, the VDAC data from the FIFO is overridden with data from an internal hard-coded sine lookup table.

Sine mode is supported only for the fastest configuration of the VDAC in continuous mode. Therefore the CONVMODE bit in VDAC\_CH0CFG needs to be set to CONTINUOUS and the CH0OUTHOLDTIME bit in VDAC\_OUTTIMERCFG needs to be programmed to zero for channel 0 to use sine generation mode. The TRIGMODE and REFRESHSOURCE bitfields in VDAC\_CHxCFG need to be programmed to NONE for channel 0 in order to avoid interference in sine output generation from other triggers. Other trigger modes are not supported. The SINE wave will always be output on channel 0 and therefore requires that this channel is enabled by writing 1 to CH0EN in the VDAC\_CMD register. If DIFF is set in VDAC\_CFG, the sine wave will additionally be output on channel 1, but inverted. Note that the first sample will only be available after the CHxWARMED bit is 1 in VDAC\_STATUS register after setting CH0EN =1 in VDAC\_CMD.

Each period, starting at 0 degrees, is made up of 16 samples and the frequency is given by [Figure 28.7 VDAC Sine Generation Frequency on page 1087](#).

$$f_{\text{sine}} = f_{\text{CLK\_DAC\_PRESC}} / 32$$

**Figure 28.7. VDAC Sine Generation Frequency**

When DIFF is 0 and SINEMODE is 1 in VDAC\_CFG, a sine wave will be generated on channel 0 but channel 1 can still be used independently as a single-ended DAC output. Channel 1 settings are ignored if DIFF is 1.

To configure the VDAC for sine wave output:

- Set VDAC\_CFG.SINEMODE to 1 to put the VDAC in sine wave mode
- Set VDAC\_CH0CFG.CONVMODE to CONTINUOUS
- Set VDAC\_CH0CFG.TRIGMODE to NONE
- Set VDAC\_CH0CFG.REFRESHSOURCE to NONE
- Set VDAC\_OUTTIMERCFG.CH0OUTHOLDTIME to 0
- Configure VDAC\_CFG.DIFF for single-ended or differential output
  - 0 = Single ended output (only channel 0 is used)
  - 1 = Enable differential output (both channel 0 and channel 1 will be used)
- Configure VDAC\_CFG.SINEREST for desired behavior when halted
  - 0 = Sine wave output is not reset when halted, and will continue at the next sample when re-started
  - 1 = Sine wave output is reset to 0 degrees when halted, and output will return to Vref / 2
- Set VDAC\_CFG.CH0EN to 1 to enable the VDAC module

### 28.3.17.1 Sine Generation - Software Control

The sine signal generation may be controlled by software using the SINEMODESTART and SINEMODESTOP commands in VDAC\_CMD. When SINEMODESTART is set to 1, sine wave generation will be started. Setting SINEMODESTOP to 1 will halt the sine wave generation. If SINEREFSET in VDAC\_CFG is set to 1, the sine output will be reset to 0 degrees when the SINEMODESTOP bit is set to 1, resulting in a voltage of  $V_{ref} / 2$  on the output channel(s). If SINEREFSET equals 0, a SINEMODESTOP command will stop progress of the sine wave at the sample currently being output. The sine will continue at the next sample when SINEMODESTART is issued again.



**Figure 28.8. VDAC Sine Mode - Software Control**

### 28.3.18 Interrupts and Wakeup

The VDAC has several interrupt flags in the VDAC\_IF register, indicating various state and error conditions related to output, FIFO status, and conversions. Each channel has a separate set of interrupt flags.

- **Conversion Done**

The Conversion Done (CHxCD) interrupt flags are set when a conversion is complete. The flags are set after a channel has driven the output with the programmed code.

- **Data Valid Level (DVL)**

The Data Valid Level (CHxDVL) interrupt flags are set when the FIFO Count reaches below or equal to Data Valid Level (DVL). The DVL number is programmed in CHxCFG.DVL Register Bits. These flags are initially set, and gets cleared when CHxF FIFO is filled with new set of data, thereby making count  $\geq$  DVL. The FIFO Count can be read through VDAC\_STATUS.CHxFIFOCNT Flag. Note that this fifo count is generated in the read domain, hence expect read synchronization delay for the count value.

- **Overflow/Underflow**

If a write is attempted in CHxF FIFO whilst it is full, the channel overflow flag (CHxOF) will be set. If a new conversion is triggered (e.g. via PRS) before whilst CHxF FIFO is empty, the channel underflow flag (CHxUF) will be set. The FIFO full and empty status can be read through VDAC\_STATUS.CHxFIFOFULL and VDAC\_STATUS.CHxFIFOEMPTY Flags.

- **ABUS Conflict/Allocation Error**

In case both channel 0 and channel 1 request the same Port and Pin for conversion output through ABUS, an ABUS Conflict Error IF (ABUSINPUTCONFLICT) will be set. In case the ABUS Allocation is not coherent with Programmed Port and Pin Setting for either channel, ABUS Allocation Error interrupt flag (ABUSALLOCERR) will be set.

Not all interrupt flags will wake up EMU to EM0 when the VDAC is operating in EM2. Only those interrupts that need interaction with the host will wakeup the CPU. For this, DVL, ABUSALLOCERR and/or ABUSINPUTCONFLICT are used as wakeup interrupt source too.

### 28.3.19 VDAC Output Configuration

The VDAC analog outputs can be routed either to specific fixed pins, to configurable GPIO through ABUS, or used internally by other blocks. These settings can be programmed in the VDAC\_OUTCTRL register after VDAC is enabled but ideally before channels are enabled. The possible settings are as follows:

- VDAC\_OUTCTRL.MAINOUTENCHx - Set this bit to route VDAC channel analog main output to the dedicated pin (CHx\_MAIN\_OUT). This is the preferred option for any DAC output.
- VDAC\_OUTCTRL.AUXOUTENCHx - Set this bit to route VDAC channel analog auxiliary output to internal blocks such as IADC and ACMP, or to the ABUS interconnect matrix, where it can be routed to any port I/O supporting ABUS. Note that the ABUS multiplexer adds significant impedance, and this option may not be suitable for certain loads or dynamic conditions.
- VDAC\_OUTCTRL.SHORTCHx - Set this bit when using the high-power buffer option with the auxiliary outputs. This will short the MAIN and AUX outputs together. The MAIN output is still driven in this configuration.
- VDAC\_OUTCTRL.ABUSPORTSELCHx - Select a particular ABUS port for the channel. Choose values from PORTA, PORTB, PORTC, PORTD
- VDAC\_OUTCTRL.ABUSPINSELCHx - Select a particular ABUS pin for the channel. Program the pin in conjunction with the port to route the analog output to a particular GPIO.

Note: Once the channel is enabled, the output control settings in VDAC and the ABUS configuration in both VDAC and GPIO should not be changed until the channel is disabled. Changing these settings while enabled may cause spurious voltage generation on random GPIO.

#### ABUS Allocation Rules to VDAC in GPIO

- AEVEN0/BEVEN0/CDEVEN0 can only be allocated to CH0
- AEVEN1/BEVEN1/CDEVEN1 can only be allocated to CH1
- AODD0/BODD0/CDODD0 can only be allocated to CH0
- AODD1/BODD1/CDODD1 can only be allocated to CH1
- The port and pin requested by ABUSPORTSELCHx/ABUSPINSELCHx must match a bus allocated to VDAC CHx.

For example, if AEVEN0 is the only bus allocated to CH0, the selected port must be port A, and the selected pin must be even.

More details on ABUS allocation can be found in GPIO chapter

## 28.4 VDAC Register Map

The offset register address is relative to the registers base address.

| Offset | Name                 | Type        | Description                   |
|--------|----------------------|-------------|-------------------------------|
| 0x000  | VDAC_IPVERSION       | R           | IPVERSION                     |
| 0x004  | VDAC_EN              | RW ENABLE   | Module Enable                 |
| 0x008  | VDAC_SWRST           | RW SWRST    | Software Reset Register       |
| 0x00C  | VDAC_CFG             | RW CONFIG   | Config Register               |
| 0x010  | VDAC_STATUS          | RH          | Status Register               |
| 0x014  | VDAC_CH0CFG          | RW CONFIG   | Channel 0 Config Register     |
| 0x018  | VDAC_CH1CFG          | RW CONFIG   | Channel 1 Config Register     |
| 0x01C  | VDAC_CMD             | W SYNC      | Command Register              |
| 0x020  | VDAC_IF              | RWH INTFLAG | Interrupt Flag Register       |
| 0x024  | VDAC_IEN             | RW          | Interrupt Enable Register     |
| 0x028  | VDAC_CH0F            | W           | Channel 0 Data Write Fifo     |
| 0x02C  | VDAC_CH1F            | W           | Channel 1 Data Write Fifo     |
| 0x030  | VDAC_OUTCTRL         | RW SYNC     | DAC Output Control            |
| 0x034  | VDAC_OUTTIMERCFG     | RW CONFIG   | DAC Out Timer Config Register |
| 0x1000 | VDAC_IPVERSION_SET   | R           | IPVERSION                     |
| 0x1004 | VDAC_EN_SET          | RW ENABLE   | Module Enable                 |
| 0x1008 | VDAC_SWRST_SET       | RW SWRST    | Software Reset Register       |
| 0x100C | VDAC_CFG_SET         | RW CONFIG   | Config Register               |
| 0x1010 | VDAC_STATUS_SET      | RH          | Status Register               |
| 0x1014 | VDAC_CH0CFG_SET      | RW CONFIG   | Channel 0 Config Register     |
| 0x1018 | VDAC_CH1CFG_SET      | RW CONFIG   | Channel 1 Config Register     |
| 0x101C | VDAC_CMD_SET         | W SYNC      | Command Register              |
| 0x1020 | VDAC_IF_SET          | RWH INTFLAG | Interrupt Flag Register       |
| 0x1024 | VDAC_IEN_SET         | RW          | Interrupt Enable Register     |
| 0x1028 | VDAC_CH0F_SET        | W           | Channel 0 Data Write Fifo     |
| 0x102C | VDAC_CH1F_SET        | W           | Channel 1 Data Write Fifo     |
| 0x1030 | VDAC_OUTCTRL_SET     | RW SYNC     | DAC Output Control            |
| 0x1034 | VDAC_OUTTIMERCFG_SET | RW CONFIG   | DAC Out Timer Config Register |
| 0x2000 | VDAC_IPVERSION_CLR   | R           | IPVERSION                     |
| 0x2004 | VDAC_EN_CLR          | RW ENABLE   | Module Enable                 |
| 0x2008 | VDAC_SWRST_CLR       | RW SWRST    | Software Reset Register       |
| 0x200C | VDAC_CFG_CLR         | RW CONFIG   | Config Register               |
| 0x2010 | VDAC_STATUS_CLR      | RH          | Status Register               |
| 0x2014 | VDAC_CH0CFG_CLR      | RW CONFIG   | Channel 0 Config Register     |
| 0x2018 | VDAC_CH1CFG_CLR      | RW CONFIG   | Channel 1 Config Register     |

| Offset | Name                 | Type        | Description                   |
|--------|----------------------|-------------|-------------------------------|
| 0x201C | VDAC_CMD_CLR         | W SYNC      | Command Register              |
| 0x2020 | VDAC_IF_CLR          | RWH INTFLAG | Interrupt Flag Register       |
| 0x2024 | VDAC_IEN_CLR         | RW          | Interrupt Enable Register     |
| 0x2028 | VDAC_CH0F_CLR        | W           | Channel 0 Data Write Fifo     |
| 0x202C | VDAC_CH1F_CLR        | W           | Channel 1 Data Write Fifo     |
| 0x2030 | VDAC_OUTCTRL_CLR     | RW SYNC     | DAC Output Control            |
| 0x2034 | VDAC_OUTTIMERCFG_CLR | RW CONFIG   | DAC Out Timer Config Register |
| 0x3000 | VDAC_IPVERSION_TGL   | R           | IPVERSION                     |
| 0x3004 | VDAC_EN_TGL          | RW ENABLE   | Module Enable                 |
| 0x3008 | VDAC_SWRST_TGL       | RW SWRST    | Software Reset Register       |
| 0x300C | VDAC_CFG_TGL         | RW CONFIG   | Config Register               |
| 0x3010 | VDAC_STATUS_TGL      | RH          | Status Register               |
| 0x3014 | VDAC_CH0CFG_TGL      | RW CONFIG   | Channel 0 Config Register     |
| 0x3018 | VDAC_CH1CFG_TGL      | RW CONFIG   | Channel 1 Config Register     |
| 0x301C | VDAC_CMD_TGL         | W SYNC      | Command Register              |
| 0x3020 | VDAC_IF_TGL          | RWH INTFLAG | Interrupt Flag Register       |
| 0x3024 | VDAC_IEN_TGL         | RW          | Interrupt Enable Register     |
| 0x3028 | VDAC_CH0F_TGL        | W           | Channel 0 Data Write Fifo     |
| 0x302C | VDAC_CH1F_TGL        | W           | Channel 1 Data Write Fifo     |
| 0x3030 | VDAC_OUTCTRL_TGL     | RW SYNC     | DAC Output Control            |
| 0x3034 | VDAC_OUTTIMERCFG_TGL | RW CONFIG   | DAC Out Timer Config Register |

## 28.5 VDAC Register Description

### 28.5.1 VDAC\_IPVERSION - IPVERSION

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x2          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description |
|------|-----------|-------|--------|-------------|
| 31:0 | IPVERSION | 0x2   | R      | IPVERSION   |

The read only IPVERSION field gives the version for this module. There may be minor software changes required for modules with different values of IPVERSION.

**28.5.2 VDAC\_EN - Module Enable**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------|----|
| 0x004         | 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  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0       | 0  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | R         | RW |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | DISABLING | EN |

| Bit                                                                                                                                                                                                                                      | Name                                                                                                                                                                                                             | Reset                                                                                                                                                                             | Access | Description                    |       |      |             |   |         |         |   |        |        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------|-------|------|-------------|---|---------|---------|---|--------|--------|
| 31:2                                                                                                                                                                                                                                     | <i>Reserved</i>                                                                                                                                                                                                  | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                |       |      |             |   |         |         |   |        |        |
| 1                                                                                                                                                                                                                                        | DISABLING                                                                                                                                                                                                        | 0x0                                                                                                                                                                               | R      | <b>Disablement busy status</b> |       |      |             |   |         |         |   |        |        |
|                                                                                                                                                                                                                                          | When EN is cleared, DISABLING is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS and FIFOs. |                                                                                                                                                                                   |        |                                |       |      |             |   |         |         |   |        |        |
| 0                                                                                                                                                                                                                                        | EN                                                                                                                                                                                                               | 0x0                                                                                                                                                                               | RW     | <b>VDAC Module Enable</b>      |       |      |             |   |         |         |   |        |        |
|                                                                                                                                                                                                                                          | Enable the VDAC module. When EN is cleared(disablement), it halts module operation immediately, and initialize the core domain such that when the is re-enabled, it starts cleanly.                              |                                                                                                                                                                                   |        |                                |       |      |             |   |         |         |   |        |        |
| <table border="1"> <thead> <tr> <th>Value</th> <th>Mode</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>DISABLE</td> <td>Disable</td> </tr> <tr> <td>1</td> <td>ENABLE</td> <td>Enable</td> </tr> </tbody> </table> |                                                                                                                                                                                                                  |                                                                                                                                                                                   |        |                                | Value | Mode | Description | 0 | DISABLE | Disable | 1 | ENABLE | Enable |
| Value                                                                                                                                                                                                                                    | Mode                                                                                                                                                                                                             | Description                                                                                                                                                                       |        |                                |       |      |             |   |         |         |   |        |        |
| 0                                                                                                                                                                                                                                        | DISABLE                                                                                                                                                                                                          | Disable                                                                                                                                                                           |        |                                |       |      |             |   |         |         |   |        |        |
| 1                                                                                                                                                                                                                                        | ENABLE                                                                                                                                                                                                           | Enable                                                                                                                                                                            |        |                                |       |      |             |   |         |         |   |        |        |

**28.5.3 VDAC\_SWRST - Software Reset Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |           |       |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-----------|-------|
| 0x008         | 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     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0 | 0         |       |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     | R         | W     |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     | RESETTING | SWRST |

| Bit  | Name                                                                                                                                  | Reset                                                                                                                                                                             | Access | Description                       |
|------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------|
| 31:2 | <i>Reserved</i>                                                                                                                       | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                   |
| 1    | RESETTING                                                                                                                             | 0x0                                                                                                                                                                               | R      | <b>Software reset busy status</b> |
|      | When SWRST command is issued, resetting logic sets RESETTING status immediately, and later it is cleared when reset process finishes. |                                                                                                                                                                                   |        |                                   |
| 0    | SWRST                                                                                                                                 | 0x0                                                                                                                                                                               | W      | <b>Software reset command</b>     |
|      | A software reset command field resets the module back to the initial condition, similar to a power on reset condition                 |                                                                                                                                                                                   |        |                                   |

## 28.5.4 VDAC\_CFG - Config Register

| Offset | Bit Position |    |     |    |         |     |    |             |     |    |       |     |    |             |     |    |               |     |    |                  |     |    |       |     |   |        |     |   |             |     |   |           |  |  |  |  |
|--------|--------------|----|-----|----|---------|-----|----|-------------|-----|----|-------|-----|----|-------------|-----|----|---------------|-----|----|------------------|-----|----|-------|-----|---|--------|-----|---|-------------|-----|---|-----------|--|--|--|--|
| 0x00C  | 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         |  |  |  |  |
| Reset  |              | RW | 0x2 |    | RW      | 0x0 |    | RW          | 0x0 |    | RW    | 0x0 |    | RW          | 0x0 |    | RW            | 0x0 |    | RW               | 0x0 |    | RW    | 0x0 |   | RW     | 0x0 |   | RW          | 0x0 |   |           |  |  |  |  |
| Access |              | RW |     |    | RW      |     |    | RW          |     |    | RW    |     |    | RW          |     |    | RW            |     |    | RW               |     |    | RW    |     |   | RW     |     |   | RW          |     |   |           |  |  |  |  |
| Name   | WARMUPTIME   |    |     |    | DBGHALT |     |    | ONDEMANDCLK |     |    | DMAWU |     |    | BIAKEEPWARM |     |    | REFRESHPERIOD |     |    | TIMER0RFLWPERIOD |     |    | PRESC |     |   | REFSEL |     |   | CH0PRESCRST |     |   | SINERESET |  |  |  |  |
|        |              |    |     |    |         |     |    |             |     |    |       |     |    |             |     |    |               |     |    |                  |     |    |       |     |   |        |     |   |             |     |   |           |  |  |  |  |

| Bit   | Name          | Reset   | Access | Description                                                                                                                                                                                                                             |
|-------|---------------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved      |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                       |
| 30:28 | WARMUPTIME    | 0x2     | RW     | <b>DAC Warmup Time</b><br><br>Number of prescaled CLK_DAC +1 cycles for the VDAC to Warmup. Default is (2+1) prescaled CLK_DAC cycles.                                                                                                  |
| 27    | DBGHALT       | 0x0     | RW     | <b>Debug Halt</b><br><br>VDAC behavior when halted by debugger                                                                                                                                                                          |
|       | Value         | Mode    |        | Description                                                                                                                                                                                                                             |
|       | 0             | NORMAL  |        | Continue operation as normal during debug mode                                                                                                                                                                                          |
|       | 1             | HALT    |        | Complete the current conversion and then halt during debug mode                                                                                                                                                                         |
| 26    | ONDEMANDCLK   | 0x0     | RW     | <b>Always allow clk_dac</b><br><br>Setting this bit to 1 always allows CLK_DAC from CMU                                                                                                                                                 |
| 25    | DMAWU         | 0x0     | RW     | <b>VDAC DMA Wakeup</b><br><br>Set to enable wakeup from EM2 to EM1 for DMA to fill CHx FIFO Data                                                                                                                                        |
| 24    | BIAKEEPWARM   | 0x0     | RW     | <b>Bias Keepwarm Mode Enable</b><br><br>Set this bit to keep the Bias on for Analog portion of DAC in between conversions. Primary purpose, is to reduce kick-back to the reference shared with IADC. Relevant only for Sample-off Mode |
| 23    | Reserved      |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                       |
| 22:20 | REFRESHPERIOD | 0x0     | RW     | <b>Refresh Timer Overflow Period</b><br><br>Select refresh counter period. A channel x will be refreshed with the period set in REFRESHPERIOD if the channel in VDACn_CHxCFG has its REFRESHSOURCE set to REFRESHTIMER                  |
|       | Value         | Mode    |        | Description                                                                                                                                                                                                                             |
|       | 0             | CYCLES2 |        | All channels with enabled refresh are refreshed every 2 CLK_REFRESH cycles                                                                                                                                                              |

| Bit   | Name                | Reset    | Access | Description                                                                                                                                                                                                    |
|-------|---------------------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | CYCLES4             |          |        | All channels with enabled refresh are refreshed every 4 CLK_REFRESH cycles                                                                                                                                     |
| 2     | CYCLES8             |          |        | All channels with enabled refresh are refreshed every 8 CLK_REFRESH cycles                                                                                                                                     |
| 3     | CYCLES16            |          |        | All channels with enabled refresh are refreshed every 16 CLK_REFRESH cycles                                                                                                                                    |
| 4     | CYCLES32            |          |        | All channels with enabled refresh are refreshed every 32 CLK_REFRESH cycles                                                                                                                                    |
| 5     | CYCLES64            |          |        | All channels with enabled refresh are refreshed every 64 CLK_REFRESH cycles                                                                                                                                    |
| 6     | CYCLES128           |          |        | All channels with enabled refresh are refreshed every 128 CLK_REFRESH cycles                                                                                                                                   |
| 7     | CYCLES256           |          |        | All channels with enabled refresh are refreshed every 256 CLK_REFRESH cycles                                                                                                                                   |
| 19    | Reserved            |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 18:16 | TIMEROVERFLOWPERIOD | 0x0      | RW     | <b>Internal Timer Overflow Period</b>                                                                                                                                                                          |
|       |                     |          |        | Select internal timer overflow period. A channel x will be provided with a conversion trigger after the period set in TIMEROVERFLOWPERIOD if the channel in VDACn_CHxCFG has its TRIGMODE set to INTERNALTIMER |
|       | Value               | Mode     |        | Description                                                                                                                                                                                                    |
|       | 0                   | CYCLES2  |        | The Timer overflows every 2 Prescaled CLK_DAC cycles                                                                                                                                                           |
|       | 1                   | CYCLES4  |        | The Timer overflows every 4 Prescaled CLK_DAC cycles                                                                                                                                                           |
|       | 2                   | CYCLES8  |        | The Timer overflows every 8 Prescaled CLK_DAC cycles                                                                                                                                                           |
|       | 3                   | CYCLES16 |        | The Timer overflows every 16 Prescaled CLK_DAC cycles                                                                                                                                                          |
|       | 4                   | CYCLES32 |        | The Timer overflows every 32 Prescaled CLK_DAC cycles                                                                                                                                                          |
|       | 5                   | CYCLES64 |        | The Timer overflows every 64 Prescaled CLK_DAC cycles                                                                                                                                                          |
| 15:14 | Reserved            |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 13:7  | PRES                | 0x0      | RW     | <b>Prescaler Setting for DAC clock</b>                                                                                                                                                                         |
|       |                     |          |        | Selected DAC clock source is prescaled by PRES+1 to generate prescaled CLK_DAC with 50% duty cycle                                                                                                             |
| 6     | Reserved            |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                              |
| 5:4   | REFSEL              | 0x0      | RW     | <b>Reference Selection</b>                                                                                                                                                                                     |
|       |                     |          |        | Select reference for analog portion of DAC                                                                                                                                                                     |
|       | Value               | Mode     |        | Description                                                                                                                                                                                                    |
|       | 0                   | V125     |        | Internal 1.25 V bandgap reference                                                                                                                                                                              |
|       | 1                   | V25      |        | Internal 2.5 V bandgap reference                                                                                                                                                                               |
|       | 2                   | VDD      |        | AVDD reference                                                                                                                                                                                                 |
|       | 3                   | EXT      |        | External pin reference                                                                                                                                                                                         |

| Bit                                                                                                                                                                                                  | Name        | Reset        | Access | Description                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|--------|---------------------------------------------|
| 3                                                                                                                                                                                                    | CH0PRESCRST | 0x0          | RW     | <b>Channel 0 Start Reset Prescaler</b>      |
| Select if prescaler (determining prescaled CLK_DAC rate) is reset on channel 0 start.                                                                                                                |             |              |        |                                             |
| Value                                                                                                                                                                                                |             | Mode         |        | Description                                 |
| 0                                                                                                                                                                                                    |             | NORESETPRES  |        | Prescaler not reset on channel 0 start      |
| 1                                                                                                                                                                                                    |             | RESETPRES    |        | Prescaler reset on channel 0 start          |
| 2                                                                                                                                                                                                    | SINEREFSET  | 0x0          | RW     | <b>Sine Wave Reset When inactive</b>        |
| In case SINEREFSET is 0, SINEMODESTOP will stop progress of the sine wave at the sample currently being output in sinemode. When Set to 1, the sine output will reset to 0 degrees when SINEMODESTOP |             |              |        |                                             |
| 1                                                                                                                                                                                                    | SINEMODE    | 0x0          | RW     | <b>Sine Mode</b>                            |
| Enable/disable sine mode.                                                                                                                                                                            |             |              |        |                                             |
| Value                                                                                                                                                                                                |             | Mode         |        | Description                                 |
| 0                                                                                                                                                                                                    |             | DISSINEMODE  |        | Sine mode disabled. Sine reset to 0 degrees |
| 1                                                                                                                                                                                                    |             | ENSINEMODE   |        | Sine mode enabled                           |
| 0                                                                                                                                                                                                    | DIFF        | 0x0          | RW     | <b>Differential Mode</b>                    |
| Select single ended or differential mode.                                                                                                                                                            |             |              |        |                                             |
| Value                                                                                                                                                                                                |             | Mode         |        | Description                                 |
| 0                                                                                                                                                                                                    |             | SINGLEENDED  |        | Single ended output                         |
| 1                                                                                                                                                                                                    |             | DIFFERENTIAL |        | Differential output                         |

## 28.5.5 VDAC\_STATUS - Status Register

| Offset | Bit Position |              |            |                   |               |               |              |              |                 |                 |            |            |             |             |         |         |        |        |
|--------|--------------|--------------|------------|-------------------|---------------|---------------|--------------|--------------|-----------------|-----------------|------------|------------|-------------|-------------|---------|---------|--------|--------|
| Reset  | 0x0          | 31           | 0x0        | 30                | 0x0           | 29            | 0x0          | 28           | 0x0             | 27              | 0x0        | 26         | 0x0         | 25          | 0x0     | 24      | 0x0    |        |
| Access | R            | R            | R          | R                 | R             | R             | R            | R            | R               | R               | R          | R          | R           | R           | R       | R       | R      |        |
| Name   | SYNCBUSY     | ABUSALLOCERR | SINEACTIVE | ABUSINPUTCONFLICT | CH1FIFOFLBUSY | CH0FIFOFLBUSY | CH1FIFOEMPTY | CH0FIFOEMPTY | CH1CURRENTSTATE | CH0CURRENTSTATE | CH1FIFOCNT | CH0FIFOCNT | CH1FIFOFULL | CH0FIFOFULL | CH1WARM | CH0WARM | CH1ENS | CH0ENS |
|        |              |              |            |                   |               |               |              |              |                 |                 |            |            |             |             |         |         |        |        |

| Bit   | Name              | Reset                                                                                                                                                                      | Access | Description                                                                                                                     |
|-------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------|
| 31    | SYNCBUSY          | 0x0                                                                                                                                                                        | R      | <b>Sync Busy Combined</b><br><br>Indicates synchronization ongoing                                                              |
| 30    | ABUSALLOCERR      | 0x0                                                                                                                                                                        | R      | <b>ABUS Allocation Error Status</b><br><br>1 if ABUS requested is not allocated                                                 |
| 29    | SINEACTIVE        | 0x0                                                                                                                                                                        | R      | <b>Sine Wave Output Status on Channel</b><br><br>1 indicates that sine wave output is generated on CH0 and/or CH1(in diff mode) |
| 28    | ABUSINPUTCONFLICT | 0x0                                                                                                                                                                        | R      | <b>ABUS Input Conflict Status</b><br><br>1 if both CH0 and CH1 request the same ABUS                                            |
| 27    | CH1FIFOFLBUSY     | 0x0                                                                                                                                                                        | R      | <b>CH1 FIFO Flush Sync Busy</b><br><br>Indicates CH1 FIFO Flush Sync Busy                                                       |
| 26    | CH0FIFOFLBUSY     | 0x0                                                                                                                                                                        | R      | <b>CH0 FIFO Flush Sync Busy</b><br><br>Indicates CH0 FIFO Flush Sync Busy                                                       |
| 25:24 | Reserved          | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                                 |
| 23    | CH1FIFOEMPTY      | 0x0                                                                                                                                                                        | R      | <b>Channel 1 FIFO Empty Status</b><br><br>1 if FIFO for Channel 1 is empty                                                      |
| 22    | CH0FIFOEMPTY      | 0x0                                                                                                                                                                        | R      | <b>Channel 0 FIFO Empty Status</b><br><br>1 if FIFO for Channel 0 is empty                                                      |
| 21    | Reserved          | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                                 |
| 20    | CH1CURRENTSTATE   | 0x0                                                                                                                                                                        | R      | <b>Channel 1 Current Status</b><br><br>0 when CH1 is in IDLE State. Set when CH1 is converting data                             |
| 19    | CH0CURRENTSTATE   | 0x0                                                                                                                                                                        | R      | <b>Channel 0 Current Status</b><br><br>0 when CH0 is in IDLE State. Set when CH0 is converting data                             |
| 18    | Reserved          | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                                 |
| 17:15 | CH1FIFOCNT        | 0x0                                                                                                                                                                        | R      | <b>Channel 1 FIFO Valid Count</b>                                                                                               |

| Bit   | Name        | Reset | Access | Description                                                                                                                                                                               |
|-------|-------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             |       |        | Number of Valid Entries in Channel 1. This FIFO entries Count is generated in Read Domain hence expect Synchronization Delay. Need to be used only when VDAC_CFG.ONDEMANDCLK is set to 1. |
| 14:12 | CH0FIFOCNT  | 0x0   | R      | <b>Channel 0 FIFO Valid Count</b>                                                                                                                                                         |
|       |             |       |        | Number of Valid Entries in Channel 0. This FIFO entries Count is generated in Read Domain hence expect Synchronization Delay. Need to be used only when VDAC_CFG.ONDEMANDCLK is set to 1. |
| 11:10 | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>         |
| 9     | CH1FIFOFULL | 0x0   | R      | <b>Channel 1 FIFO Full Status</b>                                                                                                                                                         |
|       |             |       |        | 1 if FIFO for Channel 1 is full                                                                                                                                                           |
| 8     | CH0FIFOFULL | 0x0   | R      | <b>Channel 0 FIFO Full Status</b>                                                                                                                                                         |
|       |             |       |        | 1 if FIFO for Channel 0 is full                                                                                                                                                           |
| 7:6   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>         |
| 5     | CH1WARM     | 0x0   | R      | <b>Channel 1 Warmed Status</b>                                                                                                                                                            |
|       |             |       |        | This bit is set when channel 1 has warmed up                                                                                                                                              |
| 4     | CH0WARM     | 0x0   | R      | <b>Channel 0 Warmed Status</b>                                                                                                                                                            |
|       |             |       |        | This bit is set when channel 0 has warmed up                                                                                                                                              |
| 3:2   | Reserved    |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>         |
| 1     | CH1ENS      | 0x0   | R      | <b>Channel 1 Enabled Status</b>                                                                                                                                                           |
|       |             |       |        | This bit is set when channel 1 is enabled.                                                                                                                                                |
| 0     | CH0ENS      | 0x0   | R      | <b>Channel 0 Enabled Status</b>                                                                                                                                                           |
|       |             |       |        | This bit is set when channel 0 is enabled.                                                                                                                                                |

## 28.5.6 VDAC\_CH0CFG - Channel 0 Config Register

| Offset | Bit Position |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   |   |
|--------|--------------|-----|-----|----|---------------|----|-----|----|---------|----|-----|----|---------------|----|-----|---|---|
| Reset  | 31           | 30  | 29  | 28 | 27            | 26 | 25  | 24 | 23      | 22 | 21  | 20 | 19            | 18 | 17  |   |   |
| Access | RW           | 0x0 | 0x0 | 16 |               | 15 |     |    |         |    |     |    |               |    |     |   |   |
| Name   | KEEPWARM     | RW  | 0x0 | 14 | HIGHCAPLOADEN | RW | 0x0 | 13 | FIFODVL | RW | 0x0 | 11 | REFRESHSOURCE | RW | 0x0 | 8 | 7 |
|        |              |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   | 6 |
|        |              |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   | 5 |
|        |              |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   | 4 |
|        |              |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   | 3 |
|        |              |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   | 2 |
|        |              |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   | 1 |
|        |              |     |     |    |               |    |     |    |         |    |     |    |               |    |     |   | 0 |

| Bit   | Name          | Reset        | Access | Description                                                                                                                                                                                                                            |
|-------|---------------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 16    | KEEPWARM      | 0x0          | RW     | <b>Channel 0 Keepwarm Mode Enable</b><br><br>Set this bit to keep the Channel 0 on in between conversion in sample-off mode. Primary purpose of this is to reduce kickback between Channel 0 and Channel 1 and to reduce startup time. |
| 15    | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 14    | HIGHCAPLOADEN | 0x0          | RW     | <b>Channel 0 High Cap Load Mode Enable</b><br><br>Enables High Capacitance Load Mode for Channel 0. Should be enabled with VDAC_CH0CFG.POWERMODE=HIGH-POWER                                                                            |
| 13    | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 12:11 | FIFODVL       | 0x0          | RW     | <b>Channel 0 FIFO Low Watermark</b><br><br>Set Channel 0 FIFO Low Threshold Data Valid Level (DVL)                                                                                                                                     |
| 10    | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 9:8   | REFRESHSOURCE | 0x0          | RW     | <b>Channel 0 Refresh Source</b><br><br>Select Channel 0 Refresh Trigger                                                                                                                                                                |
|       | Value         | Mode         |        | Description                                                                                                                                                                                                                            |
|       | 0             | NONE         |        | No Refresh Source Selected for Channel 0.                                                                                                                                                                                              |
|       | 1             | REFRESHTIMER |        | Channel 0 Refresh triggered by Refresh Timer Overflow                                                                                                                                                                                  |
|       | 2             | SYNCPRS      |        | Channel 0 Refresh triggered by Sync PRS. PRS Trigger should have the same clock group as VDAC.                                                                                                                                         |
|       | 3             | ASYNCPRS     |        | Channel 0 Refresh triggered by Async PRS                                                                                                                                                                                               |
| 7     | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 6:4   | TRIGMODE      | 0x0          | RW     | <b>Channel 0 Trigger Mode</b><br><br>Select Channel 0 Conversion Trigger                                                                                                                                                               |

| Bit | Name          | Reset      | Access | Description                                                                                                                                                                       |
|-----|---------------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Value         | Mode       |        | Description                                                                                                                                                                       |
| 0   | NONE          |            |        | No Conversion Trigger Source Selected for Channel 0                                                                                                                               |
| 1   | SW            |            |        | Channel 0 is triggered by Channel 0 FIFO (CH0F) write                                                                                                                             |
| 2   | SYNCPRS       |            |        | Channel 0 is triggered by Sync PRS input. PRS Trigger should have the same clock group as VDAC.                                                                                   |
| 4   | INTERNALTIMER |            |        | Channel 0 is triggered by Internal Timer Overflow                                                                                                                                 |
| 5   | ASYNCPRS      |            |        | Channel 0 is triggered by Async PRS input                                                                                                                                         |
| 3   | Reserved      |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2   | POWERMODE     | 0x0        | RW     | <b>Channel 0 Power Mode</b><br><br>Enable Power Mode for Channel 0                                                                                                                |
|     | Value         | Mode       |        | Description                                                                                                                                                                       |
|     | 0             | HIGHPOWER  |        | Default is High Power Mode                                                                                                                                                        |
|     | 1             | LOWPOWER   |        | Set this bit for Low Power Mode                                                                                                                                                   |
| 1   | Reserved      |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0   | CONVMODE      | 0x0        | RW     | <b>Channel 0 Conversion Mode</b><br><br>Configure conversion mode                                                                                                                 |
|     | Value         | Mode       |        | Description                                                                                                                                                                       |
|     | 0             | CONTINUOUS |        | DAC channel 0 is set in continuous mode                                                                                                                                           |
|     | 1             | SAMPLEOFF  |        | DAC channel 0 is set in sample/shut off mode                                                                                                                                      |

## 28.5.7 VDAC\_CH1CFG - Channel 1 Config Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
| 0x018         | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 |     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    | RW | 0x0 |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    | RW | 0x0 |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    | RW | 0x0 |

| Bit   | Name          | Reset        | Access | Description                                                                                                                                                                                                                            |
|-------|---------------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 16    | KEEPWARM      | 0x0          | RW     | <b>Channel 1 Keepwarm Mode Enable</b><br><br>Set this bit to keep the Channel 1 on in between conversion in sample-off mode. Primary purpose of this is to reduce kickback between Channel 0 and Channel 1 and to reduce startup time. |
| 15    | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 14    | HIGHCAPLOADEN | 0x0          | RW     | <b>Channel 1 High Cap Load Mode Enable</b><br><br>Enables High Capacitance Load Mode for Channel 1. Should be enabled with VDAC_CH1CFG.POWERMODE=HIGH-POWER.                                                                           |
| 13    | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 12:11 | FIFODVL       | 0x0          | RW     | <b>Channel 1 FIFO Low Watermark</b><br><br>Set Channel 1 Low threshold Data Valid Level (DVL)                                                                                                                                          |
| 10    | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 9:8   | REFRESHSOURCE | 0x0          | RW     | <b>Channel 1 Refresh Source</b><br><br>Select Channel 1 Refresh Trigger                                                                                                                                                                |
|       | Value         | Mode         |        | Description                                                                                                                                                                                                                            |
|       | 0             | NONE         |        | No Refresh Source Selected                                                                                                                                                                                                             |
|       | 1             | REFRESHTIMER |        | CH1 Refresh Triggered by Refresh Timer Overflow                                                                                                                                                                                        |
|       | 2             | SYNCPRS      |        | CH1 Refresh Triggered by Sync PRS. PRS Trigger should have the same clock group as VDAC.                                                                                                                                               |
|       | 3             | ASYNCPRS     |        | CH1 Refresh Triggered by Async PRS                                                                                                                                                                                                     |
| 7     | Reserved      |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                      |
| 6:4   | TRIGMODE      | 0x0          | RW     | <b>Channel 1 Trigger Mode</b><br><br>Select Channel 1 Conversion Trigger                                                                                                                                                               |

| Bit | Name          | Reset      | Access | Description                                                                                                                                                                       |
|-----|---------------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Value         | Mode       |        | Description                                                                                                                                                                       |
| 0   | NONE          |            |        | No Conversion Trigger Source Selected for Channel 1                                                                                                                               |
| 1   | SW            |            |        | Channel 1 is triggered by Channel 1 FIFO (CH1F) write                                                                                                                             |
| 2   | SYNCPRS       |            |        | Channel 1 is triggered by Sync PRS input.PRS Trigger should have the same clock group as VDAC.                                                                                    |
| 4   | INTERNALTIMER |            |        | Channel 1 is triggered by Internal Timer Overflow                                                                                                                                 |
| 5   | ASYNCPRS      |            |        | Channel 1 is triggered by Async PRS input                                                                                                                                         |
| 3   | Reserved      |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2   | POWERMODE     | 0x0        | RW     | <b>Channel 1 Power Mode</b><br><br>Enable Low Power Mode for Channel 1                                                                                                            |
|     | Value         | Mode       |        | Description                                                                                                                                                                       |
|     | 0             | HIGHPOWER  |        | Default is High Power Mode                                                                                                                                                        |
|     | 1             | LOWPOWER   |        | Set this bit for Low Power Mode                                                                                                                                                   |
| 1   | Reserved      |            |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0   | CONVMODE      | 0x0        | RW     | <b>Channel 1 Conversion Mode</b><br><br>Configure conversion mode for Channel 1                                                                                                   |
|     | Value         | Mode       |        | Description                                                                                                                                                                       |
|     | 0             | CONTINUOUS |        | DAC channel 1 is set in continuous mode                                                                                                                                           |
|     | 1             | SAMPLEOFF  |        | DAC channel 1 is set in sample/shut off mode                                                                                                                                      |

## 28.5.8 VDAC\_CMD - Command Register

| Offset        | Bit Position |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------|--------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x01C         | 31           | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 |
| Reset         |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access        |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name          |              |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| SINEMODESTOP  | W(nB)        | 0x0 | 11 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| SINEMODESTART | W(nB)        | 0x0 | 10 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| CH1FIFOFLUSH  | W(nB)        | 0x0 | 9  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| CH0FIFOFLUSH  | W(nB)        | 0x0 | 8  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| CH1DIS        | W(nB)        | 0x0 | 5  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| CH1EN         | W(nB)        | 0x0 | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| CH0DIS        | W(nB)        | 0x0 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| CH0EN         | W(nB)        | 0x0 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Name                       | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11    | SINEMODESTOP               | 0x0   | W(nB)  | <b>Stop Sine Wave Generation</b>                                                                                                                                                  |
|       | Stop Sine Wave Generation  |       |        |                                                                                                                                                                                   |
| 10    | SINEMODESTART              | 0x0   | W(nB)  | <b>Start Sine Wave Generation</b>                                                                                                                                                 |
|       | Start Sine Wave Generation |       |        |                                                                                                                                                                                   |
| 9     | CH1FIFOFLUSH               | 0x0   | W(nB)  | <b>CH1 WFIFO Flush</b>                                                                                                                                                            |
|       | Flush Channel 1 WFIFO      |       |        |                                                                                                                                                                                   |
| 8     | CH0FIFOFLUSH               | 0x0   | W(nB)  | <b>CH0 WFIFO Flush</b>                                                                                                                                                            |
|       | Flush Channel 0 WFIFO      |       |        |                                                                                                                                                                                   |
| 7:6   | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 5     | CH1DIS                     | 0x0   | W(nB)  | <b>DAC Channel 1 Disable</b>                                                                                                                                                      |
|       | Disables DAC Channel 1     |       |        |                                                                                                                                                                                   |
| 4     | CH1EN                      | 0x0   | W(nB)  | <b>DAC Channel 1 Enable</b>                                                                                                                                                       |
|       | Enables DAC Channel 1      |       |        |                                                                                                                                                                                   |
| 3:2   | Reserved                   |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1     | CH0DIS                     | 0x0   | W(nB)  | <b>DAC Channel 0 Disable</b>                                                                                                                                                      |
|       | Disables DAC Channel 0     |       |        |                                                                                                                                                                                   |
| 0     | CH0EN                      | 0x0   | W(nB)  | <b>DAC Channel 0 Enable</b>                                                                                                                                                       |
|       | Enables DAC Channel 0      |       |        |                                                                                                                                                                                   |

### 28.5.9 VDAC\_IF - Interrupt Flag Register

| Offset | Bit Position      |    |     |    |    |    |    |    |
|--------|-------------------|----|-----|----|----|----|----|----|
| Reset  | 31                | 30 | 29  | 28 | 27 | 26 | 25 | 24 |
| Access |                   |    |     |    |    |    |    |    |
| Name   | ABUSINPUTCONFLICT | RW | 0x0 | 26 | 25 | 24 | 23 | 22 |
|        |                   |    |     |    |    |    |    |    |
|        | CH1DVL            | RW | 0x0 | 21 | 17 | 16 | 15 | 14 |
|        | CH0DVL            | RW | 0x0 | 20 |    | 13 | 12 | 11 |
|        | ABUSALLOCERR      | RW | 0x0 | 18 |    |    | 10 |    |
|        |                   |    |     |    |    |    |    |    |
|        | CH1UF             | RW | 0x0 | 9  |    |    |    |    |
|        | CH0UF             | RW | 0x0 | 8  |    |    |    |    |
|        | CH1OF             | RW | 0x0 | 5  |    |    |    |    |
|        | CH0OF             | RW | 0x0 | 4  |    |    |    |    |
|        | CH1CD             | RW | 0x0 | 1  |    |    |    |    |
|        | CH0CD             | RW | 0x0 | 0  |    |    |    |    |

| Bit   | Name              | Reset | Access | Description                                                                                                                                                       |
|-------|-------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 26    | ABUSINPUTCONFLICT | 0x0   | RW     | <b>ABUS Input Conflict Error Flag</b><br>Set if both CH0 and CH1 request same ABUS. Should only be enabled when using ABUS for VDAC Output.                       |
| 25:22 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 21    | CH1DVL            | 0x0   | RW     | <b>CH1 Data Valid Level Interrupt Flag</b><br>Set when Channel 1 FIFO Count reaches Data Valid Level. Also used as Wakeup IRQ                                     |
| 20    | CH0DVL            | 0x0   | RW     | <b>CH0 Data Valid Level Interrupt Flag</b><br>Set when Channel 0 FIFO Count reaches Data Valid Level. Also used as Wakeup IRQ                                     |
| 19    | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 18    | ABUSALLOCERR      | 0x0   | RW     | <b>ABUS Port Allocation Error Flag</b><br>Set if APORT requested is not allocated. Should only be enabled when using ABUS for VDAC Output.                        |
| 17:10 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9     | CH1UF             | 0x0   | RW     | <b>CH1 Data Underflow Interrupt Flag</b><br>Indicates channel 1 data underflow.                                                                                   |
| 8     | CH0UF             | 0x0   | RW     | <b>CH0 Data Underflow Interrupt Flag</b><br>Indicates channel 0 data underflow.                                                                                   |
| 7:6   | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 5     | CH1OF             | 0x0   | RW     | <b>CH1 Data Overflow Interrupt Flag</b><br>Indicates channel 1 data overflow.                                                                                     |
| 4     | CH0OF             | 0x0   | RW     | <b>CH0 Data Overflow Interrupt Flag</b><br>Indicates channel 0 data overflow.                                                                                     |
| 3:2   | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |

| Bit | Name  | Reset | Access | Description                                                                           |
|-----|-------|-------|--------|---------------------------------------------------------------------------------------|
| 1   | CH1CD | 0x0   | RW     | <b>CH1 Conversion Done Interrupt Flag</b><br>Indicates channel 1 conversion complete. |
| 0   | CH0CD | 0x0   | RW     | <b>CH0 Conversion Done Interrupt Flag</b><br>Indicates channel 0 conversion complete. |

#### 28.5.10 VDAC\_IEN - Interrupt Enable Register

| Offset | Bit Position      |    |     |    |    |    |    |    |
|--------|-------------------|----|-----|----|----|----|----|----|
| Reset  | 31                | 30 | 29  | 28 | 27 | 26 | 25 | 24 |
| Access |                   |    |     |    |    |    |    |    |
| Name   | ABUSINPUTCONFLICT | RW | 0x0 | 26 | 25 | 24 | 23 | 22 |
|        |                   |    |     |    |    |    |    |    |
|        | CH1DVL            | RW | 0x0 | 21 | 17 | 16 | 15 | 14 |
|        | CH0DVL            | RW | 0x0 | 20 |    | 13 | 12 | 11 |
|        | ABUSALLOCERR      | RW | 0x0 | 18 |    |    | 10 |    |
|        |                   |    |     |    |    |    |    |    |
|        | CH1UF             | RW | 0x0 | 9  |    |    |    |    |
|        | CH0UF             | RW | 0x0 | 8  |    |    |    |    |
|        | CH1OF             | RW | 0x0 | 5  |    |    |    |    |
|        | CH0OF             | RW | 0x0 | 4  |    |    |    |    |
|        | CH1CD             | RW | 0x0 | 1  |    |    |    |    |
|        | CH0CD             | RW | 0x0 | 0  |    |    |    |    |

| Bit   | Name              | Reset | Access | Description                                                                                                                                                       |
|-------|-------------------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 26    | ABUSINPUTCONFLICT | 0x0   | RW     | <b>ABUS Input Conflict Interrupt Flag</b><br><br>Set to enable the ABUSINPUTCONFLICTIF Interrupt                                                                  |
| 25:22 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 21    | CH1DVL            | 0x0   | RW     | <b>CH1 Data Valid Level Interrupt Flag</b><br><br>Set to enable the CH1DVLIF Interrupt                                                                            |
| 20    | CH0DVL            | 0x0   | RW     | <b>CH0 Data Valid Level Interrupt Flag</b><br><br>Set to enable the CH0DVLIF Interrupt                                                                            |
| 19    | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 18    | ABUSALLOCERR      | 0x0   | RW     | <b>ABUS Allocation Error Interrupt Flag</b><br><br>Set to enable the ABUSALLOCERRIF Interrupt                                                                     |
| 17:10 | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 9     | CH1UF             | 0x0   | RW     | <b>CH1 Data Underflow Interrupt Flag</b><br><br>Set to enable the CH1UFIF Interrupt                                                                               |
| 8     | CH0UF             | 0x0   | RW     | <b>CH0 Data Underflow Interrupt Flag</b><br><br>Set to enable the CH0UFIF Interrupt                                                                               |
| 7:6   | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 5     | CH1OF             | 0x0   | RW     | <b>CH1 Data Overflow Interrupt Flag</b><br><br>Set to enable the CH1OFIF Interrupt                                                                                |
| 4     | CH0OF             | 0x0   | RW     | <b>CH0 Data Overflow Interrupt Flag</b><br><br>Set to enable the CH0OFIF Interrupt                                                                                |
| 3:2   | Reserved          |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |

| Bit | Name  | Reset | Access | Description                                                                          |
|-----|-------|-------|--------|--------------------------------------------------------------------------------------|
| 1   | CH1CD | 0x0   | RW     | <b>CH1 Conversion Done Interrupt Flag</b><br><br>Set to enable the CH1CDIF Interrupt |
| 0   | CH0CD | 0x0   | RW     | <b>CH0 Conversion Done Interrupt Flag</b><br><br>Set to enable the CH0CDIF Interrupt |

**28.5.11 VDAC\_CH0F - Channel 0 Data Write Fifo**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 0x028         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0  |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W    |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DATA |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:0  | DATA     | 0x0   | W      | <b>Channel 0 Data</b><br><br>This register writes the value which will be converted by DAC channel 0 in a FIFO.                                                                   |

**28.5.12 VDAC\_CH1F - Channel 1 Data Write Fifo**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 0x02C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0  |   |   |   |   |   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | W    |   |   |   |   |   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DATA |   |   |   |   |   |   |   |

| Bit   | Name     | Reset | Access | Description                                                                                                                                                                       |
|-------|----------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 11:0  | DATA     | 0x0   | W      | <b>Channel 1 Data</b><br><br>This register writes the value which will be converted by DAC channel 1 into a FIFO                                                                  |

## 28.5.13 VDAC\_OUTCTRL - DAC Output Control

| Offset | Bit Position  |                |               |                |          |          |             |             |             |             |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |  |
|--------|---------------|----------------|---------------|----------------|----------|----------|-------------|-------------|-------------|-------------|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|--|
| 0x030  | 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  |     |  |
| Reset  |               |                |               |                |          |          |             |             |             |             |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |  |
| Access |               | RW             | 0x0           | RW             | 0x0      | RW       | 0x0         | RW          | 0x0         | RW          | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 | RW | 0x0 |  |
| Name   | ABUSPINSELCH1 | ABUSPORTSELCH1 | ABUSPINSELCH0 | ABUSPORTSELCH0 | SHORTCH1 | SHORTCH0 | AUXOUTENCH1 | AUXOUTENCH0 | MANOUTENCH1 | MANOUTENCH0 |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |  |

| Bit   | Name           | Reset | Access                 | Description                                                                                                                                                       |
|-------|----------------|-------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved       |       |                        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 30:25 | ABUSPINSELCH1  | 0x0   | RW                     | <b>CH1 ABUS Pin Select</b><br>Set this to Select a particular ABUS Pin for Channel 1                                                                              |
| 24:22 | ABUSPORTSELCH1 | 0x0   | RW                     | <b>CH1 ABUS Port Select</b><br>Set this to Select a particular ABUS Port for Channel 1                                                                            |
|       |                |       | Value Mode Description |                                                                                                                                                                   |
|       |                |       | 0                      | NONE No GPIO Selected for CH1 ABUS Output                                                                                                                         |
|       |                |       | 1                      | PORTA Port A Selected                                                                                                                                             |
|       |                |       | 2                      | PORTB Port B Selected                                                                                                                                             |
|       |                |       | 3                      | PORTC Port C Selected                                                                                                                                             |
|       |                |       | 4                      | PORTD Port D Selected                                                                                                                                             |
| 21    | Reserved       |       |                        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 20:15 | ABUSPINSELCH0  | 0x0   | RW                     | <b>CH0 ABUS Pin Select</b><br>Set this to Select a particular ABUS Pin for Channel 0                                                                              |
| 14:12 | ABUSPORTSELCH0 | 0x0   | RW                     | <b>CH0 ABUS Port Select</b><br>Set this to Select a particular ABUS Port for Channel 0                                                                            |
|       |                |       | Value Mode Description |                                                                                                                                                                   |
|       |                |       | 0                      | NONE No GPIO Selected for CH0 ABUS Output                                                                                                                         |
|       |                |       | 1                      | PORTA Port A Selected                                                                                                                                             |
|       |                |       | 2                      | PORTB Port B Selected                                                                                                                                             |
|       |                |       | 3                      | PORTC Port C Selected                                                                                                                                             |
|       |                |       | 4                      | PORTD Port D Selected                                                                                                                                             |
| 11:10 | Reserved       |       |                        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |

| Bit | Name         | Reset | Access | Description                                                                                                                                                                                                                 |
|-----|--------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | SHORTCH1     | 0x0   | RW     | <b>CH0 Main and Alternative Output Short</b><br><br>Set this to short circuit Main and alternative Output of Channel 0. Usefull to connect Main and Alternative outputs together when DAC is enabled but not warmed up yet. |
| 8   | SHORTCH0     | 0x0   | RW     | <b>CH1 Main and Alternative Output Short</b><br><br>Set this to short circuit Main and alternative Output of Channel 1. Usefull to connect Main and Alternative outputs together when DAC is enabled but not warmed up yet. |
| 7:6 | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |
| 5   | AUXOUTENCH1  | 0x0   | RW     | <b>CH1 Alternative Output Enable</b><br><br>Set this to enable alternative output of Channel 1                                                                                                                              |
| 4   | AUXOUTENCH0  | 0x0   | RW     | <b>CH0 Alternative Output Enable</b><br><br>Set this to enable alternative output of Channel 0                                                                                                                              |
| 3:2 | Reserved     |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                           |
| 1   | MAINOUTENCH1 | 0x0   | RW     | <b>CH1 Main Output Enable</b><br><br>Set this to enable main output of Channel 1                                                                                                                                            |
| 0   | MAINOUTENCH0 | 0x0   | RW     | <b>CH0 Main Output Enable</b><br><br>Set this to enable main output of Channel 0                                                                                                                                            |

**28.5.14 VDAC\_OUTTIMERCFG - DAC Out Timer Config Register**

| Offset | Bit Position   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                |   |   |
|--------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------------|---|---|
| 0x034  | 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 |
| Reset  | 0x0            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | 0x0            |   |   |
| Access | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | RW             |   |   |
| Name   | CH1OUTHOLDTIME |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | CH0OUTHOLDTIME |   |   |

| Bit   | Name           | Reset | Access | Description                                                                                                                                                                       |
|-------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 24:15 | CH1OUTHOLDTIME | 0x0   | RW     | <b>CH1 Output Hold Time</b><br><br>Number of prescaled CLK_DAC cycles to drive the output of VDAC for Channel 1                                                                   |
| 14:10 | Reserved       |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 9:0   | CH0OUTHOLDTIME | 0x0   | RW     | <b>CH0 Output Hold Time</b><br><br>Number of prescaled CLK_DAC cycles to drive the output of VDAC for Channel 0                                                                   |

## 29. ACMP - Analog Comparator



### Quick Facts

#### What?

The ACMP (Analog Comparator) compares two analog signals and returns a digital value telling which is greater.

#### Why?

Applications often do not need to know the exact value of an analog signal, only if it has passed a certain threshold. Often the voltage must be monitored continuously, which requires extremely low power consumption.

#### How?

Available down to Energy Mode 3, the ACMP can wake up the system when input signals pass the threshold. The analog comparator can compare two analog signals or one analog signal and a highly configurable internal reference.

### 29.1 Introduction

The Analog Comparator compares the voltage of two analog inputs and outputs a digital signal indicating which input voltage is higher. Inputs can either be from internal references or from external pins. Response time, and thereby the current consumption, can be configured by altering the current supply to the comparator.

### 29.2 Features

- Internal and external input selections:
  - External port I/O routed via ABUS
  - Internal 1.25 V bandgap reference voltage with programmable divider
  - Internal 2.5 V bandgap reference voltage with programmable divider
  - AVDD supply voltage with programmable divider
  - VDAC auxiliary outputs
- Voltage supply monitoring
- Configurable hysteresis
- Selectable response time
- Operational in EM0 to EM3
- Asynchronous interrupt generation on selectable edges
- Configurable output state when inactive
- Output routing options:
  - Route to GPIO via DBUS
  - Route to most peripherals via PRS

### 29.3 Functional Description

An overview of the ACMP is shown in [Figure 29.1 ACMP Overview on page 1110](#).



**Figure 29.1. ACMP Overview**

The comparator has two analog inputs: one positive and one negative. When the comparator is active, the output indicates which of the two input voltages is higher. When the voltage on the positive input is higher than the voltage on the negative input, the digital output is high and vice versa.

In addition to the comparator core, the ACMP front-end includes reference sources, voltage divider circuits, and input muxes to route signals to the positive and negative inputs. The output from the ACMP is available on both PRS and GPIO, in addition to being observable in the ACMP\_STATUS register.

### 29.3.1 Configuration and Control

The ACMP is configured and controlled through three registers: ACMP\_CFG, ACMP\_CTRL, and ACMP\_INPUTCTRL. Configuration through ACMP\_CFG needs to happen before the ACMP is enabled. The control registers ACMP\_CTRL and ACMP\_INPUTCTRL can only be updated after the ACMP is enabled. The ACMP is enabled by setting the EN bit in ACMP\_EN. If ACMP\_CFG is updated when EN = 1, or ACMP\_CTRL / ACMP\_INPUTCTRL is updated while EN = 0, a bus fault is issued.

The input muxes are configured in the POSSEL / NEGSEL bitfields in ACMP\_INPUTCTRL. All references and inputs are available in the modes defined for these two registers. The INPUTCTRL bit in ACMP\_SYNCBUSY should be checked before writing to ACMP\_INPUTCTRL. If the ACMP\_SYNCBUSY\_INPUTCTRL bit is 1, it means a previous write to the ACMP\_INPUTCTRL register is pending, and software should wait until ACMP\_SYNCBUSY\_INPUTCTRL bit reads 0.

The POSSEL and NEGSEL muxes share several resources on the device, such as the VREFDIV and VSENSE divider circuits. Thus, there are some constraints on the POSSEL / NEGSEL configurations:

- POSSEL and NEGSEL cannot select an even numbered GPIO pin at the same time.
- POSSEL and NEGSEL cannot select an odd numbered GPIO pin at the same time.
- POSSEL and NEGSEL cannot both select a supply voltage via one of the VSENSE inputs.
- POSSEL and NEGSEL cannot both select an input using VREFDIV.
- If POSSEL = EXTPx, a low power reference (postfixed with LP) cannot be selected for NEGSEL.

If one of these constraints are violated, the INPUTCONFLICT status flag and INPUTCONFLICTIF interrupt flag will be set.

The ACMP also uses shared chip-level analog bus resources to connect to external GPIO pins. Which bus the ACMP is using depends on the configuration of POSSEL and NEGSEL. To allow the ACMP to control an analog bus, the bus must be allocated to ACMP in the GPIO module, using the GPIO\_xBUSALLOC registers. For example, pin PB5 is an odd-numbered pin on port PB, and could connect via either analog bus BODD0 or BODD1. This is configured using the BODD0 or BODD1 field in GPIO\_BBUSALLOC.

If the ACMP peripheral is trying to access a bus that has not been allocated to that instance of ACMP, the PORTALLOCERR status flag and PORTALLOCERRIF interrupt flag will be set.

### 29.3.2 Warmup Time

When the comparator is enabled or the input muxes are reconfigured, it requires some time to stabilize. On first enable (ACMP\_EN\_EN = 1), the comparator core requires 2.5 us to stabilize. In addition to this, any references selected may require some time to warm up. See table Table 29.1 Warmup Time on page 1111 for warmup times for the different references. When reconfiguring the ACMP (without disabling it), only the warmup times given in the table will be observed. When the comparator is ready for use, the ACMPRDY status flag and the ACMPRDY interrupt flag will be set.

**Note:** The hardware timeout is not sufficient to ensure glitch-free operation when using BIAS<=3. To avoid startup glitches, software should wait for 60 us after enabling the comparator to use the output.

During the warmup time and when the comparator is inactive, the comparator output will be set to the state defined by the NOTRDYV\_AL bit in ACMP\_CTRL.

Table 29.1. Warmup Time

| Reference                                  | Warmup time |
|--------------------------------------------|-------------|
| Low power reference: POSSEL / NEGSEL = *LP | 10 us       |
| VSENSE: POSSEL / NEGSEL = VSENSE*          | 5 us        |
| VREF: POSSEL / NEGSEL = VREF*              | 2 us        |
| None of the above                          | 0.5 us      |

### 29.3.3 Response Time

There is a delay from when the input voltage changes polarity to when the output toggles. This delay is called the response time and can be altered by increasing or decreasing the bias current to the comparator through the BIASPROG bitfield in the ACMP\_CFG register. The current and speed of the circuit increase as the value of BIASPROG is increased. See the part datasheet for specific current and response times related to setting of BIASPROG.

### 29.3.4 Hysteresis

When the hysteresis level is set to a non-zero value, the digital output will not toggle until the positive input voltage is at a voltage equal to the hysteresis level above or below the negative input voltage (see [Figure 29.2 Hysteresis on page 1112](#)). This feature can be used to avoid continual comparator output changes due to input noise when the positive and negative inputs are similar. Hysteresis requires the input difference to exceed the hysteresis threshold before the output can change and can reject limited amounts of noise. The hysteresis in ACMP can be configured to three different levels (10 mV, 20 mV, 30 mV), and can be enabled on positive (rising), negative (falling), or both edges. Hysteresis is configured in the HYST bitfield in ACMP\_CFG.



**Figure 29.2. Hysteresis**

### 29.3.5 Supply Voltage Monitoring (VSENSE)

The ACMP can be used to monitor supply voltages. This is done by selecting VSENSE01DIV4(LP) or VSENSE11DIV4(LP) for either POSSEL or NEGSEL. Note that the input to the comparator core will be divided by 4, as illustrated in [Figure 29.1 ACMP Overview on page 1110](#). To reduce energy consumption, a sample/hold circuit can be used to periodically sample the power supplies. To enable this, select VSENSE01DIV4LP or VSENSE11DIV4LP in POSSEL / NEGSEL. Because the sample/hold feature uses the comparator in a non-continuous fashion, enabling this will increase response times and reduce the accuracy of the comparator. The connections between VSENSE0 and VSENSE1 to power supplies are summarized in the table below.

**Table 29.2. VSENSE connections**

| ACMP instance | VSENSE0 | VSENSE1       |
|---------------|---------|---------------|
| ACMP0         | AVDD    | VDDIO0        |
| ACMP1         | DVDD    | Not connected |

### 29.3.6 VREFDIV Sources

The ACMP has two internal bandgap references: 2.5 V and 1.25 V. In addition, AVDD can be used as a reference. To select one of these references, configure POSSEL / NEGSEL to VREFDIVAVDD, VREFDIV1V25, or VREFDIV2V5. The ACMP also includes sample/hold functionality to reduce energy consumption. To enable the sample/hold feature, select VREFDIVAVDDLP, VREFDIV1V25LP, or VREFDIV2V5LP. These references can be divided by configuring VREFDIV in ACMP\_INPUTCTRL. This division factor will be VREFDIV / 63, such that VREFOUT = VREFIN \* (VREFDIV / 63).

### 29.3.7 Input Range and Accuracy Settings

By default, the ACMP can accept external rail-to-rail inputs, from 0 to AVDD. If external voltages will never be higher than AVDD - 0.7 V, the INPUTRANGE bit in ACMP\_CFG can be set to 1 to reduce the power consumption of the block.

The ACMP also has an adjustable accuracy setting (ACCURACY in ACMP\_CFG). ACCURACY is set to LOW by default, which conserves power, but may have degraded performance for rapidly changing analog Port selections in either the ACMP or the GPIO. ACCURACY can be set to HIGH to insure ACMP accuracy (at the expense of extra power consumption), when configuration changes are expected at a high rate (more than once per ms, for example), such as when scanning through channels.

### 29.3.8 Interrupts and PRS Output

The analog comparator includes independent output flags for rising edge (RISEIF) and falling edge (FALLIF) events. These will be set when a rising or falling edge is detected, respectively.

Three other interrupt sources are also available. PORTALLOCERRIF and INPUTCONFLICTIF are input configuration error flags, detailed in [29.3.1 Configuration and Control](#). The ACMPRDYIF flag indicates comparator stability after the warmup period.

The comparator output is available as an asynchronous PRS producer, and can be routed to other peripherals in the system via PRS.

### 29.3.9 Output to GPIO

The output from the comparator is available as alternate functions to the GPIO pins. Each pin connection can be enabled/disabled separately using the GPIO module control registers. See the device data sheet for the available locations for each signal.

The GPIO pin must also be set as output. The output to the GPIO can be inverted by setting the GPIOINV bit in ACMP\_CTRL.

## 29.4 ACMP Register Map

The offset register address is relative to the registers base address.

| Offset | Name               | Type        | Description               |
|--------|--------------------|-------------|---------------------------|
| 0x000  | ACMP_IPVERSION     | R           | IP Version ID             |
| 0x004  | ACMP_EN            | RW ENABLE   | ACMP Enable               |
| 0x008  | ACMP_SWRST         | RW SWRST    | Software Reset            |
| 0x00C  | ACMP_CFG           | RW CONFIG   | Configuration Register    |
| 0x010  | ACMP_CTRL          | RW          | Control Register          |
| 0x014  | ACMP_INPUTCTRL     | RW SYNC     | Input Control Register    |
| 0x018  | ACMP_STATUS        | RH          | Status Register           |
| 0x01C  | ACMP_IF            | RWH INTFLAG | Interrupt Flag Register   |
| 0x020  | ACMP_IEN           | RW          | Interrupt Enable Register |
| 0x024  | ACMP_SYNCBUSY      | RH          | Syncbusy                  |
| 0x1000 | ACMP_IPVERSION_SET | R           | IP Version ID             |
| 0x1004 | ACMP_EN_SET        | RW ENABLE   | ACMP Enable               |
| 0x1008 | ACMP_SWRST_SET     | RW SWRST    | Software Reset            |
| 0x100C | ACMP_CFG_SET       | RW CONFIG   | Configuration Register    |
| 0x1010 | ACMP_CTRL_SET      | RW          | Control Register          |
| 0x1014 | ACMP_INPUTCTRL_SET | RW SYNC     | Input Control Register    |
| 0x1018 | ACMP_STATUS_SET    | RH          | Status Register           |
| 0x101C | ACMP_IF_SET        | RWH INTFLAG | Interrupt Flag Register   |
| 0x1020 | ACMP_IEN_SET       | RW          | Interrupt Enable Register |
| 0x1024 | ACMP_SYNCBUSY_SET  | RH          | Syncbusy                  |
| 0x2000 | ACMP_IPVERSION_CLR | R           | IP Version ID             |
| 0x2004 | ACMP_EN_CLR        | RW ENABLE   | ACMP Enable               |
| 0x2008 | ACMP_SWRST_CLR     | RW SWRST    | Software Reset            |
| 0x200C | ACMP_CFG_CLR       | RW CONFIG   | Configuration Register    |
| 0x2010 | ACMP_CTRL_CLR      | RW          | Control Register          |
| 0x2014 | ACMP_INPUTCTRL_CLR | RW SYNC     | Input Control Register    |
| 0x2018 | ACMP_STATUS_CLR    | RH          | Status Register           |
| 0x201C | ACMP_IF_CLR        | RWH INTFLAG | Interrupt Flag Register   |
| 0x2020 | ACMP_IEN_CLR       | RW          | Interrupt Enable Register |
| 0x2024 | ACMP_SYNCBUSY_CLR  | RH          | Syncbusy                  |
| 0x3000 | ACMP_IPVERSION_TGL | R           | IP Version ID             |
| 0x3004 | ACMP_EN_TGL        | RW ENABLE   | ACMP Enable               |
| 0x3008 | ACMP_SWRST_TGL     | RW SWRST    | Software Reset            |
| 0x300C | ACMP_CFG_TGL       | RW CONFIG   | Configuration Register    |
| 0x3010 | ACMP_CTRL_TGL      | RW          | Control Register          |

| Offset | Name               | Type        | Description               |
|--------|--------------------|-------------|---------------------------|
| 0x3014 | ACMP_INPUTCTRL_TGL | RW SYNC     | Input Control Register    |
| 0x3018 | ACMP_STATUS_TGL    | RH          | Status Register           |
| 0x301C | ACMP_IF_TGL        | RWH INTFLAG | Interrupt Flag Register   |
| 0x3020 | ACMP_IEN_TGL       | RW          | Interrupt Enable Register |
| 0x3024 | ACMP_SYNCBUSY_TGL  | RH          | Syncbusy                  |

## 29.5 ACMP Register Description

### 29.5.1 ACMP\_IPVERSION - IP Version ID

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x2          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description   |
|------|-----------|-------|--------|---------------|
| 31:0 | IPVERSION | 0x2   | R      | IP version ID |

**29.5.2 ACMP\_EN - ACMP Enable**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------|----|
| 0x004         | 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  |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0 1     |    |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | R         |    |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | DISABLING | EN |

| Bit  | Name            | Reset                                                                                                                                                                      | Access | Description                                                                                                                                                                                                                                            |
|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | <i>Reserved</i> | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                                                                                                                                                                                                                                        |
| 1    | DISABLING       | 0x0                                                                                                                                                                        | R      | <b>Disablement busy status</b><br><br>When En is cleared, DISABLING is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and not APB registers except hardware updated registers such as INTFLAGS and FIFOs. |
| 0    | EN              | 0x0                                                                                                                                                                        | RW     | <b>Module enable</b><br><br>The ENABLE bit enables the module. Software should write to CONFIG type registers before setting the ENABLE bit. Software should write to SYNC type registers only after setting the ENABLE bit.                           |

**29.5.3 ACMP\_SWRST - Software Reset**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |       |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------|-------|
| 0x008         | 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     |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 0x0 1     |       |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | R         |       |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | RESETTING | SWRST |

| Bit  | Name            | Reset                                                                                                                                                                      | Access | Description                       |
|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------|
| 31:2 | <i>Reserved</i> | To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a> |        |                                   |
| 1    | RESETTING       | 0x0                                                                                                                                                                        | R      | <b>Software reset busy status</b> |
| 0    | SWRST           | 0x0                                                                                                                                                                        | W      | <b>Software reset</b>             |

## 29.5.4 ACMP\_CFG - Configuration Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 0x00C  | 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 |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0        |    |    |    |    |    |   |   |   | 0x4  |   |   |   |   |   |   |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |    |    |    |    |    |   |   |   | RW   |   |   |   |   |   |   |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ACCURACY   |    |    |    |    |    |   |   |   | HYST |   |   |   |   |   |   |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | INPUTRANGE |    |    |    |    |    |   |   |   | BIAS |   |   |   |   |   |   |

| Bit   | Name       | Reset    | Access | Description                                                                                                                                                                                                                                                                              |
|-------|------------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved   |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                        |
| 17    | ACCURACY   | 0x0      | RW     | <b>ACMP accuracy mode</b><br><br>Setting ACCURACY to HIGH reduces the noise in the signal input path of the ACMP. Note, high frequency changes can cause the ACMP performance to degrade. For such uses, such as quickly scanning through multiple channels, this should be set to HIGH. |
|       | Value      | Mode     |        | Description                                                                                                                                                                                                                                                                              |
|       | 0          | LOW      |        | ACMP operates in low-accuracy mode but consumes less current.                                                                                                                                                                                                                            |
|       | 1          | HIGH     |        | ACMP operates in high-accuracy mode but consumes more current.                                                                                                                                                                                                                           |
| 16    | INPUTRANGE | 0x0      | RW     | <b>Input Range</b><br><br>Adjust performance of the comparator for a given input voltage range.                                                                                                                                                                                          |
|       | Value      | Mode     |        | Description                                                                                                                                                                                                                                                                              |
|       | 0          | FULL     |        | Use this setting when the input to the comparator core can be from 0 to AVDD.                                                                                                                                                                                                            |
|       | 1          | REDUCED  |        | It is recommended to use this setting when the input to the comparator core will always be less than AVDD-0.7V.                                                                                                                                                                          |
| 15:12 | Reserved   |          |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                        |
| 11:8  | HYST       | 0x0      | RW     | <b>Hysteresis mode</b><br><br>Set hysteresis mode and level.                                                                                                                                                                                                                             |
|       | Value      | Mode     |        | Description                                                                                                                                                                                                                                                                              |
|       | 0          | DISABLED |        | Hysteresis disabled                                                                                                                                                                                                                                                                      |
|       | 1          | SYM10MV  |        | 10mV symmetrical hysteresis                                                                                                                                                                                                                                                              |
|       | 2          | SYM20MV  |        | 20mV symmetrical hysteresis                                                                                                                                                                                                                                                              |
|       | 3          | SYM30MV  |        | 30mV symmetrical hysteresis                                                                                                                                                                                                                                                              |
|       | 4          | POS10MV  |        | 10mV hysteresis on positive edge transitions                                                                                                                                                                                                                                             |
|       | 5          | POS20MV  |        | 20mV hysteresis on positive edge transitions                                                                                                                                                                                                                                             |

| Bit | Name                                                                      | Reset | Access | Description                                                                                                                                                                       |
|-----|---------------------------------------------------------------------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | POS30MV                                                                   |       |        | 30mV hysteresis on positive edge transitions                                                                                                                                      |
| 8   | NEG10MV                                                                   |       |        | 10mV hysteresis on negative edge transitions                                                                                                                                      |
| 9   | NEG20MV                                                                   |       |        | 20mV hysteresis on negative edge transitions                                                                                                                                      |
| 10  | NEG30MV                                                                   |       |        | 30mV hysteresis on negative edge transitions                                                                                                                                      |
| 7:3 | Reserved                                                                  |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 2:0 | BIAS                                                                      | 0x4   | RW     | <b>Bias Configuration</b>                                                                                                                                                         |
|     | These bits control the bias current level. See the datasheet for details. |       |        |                                                                                                                                                                                   |

### **29.5.5 ACMP\_CTRL - Control Register**

| Bit  | Name      | Reset  | Access | Description                                                                                                                                                                       |
|------|-----------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved  |        |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | GPIOINV   | 0x0    | RW     | <b>Comparator GPIO Output Invert</b><br><br>Set this bit to 1 to invert the comparator alternate function output to GPIO.                                                         |
|      | Value     | Mode   |        | Description                                                                                                                                                                       |
|      | 0         | NOTINV |        | The comparator output to GPIO is not inverted                                                                                                                                     |
|      | 1         | INV    |        | The comparator output to GPIO is inverted                                                                                                                                         |
| 0    | NOTRDYVAL | 0x0    | RW     | <b>Not Ready Value</b><br><br>The value of this bit is used as the comparator output when the comparator is not ready.                                                            |
|      | Value     | Mode   |        | Description                                                                                                                                                                       |
|      | 0         | LOW    |        | ACMP output is 0 when the ACMP is not ready.                                                                                                                                      |
|      | 1         | HIGH   |        | ACMP output is 1 when the ACMP is not ready.                                                                                                                                      |

## 29.5.6 ACMP\_INPUTCTRL - Input Control Register

| Offset | Bit Position |          |    |     |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |        |    |   |   |   |   |   |   |   |   |   |   |         |  |
|--------|--------------|----------|----|-----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|--------|----|---|---|---|---|---|---|---|---|---|---|---------|--|
| 0x014  | 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 |         |  |
| Reset  |              |          |    | 0x0 |    |    |    |    |    |    |    |    | 0x0     |    |    |    |    |    |    |    | 0x0    |    |   |   |   |   |   |   |   |   |   |   |         |  |
| Access |              |          | RW |     |    |    |    |    |    |    |    |    | RW      |    |    |    |    |    |    |    | RW     |    |   |   |   |   |   |   |   |   |   |   |         |  |
| Name   |              | CSRESSEL |    |     |    |    |    |    |    |    |    |    | VREFDIV |    |    |    |    |    |    |    | NEGSEL |    |   |   |   |   |   |   |   |   |   |   | POSSSEL |  |

| Bit   | Name     | Reset          | Access | Description                                                                                                                                                       |
|-------|----------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 30:28 | CSRESSEL | 0x0            | RW     | <b>Capacitive Sense Mode Internal Resistor</b><br><br>Deprecated capacitive sensing feature, not recommended for new designs                                      |
|       | Value    | Mode           |        | Description                                                                                                                                                       |
|       | 0        | RES0           |        | Internal capacitive sense resistor value 0                                                                                                                        |
|       | 1        | RES1           |        | Internal capacitive sense resistor value 1                                                                                                                        |
|       | 2        | RES2           |        | Internal capacitive sense resistor value 2                                                                                                                        |
|       | 3        | RES3           |        | Internal capacitive sense resistor value 3                                                                                                                        |
|       | 4        | RES4           |        | Internal capacitive sense resistor value 4                                                                                                                        |
|       | 5        | RES5           |        | Internal capacitive sense resistor value 5                                                                                                                        |
|       | 6        | RES6           |        | Internal capacitive sense resistor value 6                                                                                                                        |
| 27:22 | Reserved |                |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 21:16 | VREFDIV  | 0x0            | RW     | <b>VREF division</b><br><br>Set division factor for VREFDIV. VREFOUT = VREFIN * (VREFDIV / 63)                                                                    |
| 15:8  | NEGSEL   | 0x0            | RW     | <b>Negative Input Select</b><br><br>Select negative input.                                                                                                        |
|       | Value    | Mode           |        | Description                                                                                                                                                       |
|       | 0        | VSS            |        | VSS                                                                                                                                                               |
|       | 16       | VREFDIVAVDD    |        | Divided AVDD                                                                                                                                                      |
|       | 17       | VREFDIVAVDDLP  |        | Low-Power Divided AVDD                                                                                                                                            |
|       | 18       | VREFDIV1V25    |        | Divided 1V25 reference                                                                                                                                            |
|       | 19       | VREFDIV1V25LP  |        | Low-power Divided 1V25 reference                                                                                                                                  |
|       | 20       | VREFDIV2V5     |        | Divided 2V5 reference                                                                                                                                             |
|       | 21       | VREFDIV2V5LP   |        | Low-power Divided 2V5 reference                                                                                                                                   |
|       | 32       | VSENSE01DIV4   |        | VSENSE0 divided by 4                                                                                                                                              |
|       | 33       | VSENSE01DIV4LP |        | Low-power VSENSE0 divided by 4                                                                                                                                    |

| Bit | Name           | Reset | Access | Description                                                            |
|-----|----------------|-------|--------|------------------------------------------------------------------------|
| 34  | VSENSE11DIV4   |       |        | VSENSE1 divided by 4                                                   |
| 35  | VSENSE11DIV4LP |       |        | Low-power VSENSE1 divided by 4                                         |
| 48  | CAPSENSE       |       |        | Deprecated capacitive sensing feature, not recommended for new designs |
| 64  | VDAC0OUT0      |       |        | VDAC0 channel 0 output                                                 |
| 66  | VDAC1OUT0      |       |        | VDAC1 channel 0 output                                                 |
| 128 | PA0            |       |        | Port A, Pin0                                                           |
| 129 | PA1            |       |        | Port A, Pin1                                                           |
| 130 | PA2            |       |        | Port A, Pin2                                                           |
| 131 | PA3            |       |        | Port A, Pin3                                                           |
| 132 | PA4            |       |        | Port A, Pin4                                                           |
| 133 | PA5            |       |        | Port A, Pin5                                                           |
| 134 | PA6            |       |        | Port A, Pin6                                                           |
| 135 | PA7            |       |        | Port A, Pin7                                                           |
| 136 | PA8            |       |        | Port A, Pin8                                                           |
| 137 | PA9            |       |        | Port A, Pin9                                                           |
| 138 | PA10           |       |        | Port A, Pin10                                                          |
| 139 | PA11           |       |        | Port A, Pin11                                                          |
| 140 | PA12           |       |        | Port A, Pin12                                                          |
| 141 | PA13           |       |        | Port A, Pin13                                                          |
| 142 | PA14           |       |        | Port A, Pin14                                                          |
| 143 | PA15           |       |        | Port A, Pin15                                                          |
| 144 | PB0            |       |        | Port B, Pin0                                                           |
| 145 | PB1            |       |        | Port B, Pin1                                                           |
| 146 | PB2            |       |        | Port B, Pin2                                                           |
| 147 | PB3            |       |        | Port B, Pin3                                                           |
| 148 | PB4            |       |        | Port B, Pin4                                                           |
| 149 | PB5            |       |        | Port B, Pin5                                                           |
| 150 | PB6            |       |        | Port B, Pin6                                                           |
| 151 | PB7            |       |        | Port B, Pin7                                                           |
| 152 | PB8            |       |        | Port B, Pin8                                                           |
| 153 | PB9            |       |        | Port B, Pin9                                                           |
| 154 | PB10           |       |        | Port B, Pin10                                                          |
| 155 | PB11           |       |        | Port B, Pin11                                                          |
| 156 | PB12           |       |        | Port B, Pin12                                                          |
| 157 | PB13           |       |        | Port B, Pin13                                                          |
| 158 | PB14           |       |        | Port B, Pin14                                                          |

| Bit | Name                   | Reset | Access      | Description                  |
|-----|------------------------|-------|-------------|------------------------------|
| 159 | PB15                   |       |             | Port B, Pin15                |
| 160 | PC0                    |       |             | Port C, Pin0                 |
| 161 | PC1                    |       |             | Port C, Pin1                 |
| 162 | PC2                    |       |             | Port C, Pin2                 |
| 163 | PC3                    |       |             | Port C, Pin3                 |
| 164 | PC4                    |       |             | Port C, Pin4                 |
| 165 | PC5                    |       |             | Port C, Pin5                 |
| 166 | PC6                    |       |             | Port C, Pin6                 |
| 167 | PC7                    |       |             | Port C, Pin7                 |
| 168 | PC8                    |       |             | Port C, Pin8                 |
| 169 | PC9                    |       |             | Port C, Pin9                 |
| 170 | PC10                   |       |             | Port C, Pin10                |
| 171 | PC11                   |       |             | Port C, Pin11                |
| 172 | PC12                   |       |             | Port C, Pin12                |
| 173 | PC13                   |       |             | Port C, Pin13                |
| 174 | PC14                   |       |             | Port C, Pin14                |
| 175 | PC15                   |       |             | Port C, Pin15                |
| 176 | PD0                    |       |             | Port D, Pin0                 |
| 177 | PD1                    |       |             | Port D, Pin1                 |
| 178 | PD2                    |       |             | Port D, Pin2                 |
| 179 | PD3                    |       |             | Port D, Pin3                 |
| 180 | PD4                    |       |             | Port D, Pin4                 |
| 181 | PD5                    |       |             | Port D, Pin5                 |
| 182 | PD6                    |       |             | Port D, Pin6                 |
| 183 | PD7                    |       |             | Port D, Pin7                 |
| 184 | PD8                    |       |             | Port D, Pin8                 |
| 185 | PD9                    |       |             | Port D, Pin9                 |
| 186 | PD10                   |       |             | Port D, Pin10                |
| 187 | PD11                   |       |             | Port D, Pin11                |
| 188 | PD12                   |       |             | Port D, Pin12                |
| 189 | PD13                   |       |             | Port D, Pin13                |
| 190 | PD14                   |       |             | Port D, Pin14                |
| 191 | PD15                   |       |             | Port D, Pin15                |
| 7:0 | POSSEL                 | 0x0   | RW          | <b>Positive Input Select</b> |
|     | Select positive input. |       |             |                              |
|     | Value                  | Mode  | Description |                              |

| Bit | Name           | Reset | Access | Description                      |
|-----|----------------|-------|--------|----------------------------------|
| 0   | VSS            |       |        | VSS                              |
| 16  | VREFDIVAVDD    |       |        | Divided AVDD                     |
| 17  | VREFDIVAVDDL   |       |        | Low-Power Divided AVDD           |
| 18  | VREFDIV1V25    |       |        | Divided 1V25 reference           |
| 19  | VREFDIV1V25LP  |       |        | Low-power Divided 1V25 reference |
| 20  | VREFDIV2V5     |       |        | Divided 2V5 reference            |
| 21  | VREFDIV2V5LP   |       |        | Low-power Divided 2V5 reference  |
| 32  | VSENSE01DIV4   |       |        | VSENSE0 divided by 4             |
| 33  | VSENSE01DIV4LP |       |        | Low-power VSENSE0 divided by 4   |
| 34  | VSENSE11DIV4   |       |        | VSENSE1 divided by 4             |
| 35  | VSENSE11DIV4LP |       |        | Low-power VSENSE1 divided by 4   |
| 65  | VDAC0OUT1      |       |        | VDAC0 channel 1 output           |
| 67  | VDAC1OUT1      |       |        | VDAC1 channel 1 output           |
| 80  | EXTPA          |       |        | External interface, base is PA0. |
| 81  | EXTPB          |       |        | External interface, base is PB0. |
| 82  | EXTPC          |       |        | External interface, base is PC0. |
| 83  | EXTPD          |       |        | External interface, base is PD0. |
| 128 | PA0            |       |        | Port A, Pin0                     |
| 129 | PA1            |       |        | Port A, Pin1                     |
| 130 | PA2            |       |        | Port A, Pin2                     |
| 131 | PA3            |       |        | Port A, Pin3                     |
| 132 | PA4            |       |        | Port A, Pin4                     |
| 133 | PA5            |       |        | Port A, Pin5                     |
| 134 | PA6            |       |        | Port A, Pin6                     |
| 135 | PA7            |       |        | Port A, Pin7                     |
| 136 | PA8            |       |        | Port A, Pin8                     |
| 137 | PA9            |       |        | Port A, Pin9                     |
| 138 | PA10           |       |        | Port A, Pin10                    |
| 139 | PA11           |       |        | Port A, Pin11                    |
| 140 | PA12           |       |        | Port A, Pin12                    |
| 141 | PA13           |       |        | Port A, Pin13                    |
| 142 | PA14           |       |        | Port A, Pin14                    |
| 143 | PA15           |       |        | Port A, Pin15                    |
| 144 | PB0            |       |        | Port B, Pin0                     |
| 145 | PB1            |       |        | Port B, Pin1                     |
| 146 | PB2            |       |        | Port B, Pin2                     |
| 147 | PB3            |       |        | Port B, Pin3                     |

| Bit | Name | Reset | Access | Description   |
|-----|------|-------|--------|---------------|
| 148 | PB4  |       |        | Port B, Pin4  |
| 149 | PB5  |       |        | Port B, Pin5  |
| 150 | PB6  |       |        | Port B, Pin6  |
| 151 | PB7  |       |        | Port B, Pin7  |
| 152 | PB8  |       |        | Port B, Pin8  |
| 153 | PB9  |       |        | Port B, Pin9  |
| 154 | PB10 |       |        | Port B, Pin10 |
| 155 | PB11 |       |        | Port B, Pin11 |
| 156 | PB12 |       |        | Port B, Pin12 |
| 157 | PB13 |       |        | Port B, Pin13 |
| 158 | PB14 |       |        | Port B, Pin14 |
| 159 | PB15 |       |        | Port B, Pin15 |
| 160 | PC0  |       |        | Port C, Pin0  |
| 161 | PC1  |       |        | Port C, Pin1  |
| 162 | PC2  |       |        | Port C, Pin2  |
| 163 | PC3  |       |        | Port C, Pin3  |
| 164 | PC4  |       |        | Port C, Pin4  |
| 165 | PC5  |       |        | Port C, Pin5  |
| 166 | PC6  |       |        | Port C, Pin6  |
| 167 | PC7  |       |        | Port C, Pin7  |
| 168 | PC8  |       |        | Port C, Pin8  |
| 169 | PC9  |       |        | Port C, Pin9  |
| 170 | PC10 |       |        | Port C, Pin10 |
| 171 | PC11 |       |        | Port C, Pin11 |
| 172 | PC12 |       |        | Port C, Pin12 |
| 173 | PC13 |       |        | Port C, Pin13 |
| 174 | PC14 |       |        | Port C, Pin14 |
| 175 | PC15 |       |        | Port C, Pin15 |
| 176 | PD0  |       |        | Port D, Pin0  |
| 177 | PD1  |       |        | Port D, Pin1  |
| 178 | PD2  |       |        | Port D, Pin2  |
| 179 | PD3  |       |        | Port D, Pin3  |
| 180 | PD4  |       |        | Port D, Pin4  |
| 181 | PD5  |       |        | Port D, Pin5  |
| 182 | PD6  |       |        | Port D, Pin6  |
| 183 | PD7  |       |        | Port D, Pin7  |
| 184 | PD8  |       |        | Port D, Pin8  |

| Bit | Name | Reset | Access | Description   |
|-----|------|-------|--------|---------------|
| 185 |      | PD9   |        | Port D, Pin9  |
| 186 |      | PD10  |        | Port D, Pin10 |
| 187 |      | PD11  |        | Port D, Pin11 |
| 188 |      | PD12  |        | Port D, Pin12 |
| 189 |      | PD13  |        | Port D, Pin13 |
| 190 |      | PD14  |        | Port D, Pin14 |
| 191 |      | PD15  |        | Port D, Pin15 |

### 29.5.7 ACMP\_STATUS - Status Register

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|---|
| 0x018         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R | 0x0 | 4 |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R | 0x0 | 3 |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R | 0x0 | 2 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R | 0x0 | 1 |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | R | 0x0 | 0 |

| Bit  | Name          | Reset | Access | Description                                                                                                                                                                             |
|------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>       |
| 4    | PORTALLOCERR  | 0x0   | R      | <b>Port allocation error</b><br><br>The port selected by INPUTCTRL_POSSEL or INPUTCTRL_NEGSEL is not allocated to this ACMP. Port allocation needs to be configured in the GPIO module. |
| 3    | INPUTCONFLICT | 0x0   | R      | <b>INPUT conflict</b><br><br>INPUTCTRL_POSSEL and INPUTCTRL_NEGSEL is configured illegally.                                                                                             |
| 2    | ACMPRDY       | 0x0   | R      | <b>Analog Comparator Ready</b><br><br>Analog comparator ready status.                                                                                                                   |
| 1    | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>       |
| 0    | ACMPOUT       | 0x0   | R      | <b>Analog Comparator Output</b><br><br>Analog comparator output value.                                                                                                                  |

## 29.5.8 ACMP\_IF - Interrupt Flag Register

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              |               |    |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------|---------------|----|
| 0x01C  | 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  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0          | 4             |    |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | RW           | 0x0           |    |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | PORTALLOCERR | RW            |    |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              | INPUTCONFLICT | RW |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              | ACMPRDY       | RW |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              | FALL          | RW |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |              | RISE          | RW |

| Bit  | Name          | Reset | Access | Description                                                                                                                                                                                                                                                                                            |
|------|---------------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                                                                                                      |
| 4    | PORTALLOCERR  | 0x0   | RW     | <b>Port allocation error</b><br><br>The port selected by INPUTCTRL_POSSEL or INPUTCTRL_NEGSEL is not allocated to this ACMP. Port allocation needs to be configured in the GPIO module.                                                                                                                |
| 3    | INPUTCONFLICT | 0x0   | RW     | <b>Input conflict</b><br><br>INPUTCTRL_POSSEL and INPUTCTRL_NEGSEL is configured illegally.                                                                                                                                                                                                            |
| 2    | ACMPRDY       | 0x0   | RW     | <b>ACMP ready Interrupt flag</b><br><br>Indicates that the analog comparator is ready and references have settled. Note at lower bias settings (BIAS<=3), the ACMPRDY bit may not be reliable and additional software wait may be required. Refer to "Warmup Time" section for additional information. |
| 1    | FALL          | 0x0   | RW     | <b>Falling Edge Triggered Interrupt Flag</b><br><br>Indicates that there has been a falling edge on the analog comparator output.                                                                                                                                                                      |
| 0    | RISE          | 0x0   | RW     | <b>Rising Edge Triggered Interrupt Flag</b><br><br>Indicates that there has been a rising edge on the analog comparator output.                                                                                                                                                                        |

**29.5.9 ACMP\_IEN - Interrupt Enable Register**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|
| 0x020         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 4 |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 3 |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 2 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 1 |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 4    | PORTALLOCERR    | 0x0   | RW     | <b>Port allocation error interrupt enable</b>                                                                                                                                     |
| 3    | INPUTCONFLICT   | 0x0   | RW     | <b>Input conflict interrupt enable</b>                                                                                                                                            |
| 2    | ACMPRDY         | 0x0   | RW     | <b>ACMP ready interrupt enable</b>                                                                                                                                                |
| 1    | FALL            | 0x0   | RW     | <b>Falling edge interrupt enable</b>                                                                                                                                              |
| 0    | RISE            | 0x0   | RW     | <b>Rising edge interrupt enable</b>                                                                                                                                               |

**29.5.10 ACMP\_SYNCBUSY - Syncbusy**

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|
| 0x024         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 4   |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 3   |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 2   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1   |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0 | 0 |   |

| Bit  | Name            | Reset | Access | Description                                                                                                                                                                       |
|------|-----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | <i>Reserved</i> |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 0    | INPUTCTRL       | 0x0   | R      | <b>Syncbusy for INPUTCTRL</b><br><br>Synchronization of INPUTCTRL ongoing                                                                                                         |

## 30. KEYS defence - Keyboard Scan



| Quick Facts                                                                                                                                                                                                                       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>What?</b>                                                                                                                                                                                                                      |
| The keypad scanner autonomously scans through a matrix of keypad switches to detect key presses.                                                                                                                                  |
| <b>Why?</b>                                                                                                                                                                                                                       |
| Operating independently from the main processor, the keypad scanner can save energy by interrupting the system only as needed. The KEYS defence peripheral also saves energy by operating in a wake-on-press mode in EM2 and EM3. |
| <b>How?</b>                                                                                                                                                                                                                       |
| A traditional row/column matrix of switches is scanned using a finite state machine capable of de-bouncing and settling any key press prior to processor intervention.                                                            |

### 30.1 Introduction

The KEYS defence module connects through row and column GPIOs to an external mechanical keypad. The KEYS defence supports up to 6 rows and up to 8 columns.

### 30.2 Features

- Performs scans in EM0 / EM1 to detect the row and column address of any key
- Wake up from sleep on key press in EM2 / EM3
- Supports up to a 6 x 8 matrix of keys in one or more keypads
- Interrupt sources for detected key press and non-press
- Multi-touch mode available for detecting multiple simultaneous keys

### 30.3 Functional Description

An overview of the KEYSCAN module is shown in [Figure 30.1 KEYSCAN Overview on page 1128](#). The KEYSCAN consists of rows and columns GPIOs connected to the KEYSCAN hardware. In EM0 and EM1, KEYSCAN can actively scan all switches in the matrix for active key presses. Any closed switches between rows and columns are detected, debounced, settled, and reported to the processor via the register interface. In EM2 and EM3, KEYSCAN simultaneously checks for any key press across the entire switch matrix. Any press will wake to an active state, allowing KEYSCAN to perform a scan and determine specific key location(s).



**Figure 30.1. KEYSCAN Overview**

#### 30.3.1 Row and Column Configuration

Row and column signals are routed to physical pins using DBUS and set up in the GPIO configuration registers.

Columns are the output drivers and can be routed to any available port pin using the `GPIO_KEYSCAN_COLOUTxROUTE` register, where 'x' is the column number. Column outputs must also be individually enabled using the bits in `GPIO_KEYSCAN_ROUTEN`.

Rows are the input sense circuitry. They are routed via the `GPIO_KEYSCAN_ROWSENSExROUTE` registers, where 'x' is the row number. Row signals are only available on ports A and B.

Rows and columns should be routed starting at the lowest number. For example, a keypad requiring 3 rows and 2 columns should route ROW0, ROW1, ROW2, COL0, and COL1.

When the GPIO registers have been configured, the `KEYSCAN_CFG.NUMROWS` and `KEYSCAN_CFG.NUMCOLS` can then be configured to indicate the number of rows and columns to include in each scan.

#### 30.3.2 Clocking and Timing

The timebase for the KEYSCAN peripheral is derived from `EM01GRPACLK`. The `CFG.CLKDIV` field should be used to divide `EM01GRPACLK` to produce a 500 Hz clock (2 ms ticks), which drives the timing of delays in the KEYSCAN state machine.

There are three timed delays used in the state machine, which are described in more detail in the following sections. Timing for these delays is configured by the `SCANDLY`, `DEBDLY`, and `STABDLY` fields in the `DELAY` register. Each of these fields specifies the number of 2 ms clock ticks for a different delay, with a range from 2 ms to 32 ms.

### 30.3.3 Scanning

Figure 30.2 KEYSCAN State Machine on page 1129 shows the state machine sequence for key press scanning. When a scanning sequence begins, the scan logic grounds one column at a time, starting with column 0. The column pin is grounded for up to DELAY.SCANDLY clocks. If no rows are detected as low (indicating a key press) the scan logic will proceed to ground the next column in sequence.

If a row is read as logic low while a column is grounded, the scan logic will implement a debounce delay of DELAY.DEBDLY clocks. If any rows are still grounded at the end of the debounce delay, a stabilization delay of DELAY.STABDLY clocks will then be implemented.

If the row readings between the start and end of the stabilization delay match, the scan logic determines that a key has been pressed, the scanner halts, and the IF.KEY interrupt flag is set. The details of which column is tested are reported in STATUS.COL, and the reading from all rows is stored in STATUS.ROW. The state machine will continue once IF.KEY is cleared.

For single-press scanning (CFG.SINGLEPRESS set to SINGLEPRESS), the next step in the scan sequence is to wait until all keys are unpressed. The state machine grounds all columns and waits until all rows read back '1'. When all keys are detected as unpressed, the scan logic will then continue scanning with the next column in sequence.

For multi-press scanning (CFG.SINGLEPRESS set to MULTIPRESS), scanning will proceed with the next column immediately when the IF.KEY interrupt is cleared. In multi-press mode, the IF.NOKEY interrupt flag will set once after a full scan cycle is completed without detecting a new key press, to indicate that all keys have been released and allow for subsequent press detections. Scans without a key press will not set this flag again until one or more new key presses have been detected.

Finally, the IF.SCANNED interrupt flag is set every time the scan logic completes an entire column-by-column scan without detecting any key presses.



Figure 30.2. KEYSCAN State Machine

Figure 30.3 Single Press Mode on page 1130 shows how the scanner operates in single-press mode. One interrupt is generated upon key press. The usage model is for a single key press at a time. If multiple keys are pressed at the same time, it stops scanning at the first column that has a key press and shows all the pressed rows for that column. Scanning does not resume until all pressed keys are released.



Figure 30.3. Single Press Mode

Figure 30.4 Multi-touch Mode with Multiple Key Presses on page 1130 shows two key presses that occur on the same column (R2C2 and R0C2). The first key press R2C2 was detected first and set the IF.KEY interrupt flag. The interrupt service routine read the status, updated an array in memory, and cleared the IF.KEY. Then the scanning continued until the IF.KEY was set again. Since both pressed keys are active on the same column, STATUS.ROW shows 010 for the low true key presses on R2C2 and R0C2. When both keys have been released and the scan cycles through without detecting any key presses, the IF.NOKEY flag is set.



Figure 30.4. Multi-touch Mode with Multiple Key Presses

### 30.3.4 Wake on Key

The KEYSAN module does not actively scan channels during EM2 or EM3, but it will operate in a wake-on-key mode when the IEN.WAKEUP interrupt is enabled. In this mode, all columns are driven low, and the logic waits for any of the row inputs to be pulled low. This event can wake the device from EM2 or EM3.

After waking up, the IF.WAKEUP flag will be set. Software may service this wakeup interrupt and start a new scan using the CMD.START command. Alternatively, if CMD.AUTOSTART has been used prior to sleeping, the keysan will automatically be started each time the chip wakes up to EM0. Before going to sleep, software may use CMD.KEYSCANSTOP to turn off scanning if desired. If KEYSCANSTOP is not used, the keysan module will still power down and stop scanning once the chip enters sleep. While most of the keysan is powered down during EM2 and EM3, there is a small piece of logic that remains powered during EM2 and EM3 to allow a key press to wake the device.

A key press during sleep is unqualified, because no debouncing and settling are performed before waking the device. It is possible that noise in the mechanical keypad caused the wakeup without a real key press. In this case, after wakeup and scanning all columns, the IF.SCANNED interrupt comes in handy. IF.SCANNED would be set without IF.KEY or IF.NOKEY interrupts ever having been set. The IF.WAKEUP can be used to record to memory that the keypad has not yet completed any scans. Once IF.SCANNED fires without having seen any IF.KEY interrupts, this may indicate that the wakeup was due to noise instead of a key press, and the system can return to sleep.

### 30.4 KEYSCAN Register Map

The offset register address is relative to the registers base address.

| Offset | Name                  | Type        | Description       |
|--------|-----------------------|-------------|-------------------|
| 0x000  | KEYSCAN_IPVERSION     | R           | IPVERSION         |
| 0x004  | KEYSCAN_EN            | RW ENABLE   | Enable            |
| 0x008  | KEYSCAN_SWRST         | RW SWRST    | Software Reset    |
| 0x00C  | KEYSCAN_CFG           | RW CONFIG   | Config            |
| 0x010  | KEYSCAN_CMD           | W SYNC      | Command           |
| 0x014  | KEYSCAN_DELAY         | RW CONFIG   | Delay             |
| 0x018  | KEYSCAN_STATUS        | RH          | Status            |
| 0x01C  | KEYSCAN_IF            | RWH INTFLAG | Interrupt Flags   |
| 0x020  | KEYSCAN_IEN           | RW          | Interrupt Enables |
| 0x1000 | KEYSCAN_IPVERSION_SET | R           | IPVERSION         |
| 0x1004 | KEYSCAN_EN_SET        | RW ENABLE   | Enable            |
| 0x1008 | KEYSCAN_SWRST_SET     | RW SWRST    | Software Reset    |
| 0x100C | KEYSCAN_CFG_SET       | RW CONFIG   | Config            |
| 0x1010 | KEYSCAN_CMD_SET       | W SYNC      | Command           |
| 0x1014 | KEYSCAN_DELAY_SET     | RW CONFIG   | Delay             |
| 0x1018 | KEYSCAN_STATUS_SET    | RH          | Status            |
| 0x101C | KEYSCAN_IF_SET        | RWH INTFLAG | Interrupt Flags   |
| 0x1020 | KEYSCAN_IEN_SET       | RW          | Interrupt Enables |
| 0x2000 | KEYSCAN_IPVERSION_CLR | R           | IPVERSION         |
| 0x2004 | KEYSCAN_EN_CLR        | RW ENABLE   | Enable            |
| 0x2008 | KEYSCAN_SWRST_CLR     | RW SWRST    | Software Reset    |
| 0x200C | KEYSCAN_CFG_CLR       | RW CONFIG   | Config            |
| 0x2010 | KEYSCAN_CMD_CLR       | W SYNC      | Command           |
| 0x2014 | KEYSCAN_DELAY_CLR     | RW CONFIG   | Delay             |
| 0x2018 | KEYSCAN_STATUS_CLR    | RH          | Status            |
| 0x201C | KEYSCAN_IF_CLR        | RWH INTFLAG | Interrupt Flags   |
| 0x2020 | KEYSCAN_IEN_CLR       | RW          | Interrupt Enables |
| 0x3000 | KEYSCAN_IPVERSION_TGL | R           | IPVERSION         |
| 0x3004 | KEYSCAN_EN_TGL        | RW ENABLE   | Enable            |
| 0x3008 | KEYSCAN_SWRST_TGL     | RW SWRST    | Software Reset    |
| 0x300C | KEYSCAN_CFG_TGL       | RW CONFIG   | Config            |
| 0x3010 | KEYSCAN_CMD_TGL       | W SYNC      | Command           |
| 0x3014 | KEYSCAN_DELAY_TGL     | RW CONFIG   | Delay             |
| 0x3018 | KEYSCAN_STATUS_TGL    | RH          | Status            |
| 0x301C | KEYSCAN_IF_TGL        | RWH INTFLAG | Interrupt Flags   |

| Offset | Name            | Type | Description       |
|--------|-----------------|------|-------------------|
| 0x3020 | KEYSCAN_IEN_TGL | RW   | Interrupt Enables |

### 30.5 KEYS offense Description

#### 30.5.1 KEYS offense \_IPVERSION - IPVERSION

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x000  | 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 |
| Reset  | 0x1          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | IPVERSION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name      | Reset | Access | Description |
|------|-----------|-------|--------|-------------|
| 31:0 | IPVERSION | 0x1   | R      | IPVERSION   |

#### 30.5.2 KEYS offense \_EN - Enable

| Offset | Bit Position         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x004  | 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 |
| Reset  | 0x0                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Access | R                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name   | DISABLING R<br>EN RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit  | Name                                                                                                                                                                                                                     | Reset                                                                                                                                                             | Access                                                         | Description                    |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--------------------------------|
| 31:2 | Reserved                                                                                                                                                                                                                 | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |                                                                |                                |
| 1    | DISABLING                                                                                                                                                                                                                | 0x0                                                                                                                                                               | R                                                              | <b>Disablement busy status</b> |
|      | When EN is cleared, DISABLING status is set immediately, and cleared when disablement finishes. Disablement resets peripheral cores and bit fields or registers dependent on hardware state, such as INTFLAGS and FIFOs. |                                                                                                                                                                   |                                                                |                                |
| 0    | EN                                                                                                                                                                                                                       | 0x0                                                                                                                                                               | RW                                                             | <b>Enable</b>                  |
|      | Enable                                                                                                                                                                                                                   |                                                                                                                                                                   |                                                                |                                |
|      | Value                                                                                                                                                                                                                    | Mode                                                                                                                                                              | Description                                                    |                                |
|      | 0                                                                                                                                                                                                                        | DISABLE                                                                                                                                                           | Stops clocking and resets peripheral core logic.               |                                |
|      | 1                                                                                                                                                                                                                        | ENABLE                                                                                                                                                            | Enables clocking, and begins scanning if CFG.AUTOSTART is 0x1. |                                |

## 30.5.3 KEYS defense \_SWRST - Software Reset

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 0x008  | 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 |  |  |  |
| Reset  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Access |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|        |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

## 30.5.4 KEYS offense \_CFG - Config

| Offset | Bit Position |    |     |         |    |           |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |        |  |  |
|--------|--------------|----|-----|---------|----|-----------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--------|--|--|
| 0x00C  | 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 |        |  |  |
| Reset  |              |    | 0x2 |         |    |           | 0x5         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |        |  |  |
| Access |              | RW |     |         | RW |           | RW          | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |        |  |  |
| Name   | NUMCOLS      |    |     | NUMROWS |    | AUTOSTART | SINGLEPRESS | RW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | CLKDIV |  |  |

| Bit   | Name        | Reset        | Access | Description                                                                                                                                                                                                                                                        |
|-------|-------------|--------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved    |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                  |
| 30:28 | NUMCOLS     | 0x2          | RW     | <b>Number of Columns</b><br><br>Number of Columns minus one (0x2 indicates 3 columns)                                                                                                                                                                              |
| 27    | Reserved    |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                  |
| 26:24 | NUMROWS     | 0x5          | RW     | <b>Number of Rows</b><br><br>Number of Rows minus 1(5: represents 6 rows)                                                                                                                                                                                          |
|       | Value       | Mode         |        | Description                                                                                                                                                                                                                                                        |
|       | 0           | RSV1         |        | 1 Row is not supported; defaults to 3 instead                                                                                                                                                                                                                      |
|       | 1           | RSV2         |        | 2 Rows are not supported; defaults to 3 instead                                                                                                                                                                                                                    |
|       | 2           | ROW3         |        | 3 Rows                                                                                                                                                                                                                                                             |
|       | 3           | ROW4         |        | 4 Rows                                                                                                                                                                                                                                                             |
|       | 4           | ROW5         |        | 5 Rows                                                                                                                                                                                                                                                             |
|       | 5           | ROW6         |        | 6 Rows                                                                                                                                                                                                                                                             |
| 23    | Reserved    |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                  |
| 22    | AUTOSTART   | 0x0          | RW     | <b>Automatically Start</b><br><br>Automatically start when EN is set to 0x1.                                                                                                                                                                                       |
|       | Value       | Mode         |        | Description                                                                                                                                                                                                                                                        |
|       | 0           | AUTOSTARTDIS |        | Auto start is disabled                                                                                                                                                                                                                                             |
|       | 1           | AUTOSTARTEN  |        | Auto start is enabled                                                                                                                                                                                                                                              |
| 21    | Reserved    |              |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                  |
| 20    | SINGLEPRESS | 0x0          | RW     | <b>Single Press</b><br><br>Generates one interrupt per keypress. Then waits for all keys to be released and IF.KEYIF=0x0 before it starts scanning again. When singlepress is not set, scanning continues once IF.KEYIF=0x0 which allows for muti-touch detection. |

| Bit   | Name        | Reset   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-------------|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Value       | Mode    |        | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0     | MULTIPRESS  |         |        | After KEYIF is set and then cleared, scanning will continue. This can give multiple interrupts for the same key press, but allow multiple key presses to be detected. To use this mode for multi-key detection, the ISR should update a section of memory of COLNUM bytes on each interrupt, until key release is detected. After key release, the section of memory where key presses are recorded can be processed. |
| 1     | SINGLEPRESS |         |        | After KEYIF has been set and cleared, it will not set again until no key press is detected. This allows faster response since the ISR can start processing data as soon as the KEYIF is set.                                                                                                                                                                                                                          |
| 19:18 | Reserved    |         |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i>                                                                                                                                                                                                                                     |
| 17:0  | CLKDIV      | 0x1387F | RW     | <b>Clock Divider</b><br><br>Divides the peripheral clock by (CLKDIV+1) to produce a timebase for the keyscan timers. The nominal target timebase is 2 ms.                                                                                                                                                                                                                                                             |

### **30.5.5 KEYSPEC\_CMD - Command**

| Bit  | Name          | Reset | Access | Description                                                                                                                                                                       |
|------|---------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | Reserved      |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |
| 1    | KEYSCANSTOP   | 0x0   | W(nB)  | <b>Keyscan Stop</b>                                                                                                                                                               |
|      | Stop Keyscan  |       |        |                                                                                                                                                                                   |
| 0    | KEYSCANSTART  | 0x0   | W(nB)  | <b>Keyscan Start</b>                                                                                                                                                              |
|      | Start Keyscan |       |        |                                                                                                                                                                                   |

## 30.5.6 KEYS defense - Delay

| Offset | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |   |   |   |   |   |   |         |   |   |   |  |  |  |  |  |  |  |  |  |  |
|--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|---|---|---|---|---|---|---------|---|---|---|--|--|--|--|--|--|--|--|--|--|
| 0x014  | 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 |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0x0          |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0    |    |    |    |    |    |    |    |   |   |   |   |   |   |         |   |   |   |  |  |  |  |  |  |  |  |  |  |
| Access | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    | RW     |    |    |    |    |    |    |    |   |   |   |   |   |   |         |   |   |   |  |  |  |  |  |  |  |  |  |  |
| Name   | STABDLY      |    |    |    |    |    |    |    |    |    |    |    |    |    | DEBDLY |    |    |    |    |    |    |    |   |   |   |   |   |   | SCANDLY |   |   |   |  |  |  |  |  |  |  |  |  |  |

| Bit   | Name             | Reset     | Access | Description                                                                                                                                                       |
|-------|------------------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved         |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 27:24 | STABDLY          | 0x0       | RW     | <b>Row stable Delay</b>                                                                                                                                           |
|       | Row stable delay |           |        |                                                                                                                                                                   |
|       | Value            | Mode      |        | Description                                                                                                                                                       |
|       | 0                | STABDLY2  |        | 2ms Row Stable Delay                                                                                                                                              |
|       | 1                | STABDLY4  |        | 4ms Row Stable Delay                                                                                                                                              |
|       | 2                | STABDLY6  |        | 6ms Row Stable Delay                                                                                                                                              |
|       | 3                | STABDLY8  |        | 8ms Row Stable Delay                                                                                                                                              |
|       | 4                | STABDLY10 |        | 10ms Row Stable Delay                                                                                                                                             |
|       | 5                | STABDLY12 |        | 12ms Row Stable Delay                                                                                                                                             |
|       | 6                | STABDLY14 |        | 14ms Row Stable Delay                                                                                                                                             |
|       | 7                | STABDLY16 |        | 16ms Row Stable Delay                                                                                                                                             |
|       | 8                | STABDLY18 |        | 18ms Row Stable Delay                                                                                                                                             |
|       | 9                | STABDLY20 |        | 20ms Row Stable Delay                                                                                                                                             |
|       | 10               | STABDLY22 |        | 22ms Row Stable Delay                                                                                                                                             |
|       | 11               | STABDLY24 |        | 24ms Row Stable Delay                                                                                                                                             |
|       | 12               | STABDLY26 |        | 26ms Row Stable Delay                                                                                                                                             |
|       | 13               | STABDLY28 |        | 28ms Row Stable Delay                                                                                                                                             |
|       | 14               | STABDLY30 |        | 30ms Row Stable Delay                                                                                                                                             |
|       | 15               | STABDLY32 |        | 32ms Row Stable Delay                                                                                                                                             |
| 23:20 | Reserved         |           |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i> |
| 19:16 | DEBDLY           | 0x0       | RW     | <b>Debounce Delay</b>                                                                                                                                             |
|       | Debounce Delay   |           |        |                                                                                                                                                                   |
|       | Value            | Mode      |        | Description                                                                                                                                                       |
|       | 0                | DEBDLY2   |        | 2ms Debounce Delay                                                                                                                                                |
|       | 1                | DEBDLY4   |        | 4ms Debounce Delay                                                                                                                                                |

| Bit   | Name       | Reset                                                                                                                                                                             | Access | Description         |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------|
| 2     | DEBDLY6    |                                                                                                                                                                                   |        | 6ms Debounce Delay  |
| 3     | DEBDLY8    |                                                                                                                                                                                   |        | 8ms Debounce Delay  |
| 4     | DEBDLY10   |                                                                                                                                                                                   |        | 10ms Debounce Delay |
| 5     | DEBDLY12   |                                                                                                                                                                                   |        | 12ms Debounce Delay |
| 6     | DEBDLY14   |                                                                                                                                                                                   |        | 14ms Debounce Delay |
| 7     | DEBDLY16   |                                                                                                                                                                                   |        | 16ms Debounce Delay |
| 8     | DEBDLY18   |                                                                                                                                                                                   |        | 18ms Debounce Delay |
| 9     | DEBDLY20   |                                                                                                                                                                                   |        | 20ms Debounce Delay |
| 10    | DEBDLY22   |                                                                                                                                                                                   |        | 22ms Debounce Delay |
| 11    | DEBDLY24   |                                                                                                                                                                                   |        | 24ms Debounce Delay |
| 12    | DEBDLY26   |                                                                                                                                                                                   |        | 26ms Debounce Delay |
| 13    | DEBDLY28   |                                                                                                                                                                                   |        | 28ms Debounce Delay |
| 14    | DEBDLY30   |                                                                                                                                                                                   |        | 30ms Debounce Delay |
| 15    | DEBDLY32   |                                                                                                                                                                                   |        | 32ms Debounce Delay |
| 15:12 | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                     |
| 11:8  | SCANDLY    | 0x0                                                                                                                                                                               | RW     | <b>Scan Delay</b>   |
|       | Scan Delay |                                                                                                                                                                                   |        |                     |
|       | Value      | Mode                                                                                                                                                                              |        | Description         |
|       | 0          | SCANDLY2                                                                                                                                                                          |        | 2ms Scan Delay      |
|       | 1          | SCANDLY4                                                                                                                                                                          |        | 4ms Scan Delay      |
|       | 2          | SCANDLY6                                                                                                                                                                          |        | 6ms Scan Delay      |
|       | 3          | SCANDLY8                                                                                                                                                                          |        | 8ms Scan Delay      |
|       | 4          | SCANDLY10                                                                                                                                                                         |        | 10ms Scan Delay     |
|       | 5          | SCANDLY12                                                                                                                                                                         |        | 12ms Scan Delay     |
|       | 6          | SCANDLY14                                                                                                                                                                         |        | 14ms Scan Delay     |
|       | 7          | SCANDLY16                                                                                                                                                                         |        | 16ms Scan Delay     |
|       | 8          | SCANDLY18                                                                                                                                                                         |        | 18ms Scan Delay     |
|       | 9          | SCANDLY20                                                                                                                                                                         |        | 20ms Scan Delay     |
|       | 10         | SCANDLY22                                                                                                                                                                         |        | 22ms Scan Delay     |
|       | 11         | SCANDLY24                                                                                                                                                                         |        | 24ms Scan Delay     |
|       | 12         | SCANDLY26                                                                                                                                                                         |        | 26ms Scan Delay     |
|       | 13         | SCANDLY28                                                                                                                                                                         |        | 28ms Scan Delay     |
|       | 14         | SCANDLY30                                                                                                                                                                         |        | 30ms Scan Delay     |
|       | 15         | SCANDLY32                                                                                                                                                                         |        | 32ms Scan Delay     |
| 7:0   | Reserved   | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                     |

## 30.5.7 KEYS defense - Status

| Offset | Bit Position |       |    |    |    |    |     |    |    |    |    |    |    |    |    |         |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |
|--------|--------------|-------|----|----|----|----|-----|----|----|----|----|----|----|----|----|---------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----|--|
|        | 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 |     |  |
| Reset  | 0x0          | 0x1   |    |    |    |    |     |    |    |    |    |    |    |    |    |         | 0x0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |
| Access | R            | R     |    |    |    |    | R   |    |    |    |    |    |    |    |    | R       |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |  |
| Name   | SYNCBUSY     | NOKEY |    |    |    |    | COL |    |    |    |    |    |    |    |    | RUNNING |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | ROW |  |

| Bit   | Name     | Reset                                                                                                                                                                             | Access | Description                                                              |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------|
| 31    | SYNCBUSY | 0x0                                                                                                                                                                               | R      | <b>Sync Busy</b><br>Sync Busy                                            |
| 30    | NOKEY    | 0x1                                                                                                                                                                               | R      | <b>No Key pressed status</b><br>No Key pressed status                    |
| 29:27 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                          |
| 26:24 | COL      | 0x0                                                                                                                                                                               | R      | <b>Column Latched</b><br>column that corresponds to key press            |
| 23:17 | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                          |
| 16    | RUNNING  | 0x0                                                                                                                                                                               | R      | <b>Running</b><br>Running                                                |
| 15:6  | Reserved | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in <a href="#">1.2 Conventions</a></i> |        |                                                                          |
| 5:0   | ROW      | 0x0                                                                                                                                                                               | R      | <b>Row detection</b><br>Rows (1: pull up for no key press, 0: key press) |

## 30.5.8 KEYS defense - Interrupt Flags

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |         |    |   |   |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------|----|---|---|
| 0x01C         | 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 |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 3  |   |   |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0x0     | 2  |   |   |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | WAKEUP  | RW |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | SCANNED | RW |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | KEY     | RW |   |   |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | NOKEY   | RW |   |   |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                    |
|------|----------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                              |
| 3    | WAKEUP   | 0x0   | RW     | <b>Wake up</b><br><br>During sleep all columns are grounded and any keypress on any row will cause a wakeup and set WAKEUP. During EM01 WAKEUP will not get set.                                               |
| 2    | SCANNED  | 0x0   | RW     | <b>Completed scan</b><br><br>SCANNED sets each time all columns are scanned and no keypress is detected. The start of the scan is either from column 0 (after reset), or from the column of the last keypress. |
| 1    | KEY      | 0x0   | RW     | <b>A key was pressed</b><br><br>A key was pressed (This stops scan until the interrupt flag is cleared)                                                                                                        |
| 0    | NOKEY    | 0x0   | RW     | <b>No key was pressed</b><br><br>After a keypress is detected and IF.KEY interrupt cleared, NOKEY will set one time, after all the columns have been checked without detecting a keypress.                     |

## 30.5.9 KEYS defense - Interrupt Enables

| Offset        | Bit Position |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |         |    |
|---------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|----|
| 0x020         | 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       |    |
| <b>Reset</b>  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0     | 3  |
| <b>Access</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0x0     | 2  |
| <b>Name</b>   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | WAKEUP  | RW |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | SCANNED | RW |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | KEY     | RW |
|               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | NOKEY   | RW |

| Bit  | Name     | Reset | Access | Description                                                                                                                                                                                                              |
|------|----------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved |       |        | <i>To ensure compatibility with future devices, always write Reserved bits to their reset value, unless otherwise stated. More information in 1.2 Conventions</i>                                                        |
| 3    | WAKEUP   | 0x0   | RW     | <b>Wake up</b><br><br>A key press was detected during the first complete scan. This could be either after wake up from sleep or during the first complete scan after the first time the KEYS defense module was enabled. |
| 2    | SCANNED  | 0x0   | RW     | <b>Completed Scanning</b><br><br>SCANNEDIF sets each time all columns are scanned and no keypress is detected. The start of the scan is either from column 0 (after reset), or from the column of the last keypress.     |
| 1    | KEY      | 0x0   | RW     | <b>A Key was pressed</b><br><br>A Key was pressed (This stops scan until the interrupt flag is cleared)                                                                                                                  |
| 0    | NOKEY    | 0x0   | RW     | <b>No Key was pressed</b><br><br>After keypress is detected and keyif interrupt cleared, the NOKEYIF will set one time once all the columns are checked with no keypress.                                                |

## 31. MVP - Matrix Vector Processor



### Quick Facts

#### What?

The Matrix Vector Processor accelerates floating point operations, particularly matrixed complex floating point multiplications and additions

#### Why?

The Matrix Vector Processor hardware can save energy by offloading heavily floating-point computational intensive operations, including the Angle-of-Arrival (AoA) MUSIC algorithm, Machine Learning (ML) and linear algebra

#### How?

The Matrix Vector Processor includes a dedicated hardware arithmetic logic unit (ALU), load/store unit (LSU), and sequencer.

### 31.1 Introduction

The Matrix Vector Processor (MVP) is designed to offload the major computationally intensive floating point operations, particularly matrixed complex floating point multiplications and additions. The MVP hardware supports the acceleration of the key Angle-of-Arrival (AoA) MUSIC (MUltiple Signal Classification) algorithm computations, as well as other heavily floating-point computational problems such as Machine Learning (ML) or linear algebra.

### 31.2 Features

- Instruction Set Architecture (ISA)
  - General purpose instruction set tailored towards algorithms built out of ALU, loop, and load/store instructions
  - Enables many high-level array functions, e.g.:
    - Matrix multiplication
    - Element-wise matrix multiplication
    - Matrix addition
    - Power series generation
    - Convolution
  - Program flexibility allows efficient iteration over N-dimensional array elements, including in-place processing of special matrix views:
    - Element-wise negate / conjugate
    - Transpose / adjoint / reverse
    - Matrix blocks (i.e., rectangular parts of matrix)
    - Matrix slices (i.e., taking rows, columns, or elements uniformly spaced within a matrix)
    - Row-major or column-major ordering
- Arithmetic Logic Unit (ALU)
  - Three 32-bit floating-point input operands, interpreted as real or complex numbers
    - Partial integer input support
      - One 32-bit floating-point output operand, interpreted as real or complex numbers
      - Register bank to hold all input/output operands
    - Includes 8 registers for temporary storage and/or accumulation
  - Hardware to support 1 complex floating point multiply-accumulate (MAC) per cycle
    - Four single-precision floating-point multipliers
    - Four single-precision floating-point adders
    - 6x performance of Cortex M33 FMAC operations
  - Operations supported at a rate of one operation per cycle:
    - Complex addition, multiplication, and MAC operations
    - Parallel real multiplication and MAC
    - Parallel real addition
    - Sum of 4 reals
    - Squared-magnitude of complex/real
    - Integer-to-float conversion
    - Conditional computation
  - Input transformations (per real/complex part of each input)
    - Negation (complex conjugate)
    - Zero-masking (real/imaginary part decomposition)
- Load/Store Unit (LSU)
  - Controls data streaming from memory-to-ALU and vice versa
  - Pipelined architecture to support two simultaneous 32-bit memory reads and one 32-bit memory write per cycle
  - Supports signed / unsigned 8-bit integer conversion for both load and store operations
  - First-party DMA ports
    - Used by load / store unit for handling accesses to external (system) memory addresses
    - Three independent 32-bit AHB manager ports for supporting 2 read channels and 1 write channel simultaneously
- Sequencer
  - Coordinates all MVP blocks to execute a sequence of instructions provided via the programming interface
  - Handles array iteration according to instruction sequence and static array configuration
  - Handles loop iteration according to instruction sequence and static loop configuration

- Programming interface
  - Control registers for starting / stopping engine
  - Status registers about ongoing and finished instruction sequences
    - Fault status
    - Useful information for debug
  - Breakpoint and stepping controls for debug
  - Interrupts and faults
    - Instruction sequence completion
    - Bus faults
    - Loop faults
    - Array faults
  - Array configuration registers
  - Loop configuration registers
  - Instruction queue registers
    - Array iteration
    - ALU operations
    - Looping

### 31.3 Functional Description

The Matrix Vector Processor (MVP) is a peripheral processor that can be used to accelerate the processing of floating point operations while offloading the primary CPU. At a high level, it consists of:

- A register interface for programming and controlling operations
- A sequencer (which includes the loop controllers) that manages execution of the program
- Array and bus controllers that manage addressing, loading, and storing of data in arrays stored in system memory
- The pipeline controller, ALU, and ALU register bank for processing data



**Figure 31.1. MVP Block Diagram**

For most operations, software will program the MVP to address matrix (array) data in system memory and then process this data to perform a useful computation. The MVP provides three primary resources for controlling the operations that are fed through the ALU:

- Eight instructions, each of which encodes an ALU operation, load/store controls for the cycle, array increment controls, and loop controls
- Eight loop controllers, which can be used to form loops around a single or multiple instructions and can be nested to form complex sequences of ALU operations
- Five array controllers, each of which configure and control access to an independent matrix of data in system memory. The MVP supports arrays of up to 3 dimensions and each dimension can be independently incremented by the load/store streams, instruction, or loop controller on any given cycle

All of the MVP's control registers reside within its own register space, including the eight instructions (each of which is three 32-bit words). The MVP's register space has been organized such that DMA can be used to program all the configuration registers sequentially and initiate an operation with minimal CPU intervention. Once the program has successfully completed (by reaching an instruction with ENDPROG while completing all outstanding loops), the MVP interrupts the CPU with the PROGDONE interrupt. In the case of a fatal error (usually misprogramming), the MVP issues an error interrupt and terminate processing immediately.

## 32. Revision History

### Revision 1.1

January, 2024

- [4.2.4.1 Peripheral Map](#): Removed non-essential entries
- [4.2.2 Flash](#): Removed flash erase cycle and data retention endurance. Flash characteristics are provided in device datasheet and data retention information is published in Quarterly Quality and Reliability Report.
- [6.3.5 Bootloader](#): Updated user guide reference from UG266 to UG489.
- [6.3.12 Erase and Write Operations](#): Removed flash write and erase operations clock source and configuration information. These settings should not be modified from default.
- [6.6.5 SYSCFG Register Map](#): Updated SYSCFG\_CHIPREVHW.FAMILY reset value and added SYSCFG\_CHIPREV.CHIP values and register bit descriptions.
- [6.8.8 MSC\\_STATUS - Status Register](#): Fixed TIMEOUT, PENDING, and ERASEABORTED bit descriptions.
- [6.6.7 MPAHBRAM Register Map](#): Removed internal configuration registers from map.
- [Figure 8.2 High Frequency Peripheral Clocks on page 150](#): Added KEYS SCAN peripheral in EM01GRPACLK branch.
- [9.4.3.2 Lock Modes](#): Updated language regarding DPLL phase lock mode.
- [12.7.5 DCDC\\_PFMXCTRL - PFMX Control Register](#): Added IPKVAL enumerations and descriptions for 90 mA through 120 mA Ipeak.
- [23. IADC - Incremental Analog to Digital Converter](#): Updated chapter content to include high-speed and high-accuracy mode information
- [24. GPIO - General Purpose Input/Output](#): Updated GPIO\_IF clear and set register references throughout chapter to match register naming convention.
- [LDMA](#)
  - [25.3.7.2 SYNC Descriptor Structure](#): Added missing fields in SRC and DST words.
  - [25.3.7.3 WRI Descriptor Structure](#): Added missing field in SRC word.
  - Clarifications and corrections to LDMA\_IPVERSION, LDMA\_CHDONE, LDMA\_CHDIS, and LDMA\_CHx\_LINK bitfield descriptions
- [29. ACMP - Analog Comparator](#): Deprecated capacitive sensing. Removed capacitive sense mode chapter, removed register description mentions of capacitive sensing, and removed other references of capacitive sensing throughout document. This feature is not recommended for new designs.
- [30. KEYS SCAN - Keyboard Scan](#): Updated row configuration description to add clarification regarding available ports.

## Revision 1.0

May, 2023

- FRONT PAGE: Updated Front Page block diagram **EFR32xG24 Wireless SoC** to indicate that the LFRCO is available down to EM4
- SYSTEM OVERVIEW: Corrected memory map diagram and text in [4.2 Functional Description](#)
- SE: Added Secure Element chapter [11. SE - Secure Engine Subsystem](#)
- EMU: General improvements and clarifications in [Table 12.2 Energy Modes on page 291](#) table
- EMU: Added BURAM to Power Domains table in [Table 12.4 Peripheral Power Subdomains on page 298](#)
- EMU: Added EMU.TAMPERRSTCAUSE register and removed EMU.SEQIF and EMU.SEQIEN registers in [12.5 EMU Register Description](#)
- EMU: Added EMU.CMD.TAMPERRCCLR bit to [12.5.10 EMU\\_CMD - EMU Command Register](#)
- EMU: Added EMU.RSTCAUSE.SETAMPER bit to [12.5.16 EMU\\_RSTCAUSE - Reset Cause](#)
- DCDC: Corrected Buck Mode Recommended Settings for EM23CTRL0.DRVSPEED and CTRL.IPKTMAXCTRL in [12.3.8.3 Buck DC-DC Recommended Configuration Settings](#)
- DCDC: Corrected EM23CTRL0.IPKVAL enums in [12.7.4 DCDC\\_EM23CTRL0 - EM23 Control](#)
- DCDC: Updated register enum descriptions for DRVSPEED in [12.7.4 DCDC\\_EM23CTRL0 - EM23 Control](#) and [12.7.3 DCDC\\_EM01CTRL0 - EM01 Control](#) to clarify that only the default setting is recommended for use (no benefit to using other settings)
- DCDC: Corrected DCDC.PFXMCTRL.IPKVAL description equation in [12.7.5 DCDC\\_PFMXCTRL - PFMX Control Register](#)
- PRS: Corrected number of asynchronous PRS channels from 12 to 16 in [13. PRS - Peripheral Reflex System](#)
- EUSART: Updates to [EUSART](#) chapter to clarify operation differences when running from a low-frequency vs high-frequency clock source on EUSART0.
- GPIO: Added GPIO.RAC\_ROUTEEN, GPIO.RAC\_LNAENROUTE, and GPIO.RAC\_PAENROUTE registers to [24. GPIO - General Purpose Input/Output](#)
- LDMA: Corrected [25.7.28 LDMA\\_CHx\\_LINK - Channel Descriptor Link Address](#) description to add a "NOT". Correct description reads: "After completing the initial transfer, if this bit is NOT set, the DMA will load the next linked descriptor. If the next linked descriptor also has this bit set, the DMA will load the next linked descriptor."
- VDAC: Updates to [28.3.17 Sine Generation Mode](#) section
- ACMP: Added note about additional warm-up time required when BIAS<=3 to [29.3.2 Warmup Time](#)
- MVP: Removed Registers and Definitions from MVP section - use of the MVP shouldn't require access to these registers

## Revision 0.5

April, 2022

- Updated System Block Diagrams
- Many register bits access descriptions updated to add (nB) or (r) designators
- Acronym clarifications in [5. Radio Transceiver](#) section
- **System Chapter:**
  - Added M33CTI0/1 to Interrupt Request Lines table
- **6. MSC - Memory System Controller** Chapter:
  - Renamed MSC\_PAGELOCKWORDx registers to MSC\_PAGELOCKx
  - Added Write/Erase via "debug" for Information block in [Table 6.1 MSC Flash Memory Mapping](#) on page 56
- Removed Debug Chapter registers
- **8. CMU - Clock Management Unit** Chapter:
  - Updated clock tree showing EM01GRPACLK vs EM01GRPACLKRT
  - Corrected max PCLK and RHCLK frequencies from 50MHz to 40MHz throughout chapter
  - Clarifications on naming of EXPORTCLK throughout chapter and register descriptions
  - Clarifications to and [8.3.5 Clock Output](#) sections
  - Added HFRCODPLLRT and HFXORT enums to EM01GRPxCLKCTRL.CLKSEL bitfields
- **9. Oscillators** Chapter:
  - Corrected typical HFXO crystal frequency from 38.4 to 39 MHz
  - Improvements to [9.6.3.4.1 Reference Frequency](#) section
  - Added EM23ONDEMAND bit to HFRCO\_CTRL register
  - Added HFRCOEM23 to HFRCO features
  - Updated text to clarify that ULFRCO is available in EM4 in [9.8 ULFRCO - Ultra Low Frequency RC Oscillator](#)
- **12. EMU - Energy Management Unit** Chapter:
  - Clarified that EM1P only supports RX radio usage (not TX)
  - Removed PPMODE bit from the DCDC\_STATUS, DCDC\_IEN, DCDC\_IF registers
  - Corrections to section
  - Improvements to the Power Domains section
  - Added IADC, ACMP, and VDAC to the Low Energy Wakeup Triggers
  - Updated Temperature Sensor Polynomial Coefficients
- **13. PRS - Peripheral Reflex System** Chapter:
  - Clarified modules using synchronous channels
  - Added CORE CTIOUTx signals to [13.3.3 Producers](#) table
  - Corrections to [Table 13.3 List of Logic Functions](#) on page 348
- **20. USART - Universal Synchronous Asynchronous Receiver/Transmitter** Chapter: Inclusive language updates
- **21. EUSART - Universal Synchronous Asynchronous Receiver/Transmitter** Chapter:
  - Added CSWU bit to EUSART\_IEN and EUSART\_IF registers
  - Added IRLFCFG register
  - Added RXDMAWU and TXDMAWU bits to EUSART\_CFG1 register
  - Inclusive language updates
- **22. I2C - Inter-Integrated Circuit Interface** Chapter:
  - Clarified DMA support
  - Inclusive language updates
- **23. IADC - Incremental Analog to Digital Converter** Chapter:
  - Removed VREF from odd / even mux inputs in Block Diagram and text
  - Removed SINGLEDATADV and SCANDATADV bits from IADC\_STATUS
  - Added High Speed and High Accuracy register options in IADC\_CFGx.ADCMODE
  - Added OSRHA bitfield in IADC\_CFGx.ADCMODE
  - Added External VREF=2.5V option in IADC\_CRFx.REFSEL

- [24. GPIO - General Purpose Input/Output Chapter:](#)
  - Renamed all "GPIO\_TIMERx\_CCCx" registers, bits, and signals to "GPIO\_TIMERx\_CDTIx"
  - Improvements in display of GPIO Alternate Function Table
  - Added note on SWV pin and debug lock in [24.3.9.2 Serial Wire Debug Connection](#)
  - Removed DCDC and RAC ROUTEEN registers
- Added additional notes on input frequency in [27.3.8 PRS and PCNTn\\_S0IN,PCNTn\\_S1IN Inputs](#)
- Clarified energy mode support in [26. WDOG - Watch Dog Timer Chapter](#)

## Revision 0.2

October, 2021

- Removed references to non-applicable blocks

## Revision 0.1

July, 2021

- Initial Release

## Appendix 1. Abbreviations

This section lists abbreviations used in this document.

**Table 1.1. Abbreviations**

| Abbreviation | Description                                                                                        |
|--------------|----------------------------------------------------------------------------------------------------|
| ADC          | Analog to Digital Converter                                                                        |
| AES          | Advanced Encryption Standard                                                                       |
| AFC          | Automatic Frequency Control                                                                        |
| AGC          | Automatic Gain Control                                                                             |
| AHB          | AMBA Advanced High-performance Bus. AMBA is short for "Advanced Microcontroller Bus Architecture". |
| APB          | AMBA Advanced Peripheral Bus. AMBA is short for "Advanced Microcontroller Bus Architecture".       |
| APC          | Automatic Power Control                                                                            |
| ASK          | Amplitude Shift Keying                                                                             |
| BLE          | Bluetooth Low Energy                                                                               |
| BLE-LR       | Bluetooth Low Energy Long Range                                                                    |
| BR           | Baud Rate                                                                                          |
| BT           | Bandwidth Time product                                                                             |
| BUFC         | Buffer Controller                                                                                  |
| BW           | Bandwidth                                                                                          |
| CBC          | Cipher Block Chaining (AES mode of operation)                                                      |
| CBC-MAC      | Cipher Block Chaining - Message Authentication Code (AES mode of operation)                        |
| CC           | Compare / Capture                                                                                  |
| CCA          | Clear Channel Assessment                                                                           |
| CFB          | Cipher Feedback (AES mode of operation)                                                            |
| CHF          | Channel Filter                                                                                     |
| CLK          | Clock                                                                                              |
| CM3          | ARM Cortex-M3                                                                                      |
| CM4          | ARM Cortex-M4                                                                                      |
| CMD          | Command                                                                                            |
| CMU          | Clock Management Unit                                                                              |
| CRC          | Cyclic Redundancy Check                                                                            |
| CTR          | Counter mode (AES mode of operation)                                                               |
| CTRL         | Control                                                                                            |
| DBG          | Debug                                                                                              |
| DC           | Direct Current                                                                                     |
| DEC          | Decimator                                                                                          |
| DEMOD        | Demodulator                                                                                        |

| Abbreviation | Description                                        |
|--------------|----------------------------------------------------|
| DSA          | Detection of Signal Arrival                        |
| DSSS         | Direct Sequence Spread Spectrum                    |
| ECB          | Electronic Code Book (AES mode of operation)       |
| EFM32        | Energy Friendly Microcontroller                    |
| EFR32        | Wireless Gecko                                     |
| EM           | Energy Mode                                        |
| EMU          | Energy Management Unit                             |
| FEC          | Forward Error Correction                           |
| FIR          | Finite Impulse Response                            |
| FRC          | Frame Controller                                   |
| FSK          | Frequency Shift Keying                             |
| FSM          | Finite State Machine                               |
| GFSK         | Gaussian Frequency Shift Keying                    |
| GMSK         | Gaussian Minimum Shift Keying                      |
| GPIO         | General Purpose Input / Output                     |
| HFRCO        | High Frequency RC Oscillator                       |
| HFXO         | High Frequency Crystal Oscillator                  |
| HW           | Hardware                                           |
| Hz           | Hertz                                              |
| IF           | Intermediate Frequency                             |
| IFADC        | Intermediate Frequency Analog to Digital Converter |
| ISR          | Interrupt Service Routine                          |
| LFRCO        | Low Frequency RC Oscillator                        |
| LFXO         | Low Frequency Crystal Oscillator                   |
| LNA          | Low Noise Amplifier                                |
| LO           | Local Oscillator                                   |
| MOD          | Modulator                                          |
| MODEM        | Modulator and Demodulator                          |
| MSK          | Minimum Shift Keying                               |
| NRZ          | Non Return to Zero                                 |
| NVIC         | Nested Vector Interrupt Controller                 |
| OFB          | Output Feedback Mode (AES mode of operation)       |
| OOK          | On Off Keying                                      |
| OQPSK        | Offset Quadrature Phase Shift Keying               |
| OSR          | Over-Sampling Ratio                                |
| PA           | Power Amplifier                                    |
| PD           | Power Down                                         |

| Abbreviation | Description                        |
|--------------|------------------------------------|
| PHY          | Physical Layer                     |
| PROTIMER     | Protocol Timer                     |
| PRS          | Peripheral Reflex System           |
| PWM          | Pulse Width Modulation             |
| RAC          | Radio Controller                   |
| RAM          | Random Access Memory               |
| RF           | Radio Frequency                    |
| RMU          | Reset Management Unit              |
| RSM          | Radio State Machine                |
| RSSI         | Received Signal Strength Indicator |
| RTC          | Real Time Counter                  |
| RX           | Receive                            |
| SEQ          | Radio Sequencer                    |
| SPI          | Serial Peripheral Interface        |
| SRC          | Sample Rate Converter              |
| STIMER       | Sequencer Timer                    |
| SW           | Software                           |
| SYNTH        | Synthesizer                        |
| TX           | Transmit                           |
| XTAL         | Crystal                            |

# Simplicity Studio

One-click access to MCU and wireless tools, documentation, software, source code libraries & more. Available for Windows, Mac and Linux!



## IoT Portfolio

[www.silabs.com/IoT](http://www.silabs.com/IoT)



## SW/HW

[www.silabs.com/simplicity](http://www.silabs.com/simplicity)



## Quality

[www.silabs.com/quality](http://www.silabs.com/quality)



## Support & Community

[www.silabs.com/community](http://www.silabs.com/community)

### Disclaimer

Silicon Labs intends to provide customers with the latest, accurate, and in-depth documentation of all peripherals and modules available for system and software implementers using or intending to use the Silicon Labs products. Characterization data, available modules and peripherals, memory sizes and memory addresses refer to each specific device, and "Typical" parameters provided can and do vary in different applications. Application examples described herein are for illustrative purposes only. Silicon Labs reserves the right to make changes without further notice to the product information, specifications, and descriptions herein, and does not give warranties as to the accuracy or completeness of the included information. Without prior notification, Silicon Labs may update product firmware during the manufacturing process for security or reliability reasons. Such changes will not alter the specifications or the performance of the product. Silicon Labs shall have no liability for the consequences of use of the information supplied in this document. This document does not imply or expressly grant any license to design or fabricate any integrated circuits. The products are not designed or authorized to be used within any FDA Class III devices, applications for which FDA premarket approval is required or Life Support Systems without the specific written consent of Silicon Labs. A "Life Support System" is any product or system intended to support or sustain life and/or health, which, if it fails, can be reasonably expected to result in significant personal injury or death. Silicon Labs products are not designed or authorized for military applications. Silicon Labs products shall under no circumstances be used in weapons of mass destruction including (but not limited to) nuclear, biological or chemical weapons, or missiles capable of delivering such weapons. Silicon Labs disclaims all express and implied warranties and shall not be responsible or liable for any injuries or damages related to use of a Silicon Labs product in such unauthorized applications.

**Note: This content may contain offensive terminology that is now obsolete. Silicon Labs is replacing these terms with inclusive language wherever possible. For more information, visit [www.silabs.com/about-us/inclusive-lexicon-project](http://www.silabs.com/about-us/inclusive-lexicon-project)**

### Trademark Information

Silicon Laboratories Inc.<sup>®</sup>, Silicon Laboratories<sup>®</sup>, Silicon Labs<sup>®</sup>, SiLabs<sup>®</sup> and the Silicon Labs logo<sup>®</sup>, Bluegiga<sup>®</sup>, Bluegiga Logo<sup>®</sup>, EFM<sup>®</sup>, EFM32<sup>®</sup>, EFR, Ember<sup>®</sup>, Energy Micro, Energy Micro logo and combinations thereof, "the world's most energy friendly microcontrollers", Redpine Signals<sup>®</sup>, WiSeConnect, n-Link, ThreadArch<sup>®</sup>, EZLink<sup>®</sup>, EZRadio<sup>®</sup>, EZRadioPRO<sup>®</sup>, Gecko<sup>®</sup>, Gecko OS, Gecko OS Studio, Precision32<sup>®</sup>, Simplicity Studio<sup>®</sup>, Telegesis, the Telegesis Logo<sup>®</sup>, USBXpress<sup>®</sup>, Zentri, the Zentri logo and Zentri DMS, Z-Wave<sup>®</sup>, and others are trademarks or registered trademarks of Silicon Labs. ARM, CORTEX, Cortex-M3 and THUMB are trademarks or registered trademarks of ARM Holdings. Keil is a registered trademark of ARM Limited. Wi-Fi is a registered trademark of the Wi-Fi Alliance. All other products or brand names mentioned herein are trademarks of their respective holders.