# EFR32xG22 Wireless Gecko Reference Manual The EFR32xG22 Wireless Gecko SoC includes the EFR32BG22, EFR32FG22, and EFR32MG22 Wireless Gecko families. The EFR32xG22 improves processing capability with a 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.2 (including Direction Finding), Proprietary 2.4 GHz & Zigbee PRO/Green Power protocols. The EFR32xG22 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 76.8 MHz maximum operating frequency - Scalable Memory and Radio configuration options available in QFN packaging - Energy-efficient radio core with low active and sleep currents - Secure Boot with Root of Trust and Secure Loader (RTSL) - Integrated PA with up to 6 dBm transmit power # **Table of Contents** | 1. | About This Document | . 24 | |----|-------------------------------------------|------------| | | 1.1 Introduction | 24 | | | 1.2 Conventions | 25 | | | 1.3 Related Documentation | | | | | | | 2. | System Overview | | | | 2.1 Introduction | 28 | | | 2.2 Block Diagrams | 28 | | | 2.3 MCU Features overview | 29 | | 3. | System Processor | . 31 | | | 3.1 Introduction | | | | 3.2 Features | | | | | | | | 3.3 Functional Description | | | | 3.3.1 Interrupt Operation | | | | 3.3.2 TrustZone | | | | 3.3.3 Interrupt Request lines (IRQ) | 34 | | 4. | Memory and Bus System | . 36 | | | 4.1 Introduction | 36 | | | 4.2 Functional Description | 37 | | | 4.2.1 Bus Matrix | | | | 4.2.2 Flash | | | | 4.2.3 SRAM | | | | 4.2.4 Peripherals | | | _ | · | | | 5. | Radio Transceiver | | | | 5.1 Introduction | | | | 5.1.1 RF Frequency Synthesizer | 46 | | | 5.1.2 Modulation Modes | 47 | | | 5.1.3 Transmit Mode | 47 | | | 5.1.4 Receive Mode | 47 | | | 5.1.5 Data Buffering | 47 | | | 5.1.6 Unbuffered Data Transfer | 47 | | | 5.1.7 Frame Format Support | 48 | | | 5.1.8 Hardware CRC Support | 48 | | | 5.1.9 Convolutional Encoding / Decoding | 48 | | | 5.1.10 Binary Block Encoding / Decoding | 48 | | | 5.1.11 Data Encryption and Authentication | 49 | | | 5.1.12 RFSENSE | | | | 5.1.13 RF Test Modes | 49 | | 6 | MSC - Memory System Controller | <b>5</b> 0 | | U. | • • | | | | 6.1 Introduction | 50 | | 6.2 Features | | .51 | |-------------------------------------------------------------------|---|------| | 6.3 Functional Description | | .51 | | 6.3.1 Ram Configuration | | .51 | | 6.3.2 Instruction Cache | | .52 | | 6.3.3 Device Information (DI) Page | | .52 | | 6.3.4 User Data (UD) Page Description | | .52 | | 6.3.5 Bootloader | | .52 | | 6.3.6 Post-reset Behavior | | .52 | | 6.3.7 Flash Startup | | .52 | | 6.3.8 Flash EM0 / EM1 Power Down | | .53 | | 6.3.9 Wait-states | | .53 | | 6.3.10 Cortex-M33 If-Then Block Folding | | .53 | | 6.3.11 Line Buffering (Prefetch) | | .53 | | 6.3.12 Erase and Write Operations | | .54 | | 6.4 DEVINFO - Device Info Page | | .55 | | 6.4.1 DEVINFO Register Map | | | | 6.4.2 DEVINFO Register Description | | | | 6.5 ICACHE - Instruction Cache | | | | 6.5.1 Cache Operation | | | | 6.5.2 Performance Measurement | | | | 6.5.3 ICACHE Register Map | | | | · | | | | 6.5.4 ICACHE Register Description | | | | 6.6 SYSCFG - System Configuration | | | | 6.6.1 Ram Retention | | | | 6.6.2 ECC | | | | 6.6.3 Software Interrupts | | | | 6.6.4 Bus faults | | | | 6.6.5 SYSCFG Register Map. | | | | 6.6.6 SYSCFG Register Description | • | .97 | | 6.7 MSC Register Map | | 110 | | 6.8 MSC Register Description | | .112 | | 6.8.1 MSC_IPVERSION - IP version ID | | | | 6.8.2 MSC_READCTRL - Read Control Register | | | | 6.8.3 MSC_WRITECTRL - Write Control Register | | | | 6.8.4 MSC_WRITECMD - Write Command Register | | | | 6.8.5 MSC_ADDRB - Page Erase/Write Address Buffer | | | | 6.8.6 MSC_WDATA - Write Data Register | | | | 6.8.7 MSC STATUS - Status Register | | | | 6.8.8 MSC_IF - Interrupt Flag Register | | .118 | | 6.8.9 MSC_IEN - Interrupt Enable Register | | | | 6.8.10 MSC_USERDATASIZE - User Data Region Size Register | | | | 6.8.11 MSC_CMD - Command Register | | | | 6.8.12 MSC_LOCK - Configuration Lock Register | | | | 6.8.13 MSC_MISCLOCKWORD - Mass erase and User data page lock word | | | | 6.8.14 MSC_PWRCTRL - Power control register | | | | 6.8.15 MSC_PAGELOCK0 - Main space page 0-31 lock word | | | | 6 8 16 MSC PAGELOCK1 - Main space page 32-63 lock word | | 123 | | 7. | DBG - Debug Interface | . 124 | |----|--------------------------------------------------------|-------| | | 7.1 Introduction | . 124 | | | 7.2 Features | . 124 | | | 7.3 Functional Description | . 125 | | | 7.3.1 Debug Pins | | | | 7.3.2 Embedded Trace Macrocell V3.5 (ETM) | . 125 | | | 7.3.3 Debug and EM2/EM3 | . 125 | | | 7.4 DBG Register Map | . 126 | | | 7.5 DBG Register Description | .126 | | | 7.5.1 DBG_DCIWDATA - Write Data | | | | 7.5.2 DBG_DCIRDATA - Read Data | .126 | | | 7.5.3 DBG_DCISTATUS - Status | .127 | | | 7.5.4 DBG_DCIID - Identification | | | | 7.5.5 DBG_SYSCOM0 - Communication Status | | | | 7.5.6 DBG_SYSCOM1 - Communication Status | | | | 7.5.7 DBG_SYSPWR0 - Power Status | | | | 7.5.8 DBG_SYSCLK0 - Clocking Status | | | | 7.5.9 DBG_SYSID - Identification | .133 | | 8. | CMU - Clock Management Unit | . 134 | | | 8.1 Introduction | . 134 | | | 8.2 Features | . 134 | | | 8.3 Functional Description | . 135 | | | 8.3.1 System Clocks | . 137 | | | 8.3.2 Switching Clock Source | . 140 | | | 8.3.3 RC Oscillator Calibration | | | | 8.3.4 Energy Modes | | | | 8.3.5 Clock Output on a Pin | | | | 8.3.6 Clock Input from a Pin | | | | 8.3.7 Clock Output on PRS | | | | 8.3.8 Interrupts | | | | 8.3.9 Protection | | | | 8.4 CMU Register Map | | | | 8.5 CMU Register Description | | | | 8.5.1 CMU_IPVERSION - IP version ID | | | | 8.5.2 CMU_STATUS - Status Register | | | | 8.5.3 CMU_LOCK - Configuration Lock Register | | | | 8.5.4 CMU_WDOGLOCK - WDOG Configuration Lock Register | | | | 8.5.5 CMU_IF - Interrupt Flag Register | | | | 8.5.6 CMU_IEN - Interrupt Enable Register | | | | 8.5.7 CMU_CALCMD - Calibration Command Register | | | | 8.5.9 CMU_CALCNT - Calibration Result Counter Register | | | | 8.5.10 CMU_CLKEN0 - Clock Enable Register 0 | | | | 8.5.11 CMU_CLKEN1 - Clock Enable Register 1 | | | | 8.5.12 CMU SYSCLKCTRL - System Clock Control | . 161 | | | 8.5.13 CMU_TRACECLKCTRL - Debug Trace Clock Control | . 162 | |----|--------------------------------------------------------------------|-------| | | 8.5.14 CMU_EXPORTCLKCTRL - Export Clock Control | 163 | | | 8.5.15 CMU_DPLLREFCLKCTRL - Digital PLL Reference Clock Control | . 165 | | | 8.5.16 CMU_EM01GRPACLKCTRL - EM01 Peripheral Group A Clock Control | . 165 | | | 8.5.17 CMU_EM01GRPBCLKCTRL - EM01 Peripheral Group B Clock Control | . 166 | | | 8.5.18 CMU_EM23GRPACLKCTRL - EM23 Peripheral Group A Clock Control | . 167 | | | 8.5.19 CMU_EM4GRPACLKCTRL - EM4 Peripheral Group A Clock Control | . 167 | | | 8.5.20 CMU_IADCCLKCTRL - IADC Clock Control | .168 | | | 8.5.21 CMU_WDOG0CLKCTRL - Watchdog0 Clock Control | | | | 8.5.22 CMU_EUART0CLKCTRL - UART Clock Control | . 169 | | | 8.5.23 CMU_RTCCCLKCTRL - RTCC Clock Control | . 169 | | | 8.5.24 CMU_CRYPTOACCCLKCTRL - CRYPTOACC Clock Control | | | | 8.5.25 CMU_RADIOCLKCTRL - Radio Clock Control | 170 | | 9 | Oscillators | 171 | | ٠. | 9.1 Introduction | | | | | | | | 9.2 HFXO - High Frequency Crystal Oscillator | | | | 9.2.1 Introduction | | | | 9.2.2 Features | | | | 9.2.3 Functional Description | | | | 9.2.4 HFXO Register Map | | | | 9.2.5 HFXO Register Description | | | | 9.3 HFRCO - High-Frequency RC Oscillator | | | | 9.3.1 Introduction | | | | 9.3.2 Features | | | | 9.3.3 Functional Description | | | | 9.3.4 HFRCO Register Map | | | | 9.3.5 HFRCO Register Description | | | | 9.4 DPLL - Digital Phased Locked Loop | . 195 | | | 9.4.1 Introduction | | | | 9.4.2 Features | | | | 9.4.3 Functional Description | | | | 9.4.4 DPLL Register Map | | | | 9.4.5 DPLL Register Description | 198 | | | 9.5 LFXO - Low-Frequency Crystal Oscillator | . 203 | | | 9.5.1 Introduction | . 203 | | | 9.5.2 Features | . 203 | | | 9.5.3 Functional Description | . 203 | | | 9.5.4 LFXO Register Map | | | | 9.5.5 LFXO Register Description | 206 | | | 9.6 LFRCO - Low-Frequency RC Oscillator | 213 | | | 9.6.1 Introduction | | | | 9.6.2 Features | | | | 9.6.3 Functional Description | . 213 | | | 9.6.4 LFRCO Register Map | .216 | | | 9.6.5 LFRCO Register Description | . 217 | | | 9.7 FSRCO - Fast Start RCO | 224 | | 9.7.1 Introduction | 224 | |----------------------------------------------------------|-----| | 9.7.2 Features | 224 | | 9.7.3 Functional Description | 224 | | 9.7.4 FSRCO Register Map | 224 | | 9.7.5 FSRCO Register Description | 225 | | 9.8 ULFRCO - Ultra Low Frequency RC Oscillator | 225 | | 9.8.1 Introduction | | | 9.8.2 Features | | | 9.8.3 Functional Description | | | | | | 10. SMU - Security Management Unit | | | 10.1 Introduction | 226 | | 10.2 Features | 226 | | 10.3 Functional Description | 227 | | 10.3.1 Bus Level Security | | | 10.3.2 Privileged Access Control | | | 10.3.3 Secure Access Control | | | 10.3.4 ARM TrustZone | | | | | | 10.3.5 Configuring Masters | | | 10.3.6 Configuring Peripherals | | | 10.3.7 Configuring Memory | | | 10.3.8 Cortex-M33 Integration | | | 10.3.9 Exception Handling | | | 10.3.10 SMU Lock | 231 | | 10.4 SMU Register Map | 232 | | 10.5 SMU Register Description | 234 | | 10.5.1 SMU_IPVERSION - IP Version | | | 10.5.2 SMU STATUS - Status | | | 10.5.3 SMU_LOCK - Lock | | | 10.5.4 SMU IF - Interrupt Flag | | | 10.5.5 SMU_IEN - Interrupt Enable | | | — · · · · · · · · · · · · · · · · · · · | | | 10.5.6 SMU_M33CTRL - M33 Control | | | 10.5.7 SMU_PPUPATD0 - PPU PATD Register 0 | | | 10.5.8 SMU_PPUPATD1 - PPU PATD Register 1 | | | 10.5.9 SMU_PPUSATD0 - PPU SATD Register 0 | | | 10.5.10 SMU_PPUSATD1 - PPU SATD Register 1 | | | 10.5.11 SMU_PPUFS - PPU Fault Status | | | 10.5.12 SMU_BMPUPATD0 - BMPU PATD Register 0 | | | 10.5.13 SMU_BMPUSATD0 - BMPU SATD Register 0 | | | 10.5.14 SMU_BMPUFS - BMPU Fault Status | | | 10.5.15 SMU_BMPUFSADDR - BMPU Fault Status Address | | | 10.5.16 SMU_ESAURTYPES0 - ESAU Region Types Register 0 | 250 | | 10.5.17 SMU_ESAURTYPES1 - ESAU Region Types Register 1 | 250 | | 10.5.18 SMU_ESAUMRB01 - ESAU Movable Region Boundary 0-1 | 251 | | 10.5.19 SMU_ESAUMRB12 - ESAU Movable Region Boundary 1-2 | 251 | | 10.5.20 SMU_ESAUMRB45 - ESAU Movable Region Boundary 4-5 | 252 | | 10.5.21 SMU ESAUMRB56 - ESAU Movable Region Boundary 5-6 | 252 | | 11. CRYPTOACC - Cryptographic Accelerator | 253 | |-----------------------------------------------------------------------|-------| | 11.1 Introduction | . 253 | | 11.2 Features | . 253 | | 11.3 Cryptographic Functions | | | 11.3.1 CRYPTOACC_PKCTRL Register Map | | | 11.3.2 CRYPTOACC_PKCTRL Register Description | | | 11.4 DMA Interface | | | 11.4.1 CRYPTOACC Register Map | | | 11.4.2 CRYPTOACC Register Description | | | 11.5 Random Number Generation | | | 11.5.1 CRYPTOACC_RNGCTRL Register Map | | | 11.5.2 CRYPTOACC_RNGCTRL Register Description | | | 12. EMU - Energy Management Unit | | | | | | 12.1 Introduction | | | 12.2 Features | . 286 | | 12.3 Functional Description | | | 12.3.1 Energy Modes | | | 12.3.2 Entering Low Energy Modes | | | 12.3.3 Exiting a Low Energy Mode | | | 12.3.4 Power Domains | | | 12.3.5 Voltage Scaling | | | 12.3.7 Power Configurations | | | 12.3.8 DC-to-DC Interface | | | 12.3.9 EFP Communication | | | 12.3.10 Brown Out Detector (BOD) | | | 12.3.11 Reset Management Unit | . 303 | | 12.3.12 Temperature Sensor | 305 | | 12.3.13 Register Resets | | | 12.3.14 Register Locks | 306 | | 12.4 EMU Register Map | 307 | | 12.5 EMU Register Description | 309 | | 12.5.1 EMU_DECBOD - DECOUPLE LVBOD Control register | | | 12.5.2 EMU_BOD3SENSE - BOD3SENSE Control register | . 310 | | 12.5.3 EMU_VREGVDDCMPCTRL - DC-DC VREGVDD Comparator Control Register | | | 12.5.4 EMU_PD1PARETCTRL - PD1 Partial Retention Control | | | 12.5.5 EMU_LOCK - EMU Configuration lock register | | | 12.5.6 EMU_IF - Interrupt Flags | | | 12.5.7 EMU_IEN - Interrupt Enables | | | 12.5.8 EMU_EM4CTRL - EM4 Control | | | 12.5.9 EMU_CMD - EMU Control register | | | 12.5.10 EMO_CTRL - EMO Control register | | | 12.5.12 EMU_STATUS - EMU Status register | | | 12.5.13 EMU_TEMP - Temperature | | | | | | 12.5.14 EMU_RSTCTRL - Reset Management Control register | 320 | |---------------------------------------------------------------------------|----------| | 12.5.15 EMU_RSTCAUSE - Reset cause | . 322 | | 12.5.16 EMU_DGIF - Interrupt Flags Debug | 323 | | 12.5.17 EMU_DGIEN - Interrupt Enables Debug | 324 | | 12.5.18 EMU_EFPIF - EFP Interrupt Register | 324 | | 12.5.19 EMU_EFPIEN - EFP Interrupt Enable Register | 325 | | 12.6 DCDC Register Map | 326 | | 12.7 DCDC Register Description | 327 | | 12.7.1 DCDC_IPVERSION - IPVERSION | . 327 | | 12.7.2 DCDC_EN - Enable | . 327 | | 12.7.3 DCDC_CTRL - Control | 328 | | 12.7.4 DCDC_EM01CTRL0 - EM01 Control | | | 12.7.5 DCDC_EM23CTRL0 - EM23 Control | 330 | | 12.7.6 DCDC_IF - Interrupt Flags | 331 | | 12.7.7 DCDC_IEN - Interrupt Enable | 332 | | 12.7.8 DCDC_STATUS - Status Register | 333 | | 12.7.9 DCDC_LOCK - Lock Register | 334 | | 12.7.10 DCDC_LOCKSTATUS - Lock Status Register | 334 | | 3. PRS - Peripheral Reflex System | 335 | | 13.1 Introduction | 335 | | 13.2 Features | 335 | | 13.3 Functional Description | 336 | | 13.3.1 Asynchronous Channel Functions. | | | 13.3.2 Configurable Logic | | | 13.3.3 Producers | | | 13.3.4 Consumers | 343 | | 13.4 PRS Register Map | 344 | | 13.5 PRS Register Description | 357 | | 13.5.1 PRS IPVERSION - IP version ID | | | 13.5.2 PRS_ASYNC_SWPULSE - Software Pulse Register | 358 | | 13.5.3 PRS_ASYNC_SWLEVEL - Software Level Register | 359 | | 13.5.4 PRS_ASYNC_PEEK - Async Channel Values | 360 | | 13.5.5 PRS_SYNC_PEEK - Sync Channel Values | . 361 | | 13.5.6 PRS_ASYNC_CHx_CTRL - Async Channel Control Register | | | 13.5.7 PRS_SYNC_CHx_CTRL - Sync Channel Control Register | | | 13.5.8 PRS_CONSUMER_CMU_CALDN - CMU CALDN Consumer Selection | 364 | | 13.5.9 PRS_CONSUMER_CMU_CALUP - CMU CALUP Consumer Selection | 364 | | 13.5.10 PRS_CONSUMER_IADC0_SCANTRIGGER - IADC0 SCANTRIGGER Consumer Selec | tion 365 | | 13.5.11 PRS_CONSUMER_IADC0_SINGLETRIGGER - IADC0 SINGLETRIGGER Consumer | | | Selection | . 365 | | 13.5.12 PRS_CONSUMER_LDMAXBAR_DMAREQ0 - DMAREQ0 Consumer Selection | 366 | | 13.5.13 PRS_CONSUMER_LDMAXBAR_DMAREQ1 - DMAREQ1 Consumer Selection | 366 | | 13.5.14 PRS_CONSUMER_LETIMER0_CLEAR - LETIMER CLEAR Consumer Selection | | | 13.5.15 PRS_CONSUMER_LETIMER0_START - LETIMER START Consumer Selection | | | 13.5.16 PRS_CONSUMER_LETIMER0_STOP - LETIMER STOP Consumer Selection | | | 13.5.17 PRS CONSUMER FUARTO RX - FUARTO RX consumer register | 368 | | 13.5.18 | PRS_CONSUMER_EUART0_TRIGGER - EUART0 TRIGGER Consumer regist | ter | . 369 | |---------|---------------------------------------------------------------|-----|-------| | 13.5.19 | PRS_CONSUMER_MODEM_DIN - MODEM DIN Consumer Selection | | . 369 | | 13.5.20 | PRS_CONSUMER_RAC_CLR - RAC CLR Consumer Selection | | . 370 | | | PRS_CONSUMER_RAC_CTIIN0 - RAC CTIIN0 Consumer Selection | | | | | <del>-</del> | | 371 | | | PRS_CONSUMER_RAC_CTIIN2 - RAC CTIIN2 Consumer Selection | | 371 | | | PRS_CONSUMER_RAC_CTIIN3 - RAC CTIIN3 Consumer Selection | | 372 | | | PRS_CONSUMER_RAC_FORCETX - RAC FORCETX Consumer Selection | | . 372 | | | PRS_CONSUMER_RAC_RXDIS - RAC RXDIS Consumer Selection | | 373 | | | PRS_CONSUMER_RAC_RXEN - RAC RXEN Consumer Selection | | . 373 | | | PRS_CONSUMER_RAC_SEQ - RAC SEQ Consumer Selection | | . 374 | | | PRS_CONSUMER_RAC_TXEN - RAC TXEN Consumer Selection | | | | | PRS_CONSUMER_RTCC_CC0 - RTCC CC0 Consumer Selection | | | | | PRS_CONSUMER_RTCC_CC1 - RTCC CC1 Consumer Selection | | | | | | | | | | PRS_CONSUMER_RTCC_CC2 - RTCC CC2 Consumer Selection | | | | | PRS_CONSUMER_CORE_CTIIN0 - CTI0 Consumer Selection | | 376 | | | PRS_CONSUMER_CORE_CTIIN1 - CTI1 Consumer Selection | | 377 | | | PRS_CONSUMER_CORE_CTIIN2 - CTI2 Consumer Selection | | 377 | | | PRS_CONSUMER_CORE_CTIIN3 - CTI3 Consumer Selection | | 378 | | | PRS_CONSUMER_CORE_M33RXEV - M33 Consumer Selection | | 378 | | | PRS_CONSUMER_TIMER0_CC0 - TIMER0 CC0 Consumer Selection | | . 379 | | | PRS_CONSUMER_TIMER0_CC1 - TIMER0 CC1 Consumer Selection | | . 379 | | 13.5.40 | PRS_CONSUMER_TIMER0_CC2 - TIMER0 CC2 Consumer Selection | | . 380 | | 13.5.41 | PRS_CONSUMER_TIMER0_DTI - TIMER0 DTI Consumer Selection | | 380 | | 13.5.42 | PRS_CONSUMER_TIMER0_DTIFS1 - TIMER0 DTIFS1 Consumer Selection | | 381 | | 13.5.43 | PRS_CONSUMER_TIMER0_DTIFS2 - TIMER0 DTIFS2 Consumer Selection | | 381 | | 13.5.44 | PRS_CONSUMER_TIMER1_CC0 - TIMER1 CC0 Consumer Selection | | . 382 | | 13.5.45 | PRS_CONSUMER_TIMER1_CC1 - TIMER1 CC1 Consumer Selection | | . 382 | | 13.5.46 | PRS_CONSUMER_TIMER1_CC2 - TIMER1 CC2 Consumer Selection | | . 383 | | 13.5.47 | PRS_CONSUMER_TIMER1_DTI - TIMER1 DTI Consumer Selection | | 383 | | 13.5.48 | PRS CONSUMER TIMER1 DTIFS1 - TIMER1 DTIFS1 Consumer Selection | | 384 | | 13.5.49 | PRS_CONSUMER_TIMER1_DTIFS2 - TIMER1 DTIFS2 Consumer Selection | | 384 | | | | | . 385 | | | | | | | | | | | | | | | | | | PRS_CONSUMER_TIMER2_DTIFS1 - TIMER2 DTIFS1 Consumer Selection | | 387 | | | PRS CONSUMER TIMER2 DTIFS2 - TIMER2 DTIFS2 Consumer Selection | | | | | | | | | | | | | | | | | | | | | | | | | PRS_CONSUMER_TIMER3_DTIFS1 - TIMER3 DTIFS1 Consumer Selection | | | | | PRS CONSUMER TIMERS DTIFS1 - TIMERS DTIFS1 Consumer Selection | | | | | | | | | | <del>-</del> | | | | | <del>-</del> | | | | | | | | | 13565 | PRS_CONSUMER_TIMER4_DTI - TIMER4_DTI Consumer Selection | | 392 | | 13.5.66 PRS_CONSUMER_TIMER4_DTIFS1 - TIMER4 DTIFS1 Consumer Selection | 393 | |-------------------------------------------------------------------------|-----| | 13.5.67 PRS_CONSUMER_TIMER4_DTIFS2 - TIMER4 DTIFS2 Consumer Selection | 393 | | 13.5.68 PRS_CONSUMER_USART0_CLK - USART0 CLK Consumer Selection | | | 13.5.69 PRS_CONSUMER_USART0_IR - USART0 IR Consumer Selection | 394 | | 13.5.70 PRS_CONSUMER_USART0_RX - USART0 RX Consumer Selection | 395 | | 13.5.71 PRS_CONSUMER_USART0_TRIGGER - USART0 TRIGGER Consumer Selection | 395 | | 13.5.72 PRS_CONSUMER_USART1_CLK - USART1 CLK Consumer Selection | 396 | | 13.5.73 PRS_CONSUMER_USART1_IR - USART1 IR Consumer Selection | 396 | | 13.5.74 PRS_CONSUMER_USART1_RX - USART1 RX Consumer Selection | | | 13.5.75 PRS_CONSUMER_USART1_TRIGGER - USART1 TRIGGER Consumer Selection | | | 13.5.76 PRS_CONSUMER_WDOG0_SRC0 - WDOG0 SRC0 Consumer Selection | | | 13.5.77 PRS_CONSUMER_WDOG0_SRC1 - WDOG0 SRC1 Consumer Selection | 398 | | 14. GPCRC - General Purpose Cyclic Redundancy Check | 399 | | 14.1 Introduction | | | | | | 14.2 Features | | | 14.3 Functional Description | | | 14.3.1 Polynomial Specification | | | 14.3.2 Input and Output Specification | | | 14.3.3 Initialization | | | 14.3.4 DMA Usage | | | 14.3.5 Byte-Level Bit Reversal and Byte Reordering | | | 14.4 GPCRC Register Map | | | 14.5 GPCRC Register Description | | | 14.5.1 GPCRC_IPVERSION - IP Version ID | | | 14.5.2 GPCRC_EN - CRC Enable | | | 14.5.3 GPCRC_CTRL - Control Register | | | 14.5.4 GPCRC_CMD - Command Register | | | 14.5.5 GPCRC_INIT - CRC Init Value | | | 14.5.6 GPCRC_POLY - CRC Polynomial Value | | | 14.5.7 GPCRC_INPUTDATA - Input 32-bit Data Register | | | 14.5.8 GPCRC_INPUTDATAHWORD - Input 16-bit Data Register | | | 14.5.9 GPCRC_INPUTDATABYTE - Input 8-bit Data Register | | | 14.5.10 GPCRC_DATA - CRC Data Register | | | 14.5.11 GPCRC_DATARYTEREY - CRC Data Reverse Register | | | 14.5.12 GPCRC_DATABYTEREV - CRC Data Byte Reverse Register | 413 | | 15. RTCC - Real Time Clock with Capture | 414 | | 15.1 Introduction | 414 | | 15.2 Features | | | 15.3 Functional Description | | | 15.3.1 RTCC Counter | | | 15.3.2 Capture/Compare Channels | | | 15.3.3 Interrupts and PRS Output | | | 15.3.4 Register Lock | | | 15.3.5 Programmer's Model | | | 15.3.6 Debug Features and Description | 420 | | 15.4 RTCC Register Map | 421 | |--------------------------------------------------------------|-------| | 15.5 RTCC Register Description | 423 | | 15.5.1 RTCC_IPVERSION - IP VERSION | .423 | | 15.5.2 RTCC_EN - Module Enable Register | 423 | | 15.5.3 RTCC_CFG - Configuration Register | 424 | | 15.5.4 RTCC_CMD - Command Register | 425 | | 15.5.5 RTCC_STATUS - Status register | 426 | | 15.5.6 RTCC_IF - RTCC Interrupt Flags | 427 | | 15.5.7 RTCC_IEN - Interrupt Enable Register | . 428 | | 15.5.8 RTCC_PRECNT - Pre-Counter Value Register | .429 | | 15.5.9 RTCC_CNT - Counter Value Register | | | 15.5.10 RTCC_COMBCNT - Combined Pre-Counter and Counter Valu | | | 15.5.11 RTCC_SYNCBUSY - Synchronization Busy Register | | | 15.5.12 RTCC_LOCK - Configuration Lock Register | | | 15.5.13 RTCC_CCx_CTRL - CC Channel Control Register | | | 15.5.14 RTCC_CCx_OCVALUE - Output Compare Value Register | | | 15.5.15 RTCC_CCx_ICVALUE - Input Capture Value Register | .433 | | 16. BURTC - Back-Up Real Time Counter | 434 | | 16.1 Introduction | | | 16.2 Features | | | 16.3 Functional Description | | | 16.3.1 Clock Selection | | | 16.3.2 Configuration | | | 16.3.3 Debug Features and Description | | | 16.3.4 Counter | | | 16.3.5 Compare Channel | | | 16.3.6 Interrupts | | | 16.3.7 Register Lock | | | 16.4 BURTC Register Map | | | 16.5 BURTC Register Description | | | 16.5.1 BURTC IPVERSION - IP version ID | | | 16.5.2 BURTC_EN - Module Enable Register | | | 16.5.3 BURTC_CFG - Configuration Register | | | 16.5.4 BURTC CMD - Command Register | | | 16.5.5 BURTC_STATUS - Status Register | | | 16.5.6 BURTC_IF - Interrupt Flag Register | | | 16.5.7 BURTC_IEN - Interrupt Enable Register | | | 16.5.8 BURTC_PRECNT - Pre-Counter Value Register | | | 16.5.9 BURTC CNT - Counter Value Register | | | 16.5.10 BURTC_EM4WUEN - EM4 wakeup request Enable Register | | | 16.5.11 BURTC_SYNCBUSY - Synchronization Busy Register | | | 16.5.12 BURTC_LOCK - Configuration Lock Register | | | 16.5.13 BURTC_COMP - Compare Value Register | | | 17. BURAM - Backup RAM | 448 | | 17.1 Introduction | 448 | | | . 449<br>. 449<br>. <b>450</b><br>. 450<br>. 451 | |---------------------------------------|--------------------------------------------------| | | . 449<br>. <b>450</b><br>. 450<br>. 450 | | | . <b>450</b><br>. 450<br>. 450 | | · · · · · · · · · · · · · · · · · · · | . 450<br>. 450<br>451 | | | . 450<br>451 | | <br> | 451 | | | | | | | | | | | | . 453 | | | | | | | | | | | | | | | | | | . 458 | | | . 459 | | | . 459 | | | . 459 | | | . 459 | | | . 459 | | | 460 | | | 461 | | | | | | | | | | | | | | | | | | | | | | | | | | | . 469 | | | . 471 | | | | | | | | | | | | | | | | | | | | | | | | 476 | | | | | 18.14.14 LETIMER_IEN - Interrupt Enable Register | . 477 | |--------------------------------------------------------------|-------------| | 18.14.15 LETIMER_SYNCBUSY - Synchronization Busy Register | . 478 | | 18.14.16 LETIMER_PRSMODE - PRS Input mode select Register | . 479 | | 19. TIMER - Timer/Counter | <i>4</i> 81 | | 19.1 Introduction | . 481 | | 19.2 Features | | | 19.3 Functional Description | | | 19.3.1 Register Access. | | | 19.3.2 Counter Modes | | | 19.3.3 Compare/Capture Channels | | | 19.3.4 Dead-Time Insertion Unit | | | 19.3.5 Debug Mode | | | 19.3.6 Interrupts, DMA and PRS Output | | | 19.3.7 GPIO Input/Output | | | | | | 19.4 TIMER Register Map | | | 19.5 TIMER Register Description | | | 19.5.1 TIMER_IPVERSION - IP version ID | | | 19.5.2 TIMER_CFG - Configuration Register | | | 19.5.3 TIMER_CTRL - Control Register | | | 19.5.4 TIMER_CMD - Command Register | | | 19.5.5 TIMER_STATUS - Status Register | | | 19.5.6 TIMER_IF - Interrupt Flag Register | | | 19.5.7 TIMER_IEN - Interrupt Enable Register | | | 19.5.8 TIMER_TOP - Counter Top Value Register | | | 19.5.9 TIMER_TOPB - Counter Top Value Buffer Register | | | 19.5.10 TIMER_CNT - Counter Value Register | | | 19.5.11 TIMER_LOCK - TIMER Configuration Lock Register | | | | | | 19.5.13 TIMER_CCx_CFG - CC Channel Configuration Register | | | 19.5.14 TIMER_CCx_CTRL - CC Channel Control Register | | | 19.5.16 TIMER_CCx_OCB - OC Channel Value Buffer Register | | | 19.5.17 TIMER CCx ICF - IC Channel Value Register | | | 19.5.18 TIMER_CCx_ICOF - IC Channel Value Overflow Register | | | 19.5.19 TIMER_DTCFG - DTI Configuration Register | | | 19.5.20 TIMER_DTTIMECFG - DTI Time Configuration Register | | | 19.5.21 TIMER DTFCFG - DTI Fault Configuration Register | | | 19.5.22 TIMER_DTCTRL - DTI Control Register | | | 19.5.23 TIMER_DTOGEN - DTI Output Generation Enable Register | | | 19.5.24 TIMER_DTFAULT - DTI Fault Register | | | 19.5.25 TIMER_DTFAULTC - DTI Fault Clear Register | | | 19.5.26 TIMER_DTLOCK - DTI Configuration Lock Register | | | _ · · · · · · · · · · · · · · · · · · · | | | 20. PDM - PDM Interface | | | 20.1 Introduction | . 537 | | 20.2 Features | 538 | | 20.3 Functional Description | . 538 | |---------------------------------------------------------------------|-------| | 20.3.1 Overview | . 539 | | 20.3.2 PDM Clock Generation | .539 | | 20.3.3 Filter Order | .539 | | 20.3.4 Down Sample Rate | | | 20.3.5 Multi Channel Operation | . 540 | | 20.3.6 Output Options | | | 20.3.7 FIFO | | | 20.3.8 DMA Support | | | 20.3.9 PRS Support | | | 20.3.10 PDM Energy Modes | | | 20.3.11 Debug Mode | | | 20.3.12 Pin Configurations | | | 20.3.13 Programmer's Model | | | 20.4 Applications | . 544 | | 20.4.1 PDM Microphones | . 544 | | 20.4.2 Isolated Sigma Delta Modulators | . 545 | | 20.5 PDM Register Map | .546 | | 20.6 PDM Register Description | . 547 | | 20.6.1 PDM_IPVERSION - IP Version ID | | | 20.6.2 PDM_EN - PDM Module enable Register | .548 | | 20.6.3 PDM_CTRL - PDM Core Control Register | . 548 | | 20.6.4 PDM_CMD - PDM Core Command Register | . 549 | | 20.6.5 PDM_STATUS - PDM Status register | 550 | | 20.6.6 PDM_CFG0 - PDM Core Configuration Register0 | .551 | | 20.6.7 PDM_CFG1 - PDM Core Configuration Register1 | .553 | | 20.6.8 PDM_RXDATA - PDM Received Data Register | | | 20.6.9 PDM_IF - Interrupt Flag Register | | | 20.6.10 PDM_IEN - Interrupt Flag Register | | | 20.6.11 PDM_SYNCBUSY - Synchronization Busy Register | . 555 | | 21. USART - Universal Synchronous Asynchronous Receiver/Transmitter | .556 | | 21.1 Introduction | . 556 | | 21.2 Features | . 557 | | 21.3 Functional Description | . 558 | | 21.3.1 Modes of Operation | . 559 | | 21.3.2 Asynchronous Operation | | | 21.3.3 Synchronous Operation | | | 21.3.4 Hardware Flow Control | | | 21.3.5 Debug Halt | | | 21.3.6 PRS-triggered Transmissions | | | 21.3.7 PRS RX Input | | | 21.3.8 PRS CLK Input | | | 21.3.9 DMA Support | | | 21.3.10 Timer | | | 21.3.11 Interrupts | | | 21.3.12 IrDA Modulator/ Demodulator | . 589 | | 21.4 USART Register Map | .590 | |-------------------------------------------------------------------|-------| | 21.5 USART Register Description | . 593 | | 21.5.1 USART_IPVERSION - IPVERSION | | | 21.5.2 USART_EN - USART Enable | | | 21.5.3 USART_CTRL - Control Register | | | 21.5.4 USART_FRAME - USART Frame Format Register | | | 21.5.5 USART_TRIGCTRL - USART Trigger Control register | | | | | | 21.5.6 USART_CMD - Command Register | | | 21.5.7 USART_STATUS - USART Status Register | | | 21.5.8 USART_CLKDIV - Clock Control Register | | | 21.5.9 USART_RXDATAX - RX Buffer Data Extended Register | | | 21.5.10 USART_RXDATA - RX Buffer Data Register | | | 21.5.11 USART_RXDOUBLEX - RX Buffer Double Data Extended Register | | | 21.5.12 USART_RXDOUBLE - RX FIFO Double Data Register | | | 21.5.13 USART_RXDATAXP - RX Buffer Data Extended Peek Register | . 607 | | 21.5.14 USART_RXDOUBLEXP - RX Buffer Double Data Extended Peek R | . 608 | | 21.5.15 USART_TXDATAX - TX Buffer Data Extended Register | . 609 | | 21.5.16 USART_TXDATA - TX Buffer Data Register | . 610 | | 21.5.17 USART TXDOUBLEX - TX Buffer Double Data Extended Register | | | 21.5.18 USART_TXDOUBLE - TX Buffer Double Data Register | | | 21.5.19 USART_IF - Interrupt Flag Register | | | 21.5.20 USART_IEN - Interrupt Enable Register | | | 21.5.21 USART_IRCTRL - IrDA Control Register | | | 21.5.22 USART_I2SCTRL - I2S Control Register | | | 21.5.23 USART_TIMING - Timing Register | | | | | | 21.5.24 USART_CTRLX - Control Register Extended | | | 21.5.25 USART_TIMECMP0 - Used to generate interrupts and vario | | | 21.5.26 USART_TIMECMP1 - Used to generate interrupts and vario | | | 21.5.27 USART_TIMECMP2 - Used to generate interrupts and vario | . 627 | | 22. EUART - Enhanced Universal Asynchronous Receiver/Transmitter | . 629 | | 22.1 Introduction | . 629 | | 22.2 Features | 630 | | | | | 22.3 Functional Description | | | 22.3.1 Modes of Operation | | | 22.3.2 Frame Format | | | 22.3.3 Parity bit Calculation and Handling | 633 | | 22.3.4 Clock Generation | .634 | | 22.3.5 Auto Baud Detection | . 635 | | 22.3.6 Data Transmission | . 636 | | 22.3.7 Transmit FIFO Operation | . 637 | | 22.3.8 Frame Transmission Control | 638 | | 22.3.9 Transmission Delay | | | 22.3.10 Data Reception | | | 22.3.11 Receive FIFO Operation | | | 22.3.12 Blocking Incoming Data | | | 22.3.13 Data Sampling and Filtering | | | 22.3.14 Parity Error | . 642 | | // 3 14 Falliv Fillol | . 042 | | 22.3.15 Framing Error and Break Detection | . 642 | |---------------------------------------------------------|-------| | 22.3.16 Programmable Start Frame | 643 | | 22.3.17 Programmable Signal Frame | . 643 | | 22.3.18 Local Loopback | 643 | | 22.3.19 Half Duplex Communication | .643 | | 22.3.20 Single Data-link | 644 | | 22.3.21 Single Data-link with External Driver | | | 22.3.22 Two Data-links | | | 22.3.23 Multi-Processor Mode | | | 22.3.24 Collision Detection | | | 22.3.25 Hardware Flow Control | | | 22.3.26 Debug Halt | | | 22.3.27 PRS-triggered Transmissions | | | 22.3.28 PRS RX Input | | | 22.3.29 DMA Support | | | 22.3.30 Interrupts | | | 22.3.31 EM2 Operation (LF Mode Only) | | | 22.3.32 IrDA Modulator/ Demodulator | | | 22.4 EUSART Register Map | . 649 | | 22.5 EUSART Register Description | .651 | | 22.5.1 EUSART_IPVERSION - IP version ID | | | 22.5.2 EUSART_EN - Enable Register | | | 22.5.3 EUSART_CFG0 - Configuration 0 Register | | | 22.5.4 EUSART_CFG1 - Configuration 1 Register | | | 22.5.5 EUSART_FRAMECFG - Frame Format Register | | | 22.5.6 EUSART_IRHFCFG - HF IrDA Mod Config Register | | | 22.5.7 EUSART_IRLFCFG - LF IrDA Pulse Config Register | | | 22.5.8 EUSART_TIMINGCFG - Timing Register | | | 22.5.9 EUSART_STARTFRAMECFG - Start Frame Register | | | 22.5.10 EUSART_SIGFRAMECFG - Signal Frame Register | | | 22.5.11 EUSART TRIGCTRL - Trigger Control Register | | | 22.5.13 EUSART_CMD - Command Register | | | 22.5.14 EUSART_RXDATA - RX Data Register | | | 22.5.15 EUSART_RXDATAP - RX Data Peek Register | | | 22.5.16 EUSART_TXDATA - TX Data Register | | | 22.5.17 EUSART STATUS - Status Register | | | 22.5.18 EUSART_IF - Interrupt Flag Register | | | 22.5.19 EUSART_IEN - Interrupt Enable Register | . 671 | | 22.5.20 EUSART_SYNCBUSY - Synchronization Busy Register | . 673 | | 23. I2C - Inter-Integrated Circuit Interface | . 675 | | 23.1 Introduction | | | 23.2 Features | | | 23.3 Functional Description | | | 23.3.1 I2C-Bus Overview | | | 23.3.2 Enable and Reset | . 681 | | 23.3.3 Pin Configuration | .681 | |------------------------------------------------------------------|-------| | 23.3.4 Safely Disabling and Changing Slave Configuration | 681 | | 23.3.5 Clock Generation | .682 | | 23.3.6 Arbitration | 682 | | 23.3.7 Buffers | . 682 | | 23.3.8 Master Operation | .685 | | 23.3.9 Bus States | 693 | | 23.3.10 Slave Operation | | | 23.3.11 Transfer Automation | . 697 | | 23.3.12 Using 10-bit Addresses | . 698 | | 23.3.13 Error Handling | | | 23.3.14 DMA Support | | | 23.3.15 Interrupts | 700 | | 23.3.16 Wake-up | 700 | | 23.4 I2C Register Map | 701 | | 23.5 I2C Register Description | .703 | | 23.5.1 I2C_IPVERSION - IP VERSION Register | | | 23.5.2 I2C_EN - Enable Register | | | 23.5.3 I2C_CTRL - Control Register | .704 | | 23.5.4 I2C_CMD - Command Register | 708 | | 23.5.5 I2C_STATE - State Register | 709 | | 23.5.6 I2C_STATUS - Status Register | 710 | | 23.5.7 I2C_CLKDIV - Clock Division Register | .711 | | 23.5.8 I2C_SADDR - Slave Address Register | .711 | | 23.5.9 I2C_SADDRMASK - Slave Address Mask Register | . 712 | | 23.5.10 I2C_RXDATA - Receive Buffer Data Register | .712 | | 23.5.11 I2C_RXDOUBLE - Receive Buffer Double Data Register | 713 | | 23.5.12 I2C_RXDATAP - Receive Buffer Data Peek Register | . 713 | | 23.5.13 I2C_RXDOUBLEP - Receive Buffer Double Data Peek Register | | | 23.5.14 I2C_TXDATA - Transmit Buffer Data Register | .714 | | 23.5.15 I2C_TXDOUBLE - Transmit Buffer Double Data Register | .715 | | 23.5.16 I2C_IF - Interrupt Flag Register | . 716 | | 23.5.17 I2C_IEN - Interrupt Enable Register | 718 | | 24. IADC - Incremental Analog to Digital Converter | .720 | | 24.1 Introduction. | 720 | | 24.2 Features | 7.21 | | 24.3 Functional Description | . 722 | | 24.3.1 Register Access | 723 | | 24.3.2 Clocking | .724 | | 24.3.3 Conversion Timing | . 725 | | 24.3.4 Reference Selection and Analog Gain | .732 | | 24.3.5 Input and Configuration Selection | . 732 | | 24.3.6 Gain and Offset Correction | | | 24.3.7 Output Data FIFOs | | | 24.3.8 Window Compare | | | 24.3.9 Interrupts | . 745 | | 24.4 IADC Register Map | . 746 | |-----------------------------------------------------------|-------| | 24.5 IADC Register Description. | 749 | | 24.5.1 IADC_IPVERSION - IPVERSION | | | 24.5.2 IADC_EN - Enable | | | 24.5.3 IADC_CTRL - Control | | | 24.5.4 IADC CMD - Command | | | 24.5.5 IADC_TIMER - Timer | | | 24.5.6 IADC_STATUS - Status | | | 24.5.7 IADC_MASKREQ - Mask Request | | | 24.5.8 IADC_STMASK - Scan Table Mask | | | 24.5.9 IADC_CMPTHR - Digital Window Comparator Threshold | | | 24.5.9 IADC_CMF TTR - Digital Window Comparator Threshold | | | 24.5.10 IADC_IF - Interrupt Flags | | | <del>-</del> | | | 24.5.12 IADC_TRIGGER - Trigger | | | 24.5.13 IADC_CFGx - Configuration | | | 24.5.14 IADC_SCALEx - Scaling | | | 24.5.15 IADC_SCHEDx - Scheduling | | | 24.5.16 IADC_SINGLEFIFOCFG - Single FIFO Configuration | | | 24.5.17 IADC_SINGLEFIFODATA - Single FIFO Read Data | | | 24.5.18 IADC_SINGLEFIFOSTAT - Single FIFO Status | | | 24.5.19 IADC_SINGLEDATA - Single Data | | | 24.5.20 IADC_SCANFIFOCFG - Scan FIFO Configuration | | | 24.5.21 IADC_SCANFIFODATA - Scan FIFO Read Data | | | 24.5.22 IADC_SCANFIFOSTAT - Scan FIFO Status | | | 24.5.23 IADC_SCANDATA - Scan Data | | | 24.5.24 IADC_SINGLE - Single Queue Port Selection | | | 24.5.25 IADC_SCANx - SCAN Entry | . 775 | | 25. GPIO - General Purpose Input/Output | 777 | | 25.1 Introduction | | | | | | 25.2 Features | | | 25.3 Functional Description | | | 25.3.1 Pin Configuration | | | 25.3.2 Alternate Port Control | | | 25.3.3 Slew Rate | | | 25.3.4 Input Disable | | | 25.3.5 Configuration Lock | | | 25.3.6 EM2 Functionality | | | 25.3.7 EM4 Functionality | | | 25.3.8 EM4 Wakeup | | | 25.3.9 Debug Connections | 783 | | 25.3.10 Interrupt Generation | . 784 | | 25.3.11 Output to PRS | . 785 | | 25.3.12 Peripheral Resource Routing | . 785 | | 25.4 Synchronization | .790 | | 25.5 GPIO Register Map | . 791 | | 25.6 GPIO Register Description | 811 | | 25.6.1 | GPIO_PORTA_CTRL - Port control | . 811 | |---------|--------------------------------------------------------|--------------| | 25.6.2 | GPIO_PORTA_MODEL - mode low | . 812 | | 25.6.3 | GPIO_PORTA_MODEH - mode high | 817 | | 25.6.4 | GPIO_PORTA_DOUT - data out | . 818 | | 25.6.5 | GPIO PORTA DIN - data in | 818 | | 25.6.6 | GPIO_PORTB_CTRL - Port control | . 819 | | | | . 820 | | | | . 823 | | | GPIO_PORTB_DIN - data in | 823 | | | GPIO_PORTC_CTRL - Port control | 824 | | | GPIO_PORTC_MODEL - mode low | 825 | | | GPIO_PORTC_DOUT - data out | 830 | | | GPIO_PORTC_DIN - data in | 830 | | | GPIO_PORTD_CTRL - Port control | 831 | | | GPIO_PORTD_MODEL - mode low | 832 | | | GPIO_PORTD_DOUT - data out | 834 | | | | . 835 | | | | . 835<br>835 | | | GPIO_LOCK - Lock Register | 836 | | | GPIO_GPIOLOCKSTATUS - Lock Status | | | | GPIO_ABUSALLOC - A Bus allocation | 837 | | | GPIO_BBUSALLOC - B Bus allocation | 839 | | | GPIO_CDBUSALLOC - CD Bus allocation | .841 | | | = ' | . 843 | | | GPIO_EXTIPSELH - External interrupt Port Select High | 846 | | | GPIO_EXTIPINSELL - External Interrupt Pin Select Low | 848 | | | GPIO_EXTIPINSELH - External Interrupt Pin Select High | .851 | | | GPIO_EXTIRISE - External Interrupt Rising Edge Trigger | .852 | | | | . 853 | | | GPIO_IF - Interrupt Flag | 854 | | | <del>-</del> | 856 | | 25.6.31 | GPIO_EM4WUEN - EM4 wakeup enable | 858 | | 25.6.32 | GPIO_EM4WUPOL - EM4 wakeup polarity | . 858 | | 25.6.33 | GPIO_DBGROUTEPEN - Debugger Route Pin enable | .859 | | 25.6.34 | GPIO_TRACEROUTEPEN - Trace Route Pin Enable | 860 | | 25.6.35 | GPIO_CMU_ROUTEEN - CMU pin enable | .861 | | 25.6.36 | GPIO_CMU_CLKIN0ROUTE - CLKIN0 port/pin select | .861 | | 25.6.37 | GPIO_CMU_CLKOUT0ROUTE - CLKOUT0 port/pin select | 862 | | 25.6.38 | GPIO_CMU_CLKOUT1ROUTE - CLKOUT1 port/pin select | 862 | | 25.6.39 | GPIO_CMU_CLKOUT2ROUTE - CLKOUT2 port/pin select | 863 | | 25.6.40 | GPIO_DCDC_ROUTEEN - DCDC pin enable | .863 | | 25.6.41 | GPIO_FRC_ROUTEEN - FRC pin enable | 864 | | | GPIO_FRC_DCLKROUTE - DCLK port/pin select | | | | GPIO_FRC_DFRAMEROUTE - DFRAME port/pin select | | | | GPIO_FRC_DOUTROUTE - DOUT port/pin select | | | | GPIO_I2C0_ROUTEEN - I2C0 pin enable | | | | GPIO_I2C0_SCLROUTE - SCL port/pin select | | | | GPIO I2CO SDAROUTE - SDA port/pin select | | | | GPIO I2C1 ROUTEEN - I2C1 pin enable | 867 | | | | | | 25.6.49 | GPIO_I2C1_SCLROUTE - SCL port/pin select | 868 | |---------|-----------------------------------------------------------|-------| | 25.6.50 | GPIO_I2C1_SDAROUTE - SDA port/pin select | 868 | | 25.6.51 | GPIO_LETIMER0_ROUTEEN - LETIMER pin enable | 869 | | | GPIO_LETIMER0_OUT0ROUTE - OUT0 port/pin select | 869 | | | GPIO LETIMERO OUT1ROUTE - OUT1 port/pin select | 870 | | | | . 870 | | | GPIO_EUART0_CTSROUTE - CTS port/pin select | 871 | | | GPIO EUARTO RTSROUTE - RTS port/pin select | 871 | | | GPIO EUARTO RXROUTE - RX port/pin select | .872 | | | GPIO EUARTO TXROUTE - TX port/pin select | 872 | | | GPIO_MODEM_ROUTEEN - MODEM pin enable | 873 | | | GPIO_MODEM_ROOTEEN - MODEM pirt eriable : | 874 | | | | 875 | | | GPIO_MODEM_ANTROUTE - ANT1 port/pin select | | | | | . 875 | | | GPIO_MODEM_ANTRR0ROUTE - ANTRR0 port/pin select | 876 | | | GPIO_MODEM_ANTRR1ROUTE - ANTRR1 port/pin select | 876 | | | GPIO_MODEM_ANTRR2ROUTE - ANTRR2 port/pin select | 877 | | | GPIO_MODEM_ANTRR3ROUTE - ANTRR3 port/pin select | 877 | | 25.6.67 | GPIO_MODEM_ANTRR4ROUTE - ANTRR4 port/pin select | 878 | | 25.6.68 | GPIO_MODEM_ANTRR5ROUTE - ANTRR5 port/pin select | 878 | | 25.6.69 | GPIO_MODEM_ANTSWENROUTE - ANTSWEN port/pin select | 879 | | 25.6.70 | GPIO_MODEM_ANTSWUSROUTE - ANTSWUS port/pin select | 879 | | 25.6.71 | GPIO_MODEM_ANTTRIGROUTE - ANTTRIG port/pin select | 880 | | 25.6.72 | GPIO_MODEM_ANTTRIGSTOPROUTE - ANTTRIGSTOP port/pin select | 880 | | 25.6.73 | GPIO_MODEM_DCLKROUTE - DCLK port/pin select | 881 | | 25.6.74 | GPIO_MODEM_DINROUTE - DIN port/pin select | 881 | | 25.6.75 | GPIO_MODEM_DOUTROUTE - DOUT port/pin select | .882 | | | GPIO_PDM_ROUTEEN - PDM pin enable | .882 | | 25.6.77 | GPIO_PDM_CLKROUTE - CLK port/pin select | 883 | | | | 883 | | | | 884 | | | GPIO PRS0 ROUTEEN - PRS0 pin enable | 885 | | | : | .886 | | | | .887 | | | | .887 | | | | .888 | | | | .888 | | | | .889 | | | | .889 | | | | .890 | | | | .890 | | | | | | | | .891 | | | GPIO_PRS0_ASYNCH10ROUTE - ASYNCH10 port/pin select | .891 | | | GPIO_PRS0_ASYNCH11ROUTE - ASYNCH11 port/pin select | .892 | | | ' ' | .892 | | | ' ' | .893 | | | ' ' | .893 | | 25 6 96 | GPIO_PRS0_SYNCH3ROUTE - SYNCH3 port/pin select | 894 | | 25.6.97 | GPIO_TIMER0_ROUTEEN - TIMER0 pin enable | | | | | | | | | • | | | . 895 | |-----------|--------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|------------| | 25.6.98 ( | GPIO_TIMER0_CC0ROUTE - CC0 port/pin select | | | | | | | | | | | | 896 | | 25.6.99 ( | GPIO_TIMER0_CC1ROUTE - CC1 port/pin select | | | | | | | | | | | | 896 | | 25.6.100 | GPIO_TIMER0_CC2ROUTE - CC2 port/pin select . | | | | | | | | | | | | .897 | | 25.6.101 | GPIO_TIMER0_CCC0ROUTE - CCC0 port/pin select | | | | | | | | | | | | . 897 | | 25.6.102 | GPIO_TIMER0_CCC1ROUTE - CCC1 port/pin select | | | | | | | | | | | | . 898 | | | GPIO_TIMER0_CCC2ROUTE - CCC2 port/pin select | | | | | | | | | | | | . 898 | | | GPIO TIMER1 ROUTEEN - TIMER1 pin enable | | | | | | | | | | | | 899 | | | GPIO_TIMER1_CC0ROUTE - CC0 port/pin select . | | _ | _ | _ | | | | _ | | _ | _ | .900 | | | GPIO_TIMER1_CC1ROUTE - CC1 port/pin select . | • | - | - | - | - | | • | - | - | - | - | .900 | | | GPIO_TIMER1_CC2ROUTE - CC2 port/pin select . | • | • | • | • | | | • | · | • | • | • | .901 | | | GPIO_TIMER1_CCC0ROUTE - CCC0 port/pin select | • | • | • | • | • | | • | • | • | • | | . 901 | | | GPIO_TIMER1_CCC1ROUTE - CCC1 port/pin select | • | • | • | • | | • | • | • | • | • | | . 902 | | | GPIO_TIMER1_CCC2ROUTE - CCC2 port/pin select | • | • | • | • | | • | • | • | • | • | | . 902 | | | | • | • | • | • | | • | • | • | • | • | • | 903 | | | GPIO_TIMER2_ROUTEEN - TIMER2 pin enable | | • | • | ٠ | • | • | | • | • | • | • | | | | GPIO_TIMER2_CC0ROUTE - CC0 port/pin select . | • | • | • | • | • | | • | • | • | • | • | .904 | | | GPIO_TIMER2_CC1ROUTE - CC1 port/pin select . | • | - | - | • | | | • | • | • | • | • | .904 | | | GPIO_TIMER2_CC2ROUTE - CC2 port/pin select . | ٠ | • | • | • | | | • | • | ٠ | • | • | .905 | | | GPIO_TIMER2_CCC0ROUTE - CCC0 port/pin select | • | | • | | | • | • | | | | | . 905 | | | GPIO_TIMER2_CCC1ROUTE - CCC1 port/pin select | | • | • | | | | • | | | • | | . 906 | | | GPIO_TIMER2_CCC2ROUTE - CCC2 port/pin select | | | • | | | | • | | | | | . 906 | | 25.6.118 | GPIO_TIMER3_ROUTEEN - TIMER3 pin enable | | | | | | | | | | | | 907 | | 25.6.119 | GPIO_TIMER3_CC0ROUTE - CC0 port/pin select . | | | | | | | | | | | | .908 | | 25.6.120 | GPIO_TIMER3_CC1ROUTE - CC1 port/pin select . | | | | | | | | | | | | .908 | | 25.6.121 | GPIO_TIMER3_CC2ROUTE - CC2 port/pin select . | | | | | | | | | | | | .909 | | 25.6.122 | GPIO_TIMER3_CCC0ROUTE - CCC0 port/pin select | | | | | | | | | | | | . 909 | | 25.6.123 | GPIO_TIMER3_CCC1ROUTE - CCC1 port/pin select | | | | | | | | | | | | . 910 | | 25.6.124 | GPIO_TIMER3_CCC2ROUTE - CCC2 port/pin select | | | | | | | | | | | | . 910 | | 25.6.125 | GPIO_TIMER4_ROUTEEN - TIMER4 pin enable | | | | | | | | | | | | 911 | | 25.6.126 | GPIO_TIMER4_CC0ROUTE - CC0 port/pin select . | | | | | | | | | | | | .912 | | 25.6.127 | GPIO_TIMER4_CC1ROUTE - CC1 port/pin select . | | | | | | | | | | | | .912 | | 25.6.128 | GPIO_TIMER4_CC2ROUTE - CC2 port/pin select | | | | | | | | | | | | .913 | | 25.6.129 | GPIO TIMER4 CCC0ROUTE - CCC0 port/pin select | | | | | | | | | | | | . 913 | | 25.6.130 | GPIO TIMER4 CCC1ROUTE - CCC1 port/pin select | | | | | | | | | | | | . 914 | | 25.6.131 | GPIO TIMER4 CCC2ROUTE - CCC2 port/pin select | | | | | | | | | | | | . 914 | | | GPIO_USART0_ROUTEEN - USART0 pin enable . | | | | | | | | | | | | .915 | | | GPIO_USART0_CSROUTE - CS port/pin select | | | | | | | | | | | | 916 | | | GPIO USARTO CTSROUTE - CTS port/pin select . | | | | | | | | | | | | 916 | | | GPIO_USART0_RTSROUTE - RTS port/pin select . | - | | | | | | | | | | | 917 | | | GPIO_USART0_RXROUTE - RX port/pin select | • | | | | | | | | | | | 917 | | | GPIO_USART0_CLKROUTE - SCLK port/pin select | • | • | • | | | | | | | | | 918 | | | GPIO USARTO TXROUTE - TX port/pin select | • | • | • | | | | | | | | | . 918 | | | GPIO USART1 ROUTEEN - USART1 pin enable | • | | | | | | | | | | | .919 | | | GPIO USART1 CSROUTE - CS port/pin select | | | | | | | | | | | | 920 | | | GPIO_USART1_CTSROUTE - CTS port/pin select | • | | | | | | | | | | | 920 | | | GPIO_USART1_CTSROUTE - CTS port/pin select . | • | | | | | | | | | | | | | | | | | | | | | | | | | | 921 | | | GPIO_USART1_RXROUTE - RX port/pin select GPIO_USART1_CLKROUTE - SCLK port/pin select | • | • | • | | • | • | • | • | • | | • | 921<br>922 | | 75 D 144 | GEIG GOARTT GENRUUTE - SCEN DON/DID SPIRCE | | | | | | | | | | | | 4// | | 25.6.145 GPIO_USART1_TXROUTE - TX port/pin select | . 922 | |----------------------------------------------------------------|-------| | 26. LDMA - Linked DMA | 923 | | 26.1 Introduction | | | 26.1.1 Features | | | 26.2 Block Diagram | | | 26.3 Functional Description | | | 26.3.1 Channel Descriptor | | | 26.3.2 Channel Configuration | | | 26.3.3 Channel Select Configuration | | | 26.3.5 Managing Transfer Errors | | | 26.3.6 Arbitration | | | 26.3.7 Channel descriptor data structure | | | 26.3.8 Interaction with the EMU | | | 26.3.9 Interrupts | . 938 | | 26.3.10 Debugging | . 938 | | 26.4 Examples | .938 | | 26.4.1 Single Direct Register DMA Transfer | . 938 | | 26.4.2 Descriptor Linked List | . 939 | | 26.4.3 Single Descriptor Looped Transfer | | | 26.4.4 Descriptor List with Looping | | | 26.4.5 Simple Inter-Channel Synchronization | | | 26.4.6 2D Copy | | | 26.4.7 Ping-Pong 26.4.8 Scatter-Gather | | | | | | 26.5 LDMA Source Selection Details | | | | | | 26.6 LDMA Register Map | | | 26.7 LDMA Register Description | | | 26.7.1 LDMA_IPVERSION - DMA Channel Request Clear Register | | | 26.7.2 LDMA_EN - DMA module enable disable Register | | | 26.7.4 LDMA_STATUS - DMA Status Register | | | 26.7.5 LDMA_SYNCSWSET - DMA Sync Trig Sw Set Register | | | 26.7.6 LDMA_SYNCSWCLR - DMA Sync Trig Sw Clear register | | | 26.7.7 LDMA_SYNCHWEN - DMA Sync HW trigger enable register | | | 26.7.8 LDMA_SYNCHWSEL - DMA Sync HW trigger selection register | 959 | | 26.7.9 LDMA_SYNCSTATUS - DMA Sync Trigger Status Register | . 960 | | 26.7.10 LDMA_CHEN - DMA Channel Enable Register | | | 26.7.11 LDMA_CHDIS - DMA Channel Disable Register | | | 26.7.12 LDMA_CHSTATUS - DMA Channel Status Register | | | 26.7.13 LDMA_CHBUSY - DMA Channel Busy Register | | | 26.7.14 LDMA_CHDONE - DMA Channel Linking Done Register | | | 26.7.15 LDMA_DBGHALT - DMA Channel Debug Halt Register | | | 26.7.17 LDMA_REQDIS - DMA Channel Request Disable Register | | | _ · · · · · · · · · · · · · · · · · · · | | | 26.7.18 LDMA_REQPEND - DMA Channel Requests Pending Register | | |--------------------------------------------------------------------|------| | 26.7.19 LDMA_LINKLOAD - DMA Channel Link Load Register | | | 26.7.20 LDMA_REQCLEAR - DMA Channel Request Clear Register | | | 26.7.21 LDMA_IF - Interrupt Flag Register | | | 26.7.23 LDMA_CHx_CFG - Channel Configuration Register | | | 26.7.24 LDMA_CHx_LOOP - Channel Loop Counter Register | | | 26.7.25 LDMA_CHx_CTRL - Channel Descriptor Control Word Register | | | 26.7.26 LDMA CHx SRC - Channel Descriptor Source Address | | | 26.7.27 LDMA_CHx_DST - Channel Descriptor Destination Address | | | 26.7.28 LDMA_CHx_LINK - Channel Descriptor Link Address | 975 | | 26.8 LDMAXBAR Register Map | 975 | | 26.9 LDMAXBAR Register Description | .976 | | 26.9.1 LDMAXBAR_CHx_REQSEL - Channel Peripheral Request Select Reg | | | 27. WDOG - Watch Dog Timer | | | 27.1 Introduction | | | | | | 27.2 Features | | | 27.3 Functional Description | | | 27.3.1 Clock Source | | | 27.3.2 Debug Functionality | | | 27.3.3 Energy Mode Handling | | | 27.3.5 Window Interrupt | | | 27.3.6 PRS as Watchdog Clear | | | 27.3.7 PRS Rising Edge Monitoring | | | 27.4 WDOG Register Map | | | 27.5 WDOG Register Description | | | 27.5.1 WDOG_IPVERSION - IP Version Register | | | 27.5.2 WDOG_EN - Enable Register | | | 27.5.3 WDOG_CFG - Configuration Register | | | 27.5.4 WDOG_CMD - Command Register | .986 | | 27.5.5 WDOG_STATUS - Status Register | | | 27.5.6 WDOG_IF - Interrupt Flag Register | | | 27.5.7 WDOG_IEN - Interrupt Enable Register | | | 27.5.8 WDOG_LOCK - Lock Register | | | 27.5.9 WDOG_SYNCBUSY - Synchronization Busy Register | 989 | | 28. Revision History | 990 | | Appendix 1. Abbreviations | .991 | # 1. About This Document # 1.1 Introduction This document contains reference material for the EFR32xG22 devices. All modules and peripherals in the EFR32xG22 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 37), 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 25. **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 | | (R)W1 | Sometimes readable. Only writes to 1 have effect. Currently only used for IF_CLEAR registers (see 3.3.1 Interrupt Operation) | | 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 register explicitly does not support peripheral bit set or clear (see 4. Memory and Bus System) | | RW(a), R(a), etc. | "(a)" suffix indicates that reading the register cause an action and ay 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 0 unless otherwise stated in the Register Description. Reserved bits might be read as 1 in future 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 EFR32xG22 devices and the ARM Cortex-M33 can be found at the Silicon Labs and ARM web pages: www.silabs.com 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 EFR32xG22 ideal for many wireless IoT applications. High performance analog and digital peripherals allow complete applications to run on the EFR32xG22 SoC. #### 2.1 Introduction The high level features of EFR32xG22 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 - · Ultra-low energy RF detection for wake-up from any energy mode, through RFSENSE - · 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 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 EFR32xG22 System-On-Chip series is shown in (Figure 2.1 EFR32xG22 System-On-Chip Block Diagram on page 28). Figure 2.1. EFR32xG22 System-On-Chip Block Diagram #### 2.3 MCU Features overview # ARM Cortex-M33 CPU platform - High Performance 32-bit processor @ up to 76.8 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 - · Selective RFSENSE wakeup source - · Up to 512 kB Flash - Up to 32 kB RAM ## Up to 26 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 # • 16 Channel Peripheral Reflex System (PRS) - · Autonomous inter-peripheral signaling enables smart operation in low energy modes - · 12 asynchronous channels with configurable logic functionality - · 4 synchronous channels for high-speed signalling between TIMER and IADC # Cryptographic Accelerator (CRYPTOACC) - · AES encryption / decryption, with 128 or 256 bit keys - Multiple AES modes of operation, including Counter (CTR), Electronic CodeBook (ECB), Cipher Block Chaining (CBC), Counter mode with CBC-MAC (CCM), and Cipher-based Message Authentication Code (CMAC). - Accelerated SHA-1 and SHA-2 (SHA-224 / SHA-256) - · Accelerated Elliptic Curve Cryptography (ECC), with binary or prime fields - · Flexible 256-bit ALU and sequencer - · True random number generation # 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 - 2 × 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 - · Enhanced Universal Asynchronous Receiver/Transmitter (EUART) - · UART and IrDA 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 - 1 × 32-bit and 4 × 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 (RTCC) - 32-bit Ultra Low Energy Backup Real Time Counter (BURTC) for periodic wake-up from any Energy Mode - 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 - · Analog Bus (ABUS) signal routing - · Accurate die temperature sensor - · External thermistor interface - 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 # 3. System Processor ### **Quick Facts** ## What? The EFR32xG22 features the industry leading Cortex-M33 CPU from ARM. # Why? 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. ## How? Combined with the ultra low energy peripherals available in EFR32xG22 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 EFR32xG22 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 registers. When setting or clearing and interrupt through the IF register use of the IF\_SET or IF\_CLEAR bit operation registers is recommended. 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 33 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 which 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 | Source(s) | |------|-------------------|------------------------| | 0* | CRYPTOACC | CRYPTOACC.CRYPTOMASTER | | 1* | TRNG | CRYPTOACC.TRNG | | 2* | PKE | CRYPTOACC.PKE | | 3* | SMU_SECURE | SMU.SECURE | | 4* | SMU_PRIVILEGED | SMU.PRIVILEGED | | 5* | SMU_NS_PRIVILEGED | | | 6* | EMU | EMU.MAIN | | 7* | TIMER0 | TIMER0.MAIN | | 8* | TIMER1 | TIMER1.MAIN | | 9* | TIMER2 | TIMER2.MAIN | | 10* | TIMER3 | TIMER3.MAIN | | 11* | TIMER4 | TIMER4.MAIN | | 12* | RTCC | RTCC.MAIN | | 13* | USART0_RX | USART0.RX | | 14* | USART0_TX | USART0.TX | | 15* | USART1_RX | USART1.RX | | 16* | USART1_TX | USART1.TX | | 17* | ICACHE0 | ICACHE0.MAIN | | 18* | BURTC | BURTC.MAIN | | 19* | LETIMER0 | LETIMERO.MAIN | | 20* | SYSCFG | SYSCFG.MAIN | | 21* | LDMA | LDMA.MAIN | | 22* | LFXO | LFXO.MAIN | | 23* | LFRCO | LFRCO.MAIN | | 24* | ULFRCO | ULFRCO.MAIN | | 25* | GPIO_ODD | GPIO.ODD | | 26* | GPIO_EVEN | GPIO.EVEN | | 27* | I2C0 | 12C0.irq | | 28* | I2C1 | I2C1.irq | | 29* | EMUDG | EMU.DG | | 30* | EMUSE | EMU.SE | | 31* | AGC | AGC.MAIN | | 32* | BUFC | BUFC.MAIN | | 33* | FRC_PRI | FRC.PRI | | IRQ# | Name | Source(s) | |------|-----------|---------------| | 34* | FRC | FRC.MAIN | | 35* | MODEM | MODEM.MAIN | | 36* | PROTIMER | PROTIMER.MAIN | | 37* | RAC_RSM | RAC.RSM | | 38* | RAC_SEQ | RAC.SEQ | | 39* | RDMAILBOX | | | 40* | RFSENSE | | | 41* | PRORTC | PRORTC.MAIN | | 42* | SYNTH | SYNTH.MAIN | | 43* | WDOG0 | WDOG0.MAIN | | 44* | HFXO0 | HFX00.MAIN | | 45* | HFRCO0 | HFRCO0.MAIN | | 46* | CMU | CMU.MAIN | | 47* | AES | RADIOAES.MAIN | | 48* | IADC | IADC0.MAIN | | 49* | MSC | MSC.irq_imem | | 50* | DPLL0 | DPLL0.MAIN | | 51* | PDM | | | 52* | SW0 | SYSCFG.SW0 | | 53* | SW1 | SYSCFG.SW1 | | 54* | SW2 | SYSCFG.SW2 | | 55* | SW3 | SYSCFG.SW3 | | 56* | KERNEL0 | | | 57* | KERNEL1 | | | 58* | M33CTI0 | CORE.CTI0 | | 59* | M33CTI1 | CORE.CTI1 | | 60* | EMUEFP | | | 61* | DCDC | | | 62* | EUART0_RX | | | 63* | EUART0_TX | | # 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 EFR32xG22 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 37. Figure 4.1. System Address Space with Core and Code Space Listing Flash for the main program memory (CODE) is located at address 0x00000000 in the memory map of the EFR32xG22. SRAM for the main data memory (RAM) is located at address 0x20000000 in the memory map of the EFR32xG22. 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 master bus interfaces to the AHB slaves. The bus matrix allows several AHB slaves 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 masters (Code and System) so that it may retrieve instructions and data in parallel. The Code master is used to access all memory below address 0x20000000 and the System master access addresses 0x20000000 and above. Figure 4.2. EFR32xG22 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 slave are eliminated. Round-robin does not assign a fixed priority to each bus master. The arbiter does not insert any bus wait-states during peak interaction. However, one wait state is inserted for master accesses occurring after a prolonged inactive time. This wait state allows for increased power efficiency during master 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 2bit 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 512 kB of memory - Page size of 8 KB (minimum erase unit) - · Minimum 10k erase cycles endurance - Greater than 10 years data retention at 85°C - · 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 32 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 | |-------------------------|-------------|--------------------------| | 0x40004000 - 0x40007FFF | EMU | EM2.A | | 0x40008000 - 0x4000BFFF | CMU | EM2.B | | 0x4000C000 - 0x4000FFFF | HFXO0 | EM1 | | 0x40010000 - 0x40013FFF | HFRCO0 | EM1 | | 0x40018000 - 0x4001BFFF | FSRCO | EM4 | | 0x4001C000 - 0x4001FFFF | DPLL0 | EM1 | | 0x40020000 - 0x40023FFF | LFXO | EM4 | | 0x40024000 - 0x40027FFF | LFRCO | EM2.C / EM4 <sup>1</sup> | | 0x40028000 - 0x4002BFFF | ULFRCO | EM4 | | 0x40030000 - 0x40033FFF | MSC | EM1 | | 0x40034000 - 0x40037FFF | ICACHE0 | EM1 | | 0x40038000 - 0x4003BFFF | PRS | EM2.B | | 0x4003C000 - 0x4003FFFF | GPIO | EM2.B | | 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 | | 0x40060000 - 0x40063FFF | USART1 | 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.B | | 0x40098000 - 0x4009BFFF | PDM | EM1 | | 0x4009C000 - 0x4009FFFF | RFSENSE | EM4 | | 0x44000000 - 0x440007FF | RADIOAES | EM1 | | 0x44008000 - 0x4400BFFF | SMU | EM1 | | Address Range | Module Name | Power Domain | |-------------------------|-------------|--------------------------| | 0x4400C000 - 0x4400FFFF | SMU | EM1 | | 0x48000000 - 0x48003FFF | RTCC | EM2.A | | 0x4A000000 - 0x4A003FFF | LETIMER0 | EM2.B | | 0x4A004000 - 0x4A007FFF | IADC0 | EM2.B | | 0x4A010000 - 0x4A013FFF | I2C0 | EM2.B | | 0x4A018000 - 0x4A01BFFF | WDOG0 | EM2.B | | 0x4A020000 - 0x4A023FFF | AMUXCP0 | EM2.B | | 0x4A030000 - 0x4A033FFF | EUART0 | EM2.B | | 0x4C020000 - 0x4C0207FF | CRYPTOACC | EM1 | | 0x4C021000 - 0x4C02107F | CRYPTOACC | EM1 | | 0x4C022000 - 0x4C02201F | CRYPTOACC | EM1 | | 0x50004000 - 0x50007FFF | EMU_NS | EM2.A | | 0x50008000 - 0x5000BFFF | CMU_NS | EM2.B | | 0x5000C000 - 0x5000FFFF | HFXO0_NS | EM1 | | 0x50010000 - 0x50013FFF | HFRCO0_NS | EM1 | | 0x50018000 - 0x5001BFFF | FSRCO_NS | EM4 | | 0x5001C000 - 0x5001FFFF | DPLL0_NS | EM1 | | 0x50020000 - 0x50023FFF | LFXO_NS | EM4 | | 0x50024000 - 0x50027FFF | LFRCO_NS | EM2.C / EM4 <sup>1</sup> | | 0x50028000 - 0x5002BFFF | ULFRCO_NS | EM4 | | 0x50030000 - 0x50033FFF | MSC_NS | EM1 | | 0x50034000 - 0x50037FFF | ICACHE0_NS | EM1 | | 0x50038000 - 0x5003BFFF | PRS_NS | EM2.B | | 0x5003C000 - 0x5003FFFF | GPIO_NS | EM2.B | | 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 | | 0x50058000 - 0x5005BFFF | TIMER4_NS | EM1 | | 0x5005C000 - 0x5005FFFF | USARTO_NS | EM1 | | 0x50060000 - 0x50063FFF | USART1_NS | EM1 | | 0x50064000 - 0x50067FFF | BURTC_NS | EM4 | | 0x50068000 - 0x5006BFFF | I2C1_NS | EM1 | | 0x50078000 - 0x5007BFFF | SYSCFG_NS | EM1 | | 0x5007C000 - 0x5007FFFF | SYSCFG_NS | EM1 | | Address Range | Module Name | Power Domain | |-------------------------|---------------|--------------| | 0x50080000 - 0x50083FFF | BURAM_NS | EM4 | | 0x50088000 - 0x5008BFFF | GPCRC_NS | EM1 | | 0x50094000 - 0x50097FFF | DCDC_NS | EM2.B | | 0x50098000 - 0x5009BFFF | PDM_NS | EM1 | | 0x5009C000 - 0x5009FFFF | RFSENSE_NS | EM4 | | 0x54000000 - 0x540007FF | RADIOAES_NS | EM1 | | 0x54008000 - 0x5400BFFF | SMU_NS | EM1 | | 0x5400C000 - 0x5400FFFF | SMU_NS | EM1 | | 0x58000000 - 0x58003FFF | RTCC_NS | EM2.A | | 0x5A000000 - 0x5A003FFF | LETIMERO_NS | EM2.B | | 0x5A004000 - 0x5A007FFF | IADC0_NS | EM2.B | | 0x5A010000 - 0x5A013FFF | I2C0_NS | EM2.B | | 0x5A018000 - 0x5A01BFFF | WDOG0_NS | EM2.B | | 0x5A020000 - 0x5A023FFF | AMUXCP0_NS | EM2.B | | 0x5A030000 - 0x5A033FFF | EUART0_NS | EM2.B | | 0x5C020000 - 0x5C0207FF | CRYPTOACC_NS | EM1 | | 0x5C021000 - 0x5C02107F | CRYPTOACC_NS | EM1 | | 0x5C022000 - 0x5C02201F | CRYPTOACC_NS | EM1 | | 0xA8004000 - 0xA8007FFF | FRC | EM1 | | 0xA800C000 - 0xA800FFFF | AGC | EM1 | | 0xA8010000 - 0xA8013FFF | RFCRC | EM1 | | 0xA8014000 - 0xA8017FFF | MODEM | EM1 | | 0xA8018000 - 0xA801BFFF | SYNTH | EM1 | | 0xA801C000 - 0xA801FFFF | PROTIMER | EM1 | | 0xA8020000 - 0xA8023FFF | RAC | EM1 | | 0xA8028000 - 0xA802BFFF | RDMAILBOX0 | EM1 | | 0xA802C000 - 0xA802FFFF | RDMAILBOX1 | EM1 | | 0xAA000000 - 0xAA003FFF | BUFC | EM1 | | 0xB8004000 - 0xB8007FFF | FRC_NS | EM1 | | 0xB800C000 - 0xB800FFFF | AGC_NS | EM1 | | 0xB8010000 - 0xB8013FFF | RFCRC_NS | EM1 | | 0xB8014000 - 0xB8017FFF | MODEM_NS | EM1 | | 0xB8018000 - 0xB801BFFF | SYNTH_NS | EM1 | | 0xB801C000 - 0xB801FFFF | PROTIMER_NS | EM1 | | 0xB8020000 - 0xB8023FFF | RAC_NS | EM1 | | 0xB8028000 - 0xB802BFFF | RDMAILBOX0_NS | EM1 | | 0xB802C000 - 0xB802FFFF | RDMAILBOX1_NS | EM1 | | Address Range | Module Name | Power Domain | | | | | |-------------------------|-------------|--------------|--|--|--|--| | 0xBA000000 - 0xBA003FFF | BUFC_NS | EM1 | | | | | #### Note: 1. 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 EFR32xG22 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 to 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 EFR32xG22 Wireless Gecko 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 46), 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 SYNTH, Modulator and PA. The Modulator requests data from the Frame Controller, 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 LNA, SYNTH, Mixer, ADC and Demodulator. 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, 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 EFR32xG22 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 EFR32xG22 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.13 RF Test Modes ### 5.1.4 Receive Mode In receive mode EFR32xG22 performs the following functionality: - A single-ended (2.4 GHz) LNA amplifies the input RF signal. The amplified signal is then mixed to a low-IF signal through the quadrature down-coversion 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 EFR32xG22 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 EFR32xG22 to provide a convenient user interface. In unbuffered data transfer modes the hardware support provided by EFR32xG22 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 EFR32xG22 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 EFR32xG22 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 EFR32xG22 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 EFR32xG22 includes hardware support for binary block encoding and decoding, both performed real-time in 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 EFR32xG22 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 EFR32xG22 hardware are listed in Table 5.1 AES modes of operation with hardware support on page 49. 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 | | ССМ | 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 RFSENSE** The RFSENSE block on the EFR32xG22 is an ultra-low energy RF signal detector which provides wake-on-RF capabilites from any energy mode. The system can remain in low energy modes such as EM2 or EM4 for long durations while continuously monitoring for a valid wake condition. RFSENSE can operate as a selective On Off Keying (OOK) detector, or a simple RF energy detector. - · Selective OOK pattern detection: - 1 kHz OOK symbol rate, manchester encoded (0.5 kHz bit rate) - Configurable 4/8-bit preamble length with fixed 1010 pattern - Configurable 8/16/24/32-bit sync word length with fully programmable pattern - · Simple RF energy threshold detection: - · Programmable RF energy trip point - · Configurable energy averaging duration ## 5.1.13 RF Test Modes EFR32xG22 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 ## 011001010110111001100101011110010 #### **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 though 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 EFR32xG22 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 disfolding 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 512 kB (64 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 0x00000000 and the information block is mapped to address 0x0FE00000. Table 6.1 MSC Flash Memory Mapping on page 51 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 Reada-<br>ble? | Purpose/Name | Size | |-------------|-----------------|--------------|-----------------|-------------------------|-------------------------|----------------| | Main | 0 | 0x0000000 | Software, debug | Yes | User code and data | 16 KB - 512 kB | | | 1 | 0x00002000 | Software, debug | Yes | | | | | | | Software, debug | Yes | | | | | 63 <sup>1</sup> | 0x0007E000 | Software, debug | Yes | | | | Information | N/A | 0x0FE00000 | Software | Yes | User Data (UD) | 1 KB | | | N/A | 0x0FE08000 | - | Yes | Device Information (DI) | 1 KB | ## Note: 1.64 pages for largest device. ## 6.3.1 Ram Configuration The SYSCFG module contains controls for configuring the various RAM blocks on the device. Options include enabling EM2/EM3 data retention, ECC, prefetch, and cache. 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. This page is written in the same way as any page in the Main user code area. ### 6.3.5 Bootloader The EFR32xG22 supports use of the Gecko Bootloader detailed in *UG266: Silicon Labs Gecko Bootloader User's Guide* (https://www.silabs.com/support/resources).To enable bootloader functionality the second stage of the bootloader must be configured and programmed into the first 16KB of flash. #### 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 On transitions from EM2/3 to EM0, the flash must be powered up. The time this takes depends on the current operating conditions. To have a deterministic wake time, set STDLY0 in MSC\_STARTUP to 0x64 and clear STDLY1, ASTWAIT, STWSEN and STWS. This will result in a 10 us delay before the flash is ready. The system will wake up before this, but the CPU core will stall on the first access to the flash until it is ready. Execute code from RAM or cache to get a faster CPU wake time. To get a faster flash wake time that depends on the current operating conditions, set STDLY0 to 0x32 and set ASTWAIT in MSC\_STARTUP. When configured this way, the system will poll the flash to determine when it is ready, and then start execution. For the fastest possible wakeup, code may be run with a set of wait-states initially and then automatically switched to normal operation. Set STDLY0 to 0x32, STDLY1 to 0x32, and set ASTWAIT and STWSEN. Then configure STWS in MSC\_STARTUP to the number of wait-states to run with. With this setup, execution will begin with the given number of wait-states after 5 uS, and the system will run with reduced throughput due to the wait-states for another 5 us before returning to normal full speed operation The recommended setting for MSC\_STARTUP register is to set STDLY0 to 0x32 for a 5 us wait and set ASTWAIT to one for active sampling. Set STWSEN to zero to bypass second delay period. This provides the best wakeup time without sacrificing power consumption. Flash wakeup on demand is supported when wakeup 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 The 20 MHz FSRCO is used for timing during flash write and erase operations. The default values in MSC\_FLASHPROGRAMTIME and MSC FLASHERASETIME contain the recommended programming configuration. 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 Element. 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 such as the radio controller 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, and CMD\_WDATA registers 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/Erase To limit maximum current, the programming operations can be slowed down. Set LPWRITE in MSC\_WRITECTRL to double the write/erase time, halving the write/erase 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. Similarly, code may lock the user data page by setting UDLOCKBIT in MSC\_MISCLOCKWORD, and mass erase may be disabled by setting MELOCKBIT in MSC\_MISCLOCKWORD. ## 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 | Туре | 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 Information | | 0x054 | DEVINFO_EMUTEMP | R | EMU Temperature Sensor Calibration Information | | 0x058 | DEVINFO_HFRCODPLLCALn | R | HFRCODPLL 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-<br>SETCAL0 | R | IADC Offset Calibration | | 0x190 | DEVINFO_IADC0NORMALOFF-<br>SETCAL1 | R | IADC Offset Calibration | | 0x194 | DEVINFO_IADC0HISPDOFF-<br>SETCAL0 | R | IADC Offset Calibration | | 0x198 | DEVINFO_IADC0HISPDOFF-<br>SETCAL1 | R | IADC Offset Calibration | | Offset | Name | Туре | Description | |--------|----------------|------|------------------------| | 0x1FC | DEVINFO_LEGACY | R | Legacy Device Info | | 0x25C | DEVINFO_RTHERM | R | Thermistor Calibration | # 6.4.2 DEVINFO Register Description # 6.4.2.1 DEVINFO\_INFO - DI Information | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--|------------|---|--|---------|--|---------|---------|--|----|---|----|----|----|---|----|----|---|----|-----|---|--|--|---|---|-----|---|---|---| | 0x000 | 31<br>30<br>22<br>22<br>22<br>24<br>24<br>25<br>27<br>26<br>26<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>28<br>28<br>29<br>29<br>29<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | | | | | | | | | | | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | = | 10 | 6 | ω | | | 2 | 4 | . ო | 2 | _ | 0 | | Reset | | | | 2 | Š | | 0 0 0 0 | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | ۵ | ۷ | | | | α | | | | | | | | ď | | | | | | | | | | | | | | | | Name | | | | VEVINEODEV | | | | | PPONPEV | TRODREY | | | | | | | | | | | | CRC | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | |-------|--------------------------|-------------------|--------------------|---------------------|--|--|--|--|--|--| | 31:24 | DEVINFOREV | 0x7 | R | DI Page Version | | | | | | | | | DEVINFO layout revision | n as unsigned | integer (initially | 1) | | | | | | | | 23:16 | PRODREV | 0x0 | R | Production Revision | | | | | | | | | Production revision as u | nsigned integ | er | | | | | | | | | 15:0 | CRC | 0x0 | R | CRC | | | | | | | | | CRC of DI-page (CRC-1 | ge (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 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | | Reset | | • | | • | 2 | e e | | | | | | 0% | | | | | | | | | | 0×0 | | | | | | | | | | | | | Access | | | | | ۵ | ۲ | | | | | | | <u>к</u> | | | | | | | | | | | | | | | | | | | | | | Name | | | | | > | | | | | | FAMILYNUM | | | | | | | | | | | | | = | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|----------------|--------------------|---------------------------------------------------------------------------| | 31:30 | Reserved | To ensur | | with future devices, always write bits to 0. More information in 1.2 Con- | | 29:24 | FAMILY | 0x0 | R | Device Family | | | Encoded portion of | the Device Fan | nily | | | | Value | Mode | | Description | | | 0 | FG | | Flex Gecko | | | 1 | MG | | Mighty Gecko | | | 2 | BG | | Blue Gecko | | | 5 | PG | | Pearl Gecko | | 23:22 | Reserved | To ensur | | with future devices, always write bits to 0. More information in 1.2 Con- | | 21:16 | FAMILYNUM | 0x0 | R | Device Family | | | Numeric portion of t | he Device Fam | ily | | | 15:0 | DEVICENUM | 0x0 | R | Device Number | | | Device Number. The<br>B123 | e device numbe | er is one letter a | and 3 digits. NUMBER = (alpha-'A')*1000 + numeric. 0 = A000; 1123 = | ## 6.4.2.3 DEVINFO\_MEMINFO - Memory Info | Offset | Bit Position | | | | | | | | | | | | | |--------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x008 | 2 2 2 3 3 3 3 4 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 | 5 4 5 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | Reset | 0×0 | 000000000000000000000000000000000000000 | | | | | | | | | | | | | Access | α. | α α | | | | | | | | | | | | | Name | DILEN | UDPAGESIZE | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | | | |-------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--------|---------------------|--|--|--|--|--|--|--|--|--|--|--| | 31:16 | DILEN | 0x0 | R | Length of DI Page | | | | | | | | | | | | | | Length of DI area (numb | ength of DI area (number of 32-bit words included in CRC) | | | | | | | | | | | | | | | 15:8 | UDPAGESIZE | 0x0 | R | User Data Page Size | | | | | | | | | | | | | | User Data page size | | | | | | | | | | | | | | | | 7:0 | FLASHPAGESIZE | 0x0 R Flash Page Size | | | | | | | | | | | | | | | | Flash page size in bytes coded as 2^((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 | 33 34 35 36 37 38 39 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>13</th> <th>12</th> <th>7</th> <th>10</th> <th><b>О</b></th> <th>œ</th> <th>7</th> <th>9</th> <th>2</th> <th>4</th> <th>က</th> <th>2</th> <th>_</th> <th>0</th> | | | | | | | | | | | | 13 | 12 | 7 | 10 | <b>О</b> | œ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 0%0 | | | | | | | | | | | 000 | | | | | | | | | | | | | | | | Access | | α. | | | | | | | | | | | <u>~</u> | | | | | | | | | | | | | | | | Name | | SRAM | | | | | | | | | | | FLASH | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|-------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------|-------------|--|--|--|--|--|--|--|--| | 31:27 | Reserved | To ensure o | To ensure compatibility with future devices, always write bits to 0. More informativentions | | | | | | | | | | | 26:16 | SRAM | 0x0 | R | Sram Size | | | | | | | | | | | Ram size, kbyte count a | s unsighed in | teger (eg. 16) | | | | | | | | | | | 15:0 | FLASH | 0x0 R Flash Size | | | | | | | | | | | | | Flash size, kbyte count as unsigned integer (eg. 128) | | | | | | | | | | | | ## 6.4.2.5 DEVINFO\_PKGINFO - Misc Device Info | Offset | | Bit Position | | | | | | | | | | | | |--------|----|--------------|---------|-----------|--|--|--|--|--|--|--|--|--| | 0x010 | 31 | | | | | | | | | | | | | | Reset | | 0×0 | 0×0 | 0×0 | | | | | | | | | | | Access | | α | α | ď | | | | | | | | | | | Name | | PINCOUNT | PKGTYPE | TEMPGRADE | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|----------------------|-------------------|---------------------------------------------------------------------------| | 31:24 | Reserved | To ensur<br>ventions | e compatibility ( | with future devices, always write bits to 0. More information in 1.2 Con- | | 23:16 | PINCOUNT | 0x0 | R | Pin Count | | | Device pin count as | unsigned intege | er (eg. 48) | | | 15:8 | PKGTYPE | 0x0 | R | Package Type | | | Package identifier as | s 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 | Temperature Grade | | | Temperature Grade | of produt as un | signed integer | enumeration | | | Value | Mode | | Description | | | 0 | N40TO8 | 5 | -40 to 85 degC | | | 1 | N40TO12 | 25 | -40 to 125 degC | | | 2 | N40TO10 | 05 | -40 to 105 degC | | | 3 | N0TO70 | | 0 to 70 degC | | | | | | | ## 6.4.2.6 DEVINFO\_CUSTOMINFO - Custom Part Info | Offset | Bit Position | | | | | | | | | | | | | | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x014 | 30 31 31 32 33 34 35 36 37 38 39 30 31 32 33 34 35 36 37 31 32 33 34 4 4 4 4 4 4 4 4 4 5 6 6 6 7 8 8 8 8 8 8 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | | | | | | | | | | | | | | | Reset | OXO | | | | | | | | | | | | | | | Access | α | | | | | | | | | | | | | | | Name | PARTNO | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |-------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------|-------------|--|--|--|--|--|--|--|--|--| | 31:16 | PARTNO | 0x0 | R | Part Number | | | | | | | | | | | | Custom part identifier as unsigned integer (eg. 903). 65535 for standard product | | | | | | | | | | | | | | 15:0 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Conventions | | | | | | | | | | | | ## 6.4.2.7 DEVINFO\_SWFIX - SW Fix Register | Offset | Bit Position | | | | | | | | | | | | | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--| | 0x018 | 30 30 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 5 6 6 6 7 7 8 8 8 8 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 1 | | | | | | | | | | | | | | Reset | OXFFFFF<br>OXFFFFFFFFFFFFFFFFFFFFFFFFFFFFF | | | | | | | | | | | | | | Access | <b>α</b> | | | | | | | | | | | | | | Name | RSV | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|----------------|--------|-------------| | 31:0 | RSV | 0xFFFFFF<br>FF | R | Reserved | | | 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 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | 2 | )<br>X | | | 2 | )<br>S | | | 2 | Š | | • | ć | Š | | | 2 | 2 | | | Š | S<br>S | | Access | | | | | | | | | | | _ | צ | | | ۵ | צ | | | ב | צ | | | ٥ | צ | | | ٥ | ۷ | | | ۵ | צ | | Name | | | | | | | | - | אַ | | | FORMINGO | | | | TOANACTO | BIOMAKI | | | ( | 74<br>1 | | | | 1 | | | 210012 | ZIGBEE | | | | | Bit | Name | Reset | Access | Description | | | | | | | |-------|-------------------------|------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--| | 31:22 | Reserved | To ensure o | compatibility witl | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 21:20 | SRI | 0x0 | R | RAIL Capability | | | | | | | | | RAIL capability level | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | 0 | LEVEL0 | | RAIL capability not available | | | | | | | | | 1 | LEVEL1 | | RAIL enabled | | | | | | | | | 2 | LEVEL2 | | N/A | | | | | | | | | 3 | LEVEL3 | | N/A | | | | | | | | 19:18 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 17:16 | CONNECT | 0x0 | R | Connect Capability | | | | | | | | | Connect stack capabilit | y level | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | 0 | LEVEL0 | | Connect stack capability not available | | | | | | | | | 1 | LEVEL1 | | Connect enabled | | | | | | | | | 2 | LEVEL2 | | N/A | | | | | | | | | 3 | LEVEL3 | | N/A | | | | | | | | 15:14 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 13:12 | BTSMART | 0x0 | R | Bluetooth Smart Capability | | | | | | | | | Bluetooth SMART stac | k capability lev | el | | | | | | | | | | Value | Mode | | Description | | | | | | | | | 0 | LEVEL0 | | Bluetooth SMART stack capability not available | | | | | | | | | 1 | LEVEL1 | | Bluetooth SMART enabled | | | | | | | | | 2 | LEVEL2 | | N/A | | | | | | | | | 3 | LEVEL3 | | N/A | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------|---------------|-----------------|---------------------------------------------------------------------------| | 11:10 | Reserved | | | vith future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | RF4CE | 0x0 | R | RF4CE Capability | | | RF4CE stack capa | ability level | | | | | Value | Mode | | Description | | | 0 | LEVEL0 | | RF4CE stack capability not available | | | 1 | LEVEL1 | | RF4CE stack enabled | | | 2 | LEVEL2 | | N/A | | | 3 | LEVEL3 | | N/A | | 7:6 | Reserved | To ensure o | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | THREAD | 0x0 | R | Thread Capability | | | Thread stack capa | ability level | | | | | Value | Mode | | Description | | | 0 | LEVEL0 | | Thread stack capability not available | | | 1 | LEVEL1 | | Thread stack enabled | | | 2 | LEVEL2 | | N/A | | | 3 | LEVEL3 | | N/A | | 3:2 | Reserved | To ensure o | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | ZIGBEE | 0x0 | R | Zigbee Capability | | | ZigBee stack capa | ability level | | | | | Value | Mode | | Description | | | 0 | LEVEL0 | | Zigbee stack capability not available | | | 1 | LEVEL1 | | Green Power only | | | 2 | LEVEL2 | | Zigbee and Green Power | | | 3 | LEVEL3 | | Zigbee Only | # 6.4.2.9 DEVINFO\_SWCAPA1 - Software Restriction | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|------|-------|---------| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | ' | | | | | | | | | | | | | | | | | | | | | | | | | 0X0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 22 | 22 | 2 | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | GWEN | NCPEN | RFMCUEN | | Bit | Name | Reset | Access | Description | |------|---------------------|----------------------|----------------|-----------------------------------------------------------------------------| | 31:3 | Reserved | To ensur<br>ventions | • | y with future devices, always write bits to 0. More information in 1.2 Con- | | 2 | GWEN | 0x0 | R | Gateway | | | Gateway enabled pa | rt | | | | 1 | NCPEN | 0x0 | R | NCP | | | Network co-processo | or enabled part | . NCP only if | RFMCUEN = 0 | | 0 | RFMCUEN | 0x0 | R | RF-MCU | | | RF-MCU enabled pa | rt. RF-MCU or | nly if NCPEN = | = 0 | # 6.4.2.10 DEVINFO\_EXTINFO - External Component Info | Offset | | Bit Po | sition | | |--------|----------------------------------------------------------|----------------------------------------------|------------|---------------------------------------------------------------| | 0x028 | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>25<br>27<br>27 | 23<br>22<br>21<br>20<br>20<br>19<br>17<br>17 | 6 9 9 8 | L 0 0 4 0 1 0 | | Reset | | 0×0 | 0×0 | 0×0 | | Access | | α | α | ď | | Name | | REV | CONNECTION | ТҮРЕ | | Bit | Name | Reset | Access | Description | |-------|--------------------------|------------------|-------------------|------------------------------------------------------------------------| | 31:24 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 23:16 | REV | 0x0 | R | Revision | | | MCM Revision | | | | | 15:8 | CONNECTION | 0x0 | R | Connection | | | Connection protocol to e | external interfa | ace | | | | Value | Mode | | Description | | | 0 | SPI | | SPI control interface | | | 255 | NONE | | No interface | | 7:0 | TYPE | 0x0 | R | Туре | | | External Component | | | | | | Value | Mode | | Description | | | 255 | NONE | | | | | | | | | ## 6.4.2.11 DEVINFO\_EUI48L - EUI 48 Low | Offset | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----------------------------------------|----|--------|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---| | 0x040 | 31 | 29 | 73 | 27 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | δ<br>« « | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | OUI48L | | | | | | | | | | | | | | | | UNICOEID | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------|---------------|-----------------|-------------| | 31:24 | OUI48L | 0x0 | R | OUI48L | | | Lower Octet of EUI48 | Organizationa | lly Unique Iden | tifier | | 23:0 | UNIQUEID | 0x0 | R | Unique ID | | | Unique identifier | | | | # 6.4.2.12 DEVINFO\_EUI48H - EUI 48 High | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|---------|----|----|----|----|----|--------|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|-------------------------|---|---|---|---|---|---|---| | 0x044 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | OXO OXO | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | ٥ | ۲ | | | | | | | | | | | | | | | ۵ | צ | | | | | | | | | Name | | | | | | | | מהימהמ | > | | | | | | | | | | | | | | | | 00<br>100<br>100<br>100 | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------|--------|-------------| | 31:16 | RESERVED | 0xFFFF | R | RESERVED | | | | | | | | 15:0 | OUI48H | 0x0 | R | OUI48H | | | Upper two Octets of EU | 48 OUI | | | ## 6.4.2.13 DEVINFO\_EUI64L - EUI64 Low | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x048 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | • | • | | • | • | • | | • | | • | 2 | 3 | | | • | | | • | • | | | • | • | • | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|----------------|--------|-------------| | 31:0 | UNIQUEL | 0x0 | R | UNIQUEL | | | Lower 32 bits of EUI64 L | Jnique Identif | ier | | # 6.4.2.14 DEVINFO\_EUI64H - EUI64 High | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|---------------------------------------|----|----|----|----|----|----|----|----|----|-------|------|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x04C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | OX OX | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | ν ν ν ν ν ν ν ν ν ν ν ν ν ν ν ν ν ν ν | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | 29110 | 1000 | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|-----------------|--------|-------------| | 31:8 | OUI64 | 0x0 | R | OUI64 | | | 24-bit OUI identifier | | | | | 7:0 | UNIQUEH | 0x0 | R | UNIQUEH | | | Upper 8 bits of EUI64 ur | nique identifie | r | | ## 6.4.2.15 DEVINFO\_CALTEMP - Calibration temperature Information | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|------|-------------|---|---|---| | 0x050 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 41 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | • | • | | | | | • | | • | | | | • | • | • | • | | | | | | | 2 | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | Δ | ۷ | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | TEMD | L<br>2<br>1 | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | TEMP | 0x0 | R | Cal Temp | | | Calibration temperature | as an unsigne | ed int in DegC. ( | 0x19 = 25 DegC) | # 6.4.2.16 DEVINFO\_EMUTEMP - EMU Temperature Sensor Calibration Information | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|-------------|---|---|---|---|---|---| | 0x054 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | • | | • | • | • | • | • | • | • | • | | • | • | • | | | • | | • | | | • | | 0x0 | • | • | • | • | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | œ | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | EMUTEMPROOM | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------|-------------------------|-------------------|------------------------------------------------------------------------| | 31:11 | Reserved | To ensure c<br>ventions | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 10:2 | EMUTEMPROOM | 0x0 | R | Emu Room Temperature | | 1:0 | Reserved | To ensure c | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | ## 6.4.2.17 DEVINFO\_HFRCODPLLCALn - HFRCODPLL Calibration | Offset | | | Bit Position | | |--------|----------|----------------------------------------------------|----------------------------------------------------------------------------------|-----------------| | 0x058 | 30 29 28 | 27<br>26<br>27<br>27<br>23<br>23<br>23<br>21<br>21 | 20<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10 | V 0 7 4 8 7 F 0 | | Reset | 0x0 | 0% 0% 0% | 000000000000000000000000000000000000000 | 0x0 | | Access | α. | м м м | и и и | α. | | Name | IREFTC | CMPSEL | FREQRANGE LDOHP FINETUNING | JUNING | | 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 C | lock Output | | | | 23:21 | CMPBIAS | 0x0 | R | | | | Comparator Bias Curren | t | | | | 20:16 | FREQRANGE | 0x0 | R | | | | Frequency Range | | | | | 15 | LDOHP | 0x0 | R | | | | LDO High Power Mode | | | | | 14 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 13:8 | FINETUNING | 0x0 | R | | | | Fine Tuning Value | | | | | 7 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 6:0 | TUNING | 0x0 | R | | | | Tuning Value | | | | ## 6.4.2.18 DEVINFO\_MODULENAME0 - Module Name Information | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|-------|----|----|---------|----|----|----|----|----|----|----|-----------|--------|----|------|------|----|----|----|----------|----|---|---|---|---|---|--------|----------|---|---|---| | 0x130 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | | | | | | | | | 2 | -<br>3 | | • | | | | | | | | | | | | | | | | | | Access | | A × 0 | | | | | | | | | | ב | ۲ | | | | | | | ב | צ | | | | | | | ۵ | <u> </u> | | | | | Name | | | | | 455000W | | | | | | | | SAREDOUNI | | | | | | | - | MODOHARA | | | | | | | TONDOM | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|---------------|-----------------|-----------------------------------| | 31:24 | MODCHAR4 | 0xFF | R | | | | Fourth character of Mod | ule Name, 0xl | FF = unwritten, | 0x00 = character not used in name | | 23:16 | MODCHAR3 | 0xFF | R | | | | Third character of Modul | e Name, 0xFI | = unwritten, 0 | x00 = character not used in name | | 15:8 | MODCHAR2 | 0xFF | R | | | | Second character of Mod | dule Name, 0 | xFF = unwritten | 0x00 = character not used in name | | 7:0 | MODCHAR1 | 0xFF | R | | | | First character of Module | e Name, 0xFF | = unwritten, 0x | 00 = character not used in name | # 6.4.2.19 DEVINFO\_MODULENAME1 - Module Name Information | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|---------------------------------------|----|----|-----------------------------------------|-------------|----|----|----|----|----|----|----------------|----------|------|----|------|------|----|----|----|---|----|---|---|---|---|---|---|----------|---|---|---| | 0x134 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 41 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | - ო | 2 | _ | 0 | | Reset | X X X X X X X X X X X X X X X X X X X | | | | | | | | | | | | | 0xFF | | | | | | | | | | | | | | | | | | | | Access | | α | | | | | | | | | | ۵ | ۲ | | | | | | | ٥ | ۲ | | | | | | | | ď | | | | | Name | | | | S C C C C C C C C C C C C C C C C C C C | Z<br>L<br>O | | | | | | | 70 V I C C V I | YYYEOON! | | | | | | | | | | | | | | | | MODCHAR5 | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|---------------|-------------------|----------------------------| | 31:24 | MODCHAR8 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | ınwritten, 0x00 = | character not used in name | | 23:16 | MODCHAR7 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | ınwritten, 0x00 = | character not used in name | | 15:8 | MODCHAR6 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | ınwritten, 0x00 = | character not used in name | | 7:0 | MODCHAR5 | 0xFF | R | | | | Character of Module Na | ıme, 0xFF = ι | ınwritten, 0x00 = | character not used in name | ## 6.4.2.20 DEVINFO\_MODULENAME2 - Module Name Information | Offset | | Bit Po | sition | | |--------|----------------------------------------------------------|-----------------------------------------------------|-----------|-----------------| | 0x138 | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>26<br>27<br>27 | 22 22 21 20 119 149 149 149 149 149 149 149 149 149 | 6 9 9 8 | V 0 0 4 8 0 T O | | Reset | 0×F | OXFF. | 0xFF | 0XFF | | Access | α. | α | α | <u>~</u> | | Name | MODCHAR12 | MODCHAR11 | MODCHAR10 | MODCHAR9 | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------|-----------------|------------------------------| | 31:24 | MODCHAR12 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | unwritten, 0x00 | = character not used in name | | 23:16 | MODCHAR11 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | unwritten, 0x00 | = character not used in name | | 15:8 | MODCHAR10 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | unwritten, 0x00 | = character not used in name | | 7:0 | MODCHAR9 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | unwritten, 0x00 | = character not used in name | ## 6.4.2.21 DEVINFO\_MODULENAME3 - Module Name Information | Offset | | Bit Po | sition | | |--------|----------------------------------------------------------|-------------------------------------|-----------|-----------------| | 0x13C | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>26<br>27<br>27 | 23 22 22 23 20 19 19 14 14 17 17 16 | 6 9 9 8 | V 9 R 4 R 7 L 0 | | Reset | 0×FF | 0×FF | 0xFF | 0XFF | | Access | α. | α_ | α | <u>~</u> | | Name | MODCHAR16 | MODCHAR15 | MODCHAR14 | MODCHAR13 | | Bit | Name | Reset | Access | Description | | | |-------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------|--------|-------------|--|--| | 31:24 | MODCHAR16 | 0xFF | R | | | | | | Character of Module | cter 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.22 DEVINFO\_MODULENAME4 - Module Name Information | Offset | | Bit Po | sition | | | | | | | | | | |--------|----------------------------------------------------------|----------------------------------------------------|-----------|-------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 0x140 | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>26<br>27<br>27 | 23<br>22<br>21<br>20<br>20<br>19<br>17<br>17<br>16 | 6 9 9 8 | 7 9 6 4 8 7 1 0 | | | | | | | | | | Reset | 0×F | 0×FF | 0xFF | 0xFF | | | | | | | | | | Access | α. | ď | α | α. | | | | | | | | | | Name | MODCHAR20 | MODCHAR19 | MODCHAR18 | MODCHAR17 | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|---------------|-----------------|------------------------------| | 31:24 | MODCHAR20 | 0xFF | R | | | | Character of Module Na | me, 0xFF = ι | unwritten, 0x00 | = character not used in name | | 23:16 | MODCHAR19 | 0xFF | R | | | | Character of Module Na | ıme, 0xFF = ι | unwritten, 0x00 | = character not used in name | | 15:8 | MODCHAR18 | 0xFF | R | | | | Character of Module Na | ıme, 0xFF = ι | unwritten, 0x00 | = character not used in name | | 7:0 | MODCHAR17 | 0xFF | R | | | | Character of Module Na | ıme, 0xFF = ι | unwritten, 0x00 | = character not used in name | ### 6.4.2.23 DEVINFO\_MODULENAME5 - Module Name Information | Offset | | Bit Po | sition | | | | | | | | | | |--------|----------------------------------------------------|----------------------------------------------|-----------|-------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 0x144 | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>25<br>27 | 23<br>22<br>21<br>20<br>20<br>19<br>17<br>17 | 6 9 9 8 | L 0 0 4 8 0 1 0 | | | | | | | | | | Reset | 0×FF | 0xFF | 0xFF | OXFI | | | | | | | | | | Access | α. | α | α | ď | | | | | | | | | | Name | MODCHAR24 | MODCHAR23 | MODCHAR22 | MODCHAR21 | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | | | |-------|-------------------------------------------------------------------------------|---------------|------------------|----------------------------|--|--|--|--|--|--|--|--|--|--|--| | 31:24 | MODCHAR24 | 0xFF | R | | | | | | | | | | | | | | | Character of Module Na | me, 0xFF = ui | nwritten, 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 Na | me, 0xFF = ui | nwritten, 0x00 = | character not used in name | | | | | | | | | | | | | 7:0 | MODCHAR21 | 0xFF | R | | | | | | | | | | | | | | | Character of Module Na | me, 0xFF = ui | nwritten, 0x00 = | character not used in name | | | | | | | | | | | | # 6.4.2.24 DEVINFO\_MODULENAME6 - Module Name Information | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | | | |--------|----|--------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|-----------|---|---|---|-----------|---|------|---|---|-----|---|---|---|--|--| | 0x148 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | = | 9 | 6 | 8 | 7 | 9 | 5 | 4 | - ო | 2 | _ | 0 | | | | Reset | | O<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H | | | | | | | | | | | | | | | 0×FF | | | | | | | | | OXFF | | | | | | | | | | Access | | α | | | | | | | | | | | | | | | | | | צ | | | | <b>c</b> | | | | | | | | | | | | Name | | RSV<br>R | | | | | | | | | | | | | | | | | | MODCHARZO | | | | 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 nan | ne, 0xFF = unw | ritten, 0x00 = character not used in name | | 7:0 | MODCHAR25 | 0xFF | R | | | | 0xFF = unwritten, 0x00 = | character no | t used in name | | ### 6.4.2.25 DEVINFO\_MODULEINFO - Module Information | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----------|------------|--------|----|----|----|----|--------------|----|----|----|----|------------|------------|---------|------|------|----|----|----|-----------|----|---|---|---|---------|---|---|---|----------|---|---| | 0x14C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x1 | 0x1 | 0x1 | | • | | • | 0x1FF | | | | | 0x1 | 0x1 | 0x1 | 0x1 | 0x1 | | | | 0x7F | | | | | 0x7 | • | | | 0x1F | | | | Access | 2 | ~ | ~ | | | | | ~ | | | | | 22 | 22 | 2 | 22 | 22 | | | | ~ | | | | | ~ | | | | <u>~</u> | | | | Name | EXTVALID | PHYLIMITED | PADCDC | | | | | MODNUMBERMSB | | | | | HFXOCALVAL | LFXOCALVAL | EXPRESS | LFXO | TYPE | | | | MODNUMBER | | | | | ANTENNA | | | | HWREV | | | | | | _ | | | |-------|------------------------|-----------------|-----------------|-------------------------------------------| | Bit | Name | Reset | Access | Description | | 31 | EXTVALID | 0x1 | R | | | | EXTINFO entry used | | | | | | Value | Mode | | Description | | | 0 | EXTUSE | ) | EXT used | | | 1 | EXTUNUS | SED | EXT not used | | 30 | PHYLIMITED | 0x1 | R | | | | PHY Limited | | | | | | Value | Mode | | Description | | | 0 | LIMITED | | | | | 1 | UNLIMITE | ED | | | 29 | PADCDC | 0x1 | R | | | | PAVDD Connection | | | | | | Value | Mode | | Description | | | 0 | VDCDC | | PAVDD connected to Vdcdc | | | 1 | OTHER | | PAVDD connected to Vdd or other | | 28:20 | MODNUMBERMSB | 0x1FF | R | | | | Counter allowing uniqu | e identificatio | n of module per | lookup when combined with MODNUMBER | | 19 | HFXOCALVAL | 0x1 | R | | | | HFXO Factory Calibrat | ed | | | | | Value | Mode | | Description | | | 0 | VALID | | HFXO calibration in MODXOCAL is valid | | | 1 | NOTVALI | D | HFXO calibration in MODXOCAL is not valid | | 18 | LFXOCALVAL | 0x1 | R | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-----------------|------------------|--------------------------------------------| | | LFXO Factory Calibrated | d | | | | | Value | Mode | | Description | | | 0 | VALID | | LFXO Tuning in MODXOCAL is valid | | | 1 | NOTVALID | | LFXO Tuning value in MODXOCAL is not valid | | 17 | EXPRESS | 0x1 | R | | | | Blue Gecko Express | | | | | | Value | Mode | | Description | | | 0 | SUPPORTE | ED . | Blue Gecko Express is supported | | | 1 | NONE | | Blue Gecko Express is not supported | | 16 | LFXO | 0x1 | R | | | | Module has LFXO | | | | | | Value | Mode | | Description | | | 0 | NONE | | LFXO is not installed | | | 1 | PRESENT | | LFXO is installed | | 15 | TYPE | 0x1 | R | | | | Module Type | | | | | | Value | Mode | | Description | | | 0 | PCB | | PCB | | | 1 | SIP | | SIP | | 14:8 | MODNUMBER | 0x7F | R | | | | Counter allowing unique | identification | of module per lo | pokup when combined with MODNUMBER MSB | | 7:5 | ANTENNA | 0x7 | R | | | | Module Antenna Type | | | | | | Value | Mode | | Description | | | 0 | BUILTIN | | Built-in Antenna | | | 1 | CONNECT | OR | RF Connector | | | 2 | RFPAD | | RF Pad | | | 3 | INVERTED | F | F-invert PCB | | 4:0 | HWREV | 0x1F | R | | | | Module Hardware Revis | ion. Starting f | rom 0 | | ### 6.4.2.26 DEVINFO\_MODXOCAL - Module External Oscillator Calibration Information | Offset | | Bit Po | sition | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------|---------------------------------------------------------------| | 0x150 | 31<br>30<br>29<br>28<br>27<br>27<br>27<br>26<br>26<br>25<br>27<br>27<br>27<br>27<br>27<br>27<br>28<br>28<br>29<br>29<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | 22<br>21<br>20<br>20<br>19<br>17<br>16 | 15 | 7 8 4 8 5 1 0 | | Reset | | 0x7F | 0xFF | 0XFF | | Access | | α | α | | | Name | | LFXOCAPTUNE | HFXOCTUNEXOANA | HFXOCTUNEXIANA | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:23 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 22:16 | LFXOCAPTUNE | 0x7F | R | | | | LFXO Cap Tuning | | | | | 15:8 | HFXOCTUNEXOANA | 0xFF | R | | | | Tuning capacitance on > | (O | | | | 7:0 | HFXOCTUNEXIANA | 0xFF | R | | | | Tuning capacitance on > | KI | | | ### 6.4.2.27 DEVINFO\_IADC0GAIN0 - IADC Gain Calibration | Offset | | | | | | | | | | | | | | | | Position | | | | | | | | | | | | | | | | | |--------|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|---|----|----|---|----|-----------|---|---|---|---|---|---|---|---|---| | 0x180 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 8 | | | | | | | | | | | | | | 0×0 | | | | | | | | | | | | | | | | | | Access | | <u>~</u> | | | | | | | | | | | | | | | <b>c</b> | | | | | | | | | | | | | | | | | Name | | GAINCANA2 R | | | | | | | | | | | | | | | | | | | | ( | GAINCANAT | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------|--------|-------------| | 31:16 | GAINCANA2 | 0x0 | R | | | | Input Gain = 2x | | | | | 15:0 | GAINCANA1 | 0x0 | R | | | | Input Gain = 1x and 0.5 | x | | | ### 6.4.2.28 DEVINFO\_IADC0GAIN1 - IADC Gain Calibration | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|--|--|---|---|---|---|--|---|----------|--|---------------------------------------|-------------|--|--|--|--|--|--|--| | 0x184 | - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - <th>_</th> <th>0</th> | | | | | | | | | _ | 0 | | | | | | | | | | | | | | | Reset | | | | | | | | 2 | Š | | • | | • | 0X0 | | | | | | | | | | | | Access | | | | | | | | ۵ | ۲ | | | | | <u>~</u> | | | | | | | | | | | | Name | | 3AINCANA4 R | | | | | | | | | | | | | | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | GAIIACAIIAS | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------|-------|--------|-------------| | 31:16 | GAINCANA4 | 0x0 | R | | | | Input Gain = 4x | | | | | 15:0 | GAINCANA3 | 0x0 | R | | | | Input Gain = 3x | | | | # 6.4.2.29 DEVINFO\_IADC0OFFSETCAL0 - IADC Offset Calibration | Offset | Bit | osition | | | | | | | |--------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--|--|--|--|--|--| | 0x188 | 33<br>33<br>33<br>33<br>33<br>33<br>34<br>35<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27 | 2 2 4 8 2 7 7 0 8 8 7 9 4 8 7 7 7 0 | | | | | | | | Reset | 0×0 | 0x0 | | | | | | | | Access | <b>~</b> | <u>د</u> | | | | | | | | Name | OFFSETANA1HIACC | OFFSETANABASE | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------|--------|-------------| | 31:16 | OFFSETANA1HIACC | 0x0 | R | | | | High-accuracy OSR adj | ustment term | | | | 15:0 | OFFSETANABASE | 0x0 | R | | | | Base analog offset term | | | | ### 6.4.2.30 DEVINFO\_IADC0NORMALOFFSETCAL0 - IADC Offset Calibration | Offset | Bit Po | sition | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 0x18C | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <t< th=""><th>4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1</th></t<> | 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | Reset | 000 | 0×0 | | | | | | Access | α. | α | | | | | | Name | OFFSETANA2NORM | OFFSETANA1NORM | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|----------------|------------------|-------------| | 31:16 | OFFSETANA2NORM | 0x0 | R | | | | Normal mode offset gain | adjustment to | erm | | | 15:0 | OFFSETANA1NORM | 0x0 | R | | | | Normal mode analog offs | set term at OS | SR=2x, gain = 1: | K | # 6.4.2.31 DEVINFO\_IADC0NORMALOFFSETCAL1 - IADC Offset Calibration | Offset | Bit P | osition | | | | | | |--------|----------------------------------------|----------------------------------------|--|--|--|--|--| | 0x190 | 10 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 15 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | Reset | | 0×0 | | | | | | | Access | | <u>د</u> | | | | | | | Name | | OFFSETANA3NORM | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | OFFSETANA3NORM | 0x0 | R | | | | Normal mode offset term | n for OSR>=4 | łx | | ### 6.4.2.32 DEVINFO\_IADC0HISPDOFFSETCAL0 - IADC Offset Calibration | Offset | Bit Positio | osition | | | | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 0x194 | 30 31 31 32 33 34 35 36 37 38 39 30 31 32 33 34 36 37 38 30 31 31 32 33 34 35 36 37 37 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1</th> | 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | Reset | 000 | 0×0 | | | | | | Access | α | α. | | | | | | Name | OFFSETANA2HISPD | OFFSETANA1HISPD | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|-----------------|-----------------|-------------| | 31:16 | OFFSETANA2HISPD | 0x0 | R | | | | High speed mode offset | gain adjustme | ent term | | | 15:0 | OFFSETANA1HISPD | 0x0 | R | | | | High speed mode analog | g offset term a | at OSR=2x, gair | n = 1x | # 6.4.2.33 DEVINFO\_IADC0HISPDOFFSETCAL1 - IADC Offset Calibration | Offset | t Bit Position | | |--------|----------------|-----------------| | 0x198 | 9 9 | 8 | | Reset | | 0×0 | | Access | es . | ď | | Name | | OFFSETANA3HISPD | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|------------------------|---------------------------------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:16 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 15:0 | OFFSETANA3HISPD | 0x0 | R | | | | | | | | | | | | High-speed mode offset | gh-speed mode offset term for OSR>=4x | | | | | | | | | | | # 6.4.2.34 DEVINFO\_LEGACY - Legacy Device Info | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|---------------------------------------------------------------------------------|--|---|---|--|--|--|--|--------------|--|--|----|---|----|----|---|----|---|---|---|---|---|---|---|---|---|---|--|--|---|--| | 0x1FC | 31 | 33<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>3 | | | | | | | | | | | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | | | | | Reset | | | | • | • | | | | | 0880 | | | | | | | | | | | • | | | • | | • | | | | | • | | | Access | | | | | | | | | | α | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | DEVICEFAMILY | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |-------|---------------|--------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:24 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 23:16 | DEVICEFAMILY | 0x80 | R | Device Family | | | | | | | | | | Device Family | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 16 | EFR32MG | G1P | EFR32 Mighty Gecko Family Series 1 Device Config 1 | | | | | | | | | | 17 | EFR32MG | G1B | EFR32 Mighty Gecko Family Series 1 Device Config 1 | | | | | | | | | | 18 | EFR32MG | 61V | EFR32 Mighty Gecko Family Series 1 Device Config 1 | | | | | | | | | | 19 | EFR32BG | i1P | EFR32 Blue Gecko Family Series 1 Device Config 1 | | | | | | | | | | 20 | EFR32BG | i1B | EFR32 Blue Gecko Family Series 1 Device Config 1 | | | | | | | | | | 21 | EFR32BG | i1V | EFR32 Blue Gecko Family Series 1 Device Config 1 | | | | | | | | | | 25 | EFR32FG | 1P | EFR32 Flex Gecko Family Series 1 Device Config 1 | | | | | | | | | | 26 | EFR32FG | 1B | EFR32 Flex Gecko Family Series 1 Device Config 1 | | | | | | | | | | 27 | EFR32FG | 1V | EFR32 Flex Gecko Family Series 1 Device Config 1 | | | | | | | | | | 28 | EFR32MG | 612P | EFR32 Mighty Gecko Family Series 1 Device Config 2 | | | | | | | | | | 29 | EFR32MG | 612B | EFR32 Mighty Gecko Family Series 1 Device Config 2 | | | | | | | | | | 30 | EFR32MG | 612V | EFR32 Mighty Gecko Family Series 1 Device Config 2 | | | | | | | | | | 31 | EFR32BG | 12P | EFR32 Blue Gecko Family Series 1 Device Config 2 | | | | | | | | | | 32 | EFR32BG | 12B | EFR32 Blue Gecko Family Series 1 Device Config 2 | | | | | | | | | | 33 | EFR32BG | 12V | EFR32 Blue Gecko Family Series 1 Device Config 2 | | | | | | | | | | 37 | EFR32FG | 12P | EFR32 Flex Gecko Family Series 1 Device Config 2 | | | | | | | | | | 38 | EFR32FG | 12B | EFR32 Flex Gecko Family Series 1 Device Config 2 | | | | | | | | | | 39 | EFR32FG | 12V | EFR32 Flex Gecko Family Series 1 Device Config 2 | | | | | | | | | | 40 | EFR32MG | 613P | EFR32 Mighty Gecko Family Series 13 Device Config 3 | | | | | | | | | | 41 | EFR32MG | 613B | EFR32 Mighty Gecko Family Series 13 Device Config 3 | | | | | | | | | | 42 | EFR32MG | 613V | EFR32 Mighty Gecko Family Series 1 Device Config 3 | | | | | | | | | | 43 | EFR32BG | i13P | 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 | To ensure compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con | | | | | | | | | #### 6.4.2.35 DEVINFO\_RTHERM - Thermistor Calibration | Offset | Bit Po | osition | | | | | | | | | | | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 0x25C | 33 34 35 36 37 38 39 30 30 31 32 33 34 35 36 37 38 39 30 30 31 32 33 34 35 36 37 38 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>7 4 5 4 5 5 6 6 7 7 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 <t< th=""></t<></th> | 7 4 5 4 5 5 6 6 7 7 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 <t< th=""></t<> | | | | | | | | | | | | Reset | | 0×0 | | | | | | | | | | | | Access | | α. | | | | | | | | | | | | Name | | RTHERM | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | |-------|--------------------------------|-------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--| | 31:16 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 15:0 | RTHERM | 0x0 | R | | | | | | | | | Calibrated Thermistor Resistor | | | | | | | | | #### 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 accesses 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 83. 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 IC-ACHE\_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 is 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 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 PCMISSES. The cache hit-ratio can be calculated as PCHITS / (PCHITS + PCMISSES). 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 + PCMISSES). When PCHITS/PCAHITS/PCMISSES overflow, the HITOF/AHITOF/MISSOF 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 PCMISSES. Software may check the 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 | Туре | 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 | Туре | Description | |--------|-------------------|-------------|------------------| | 0x3014 | ICACHE_STATUS_TGL | RH | Status Register | | 0x3018 | ICACHE_CMD_TGL | W | Command Register | | 0x301C | ICACHE_LPMODE_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 | 3 3 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | | | | | | | | | | | | | Reset | OX OX | | | | | | | | | | | | | Access | <u>~</u> | | | | | | | | | | | | | Name | IPVERSION | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|-----------|---------------------------------------------------------------------------------------------------------------------------------------|--------|---------------|--|--|--|--|--|--|--|--| | 31:0 | IPVERSION | 0x0 | R | IP version ID | | | | | | | | | | | • | nly IPVERSION field gives the version for this module. There may be minor software changes required th 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 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | ' | | | | | | ' | | ' | | | ' | | ' | • | | | | - | | | | • | • | • | 0x0 | 0X0 | 000 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | ₩ | R<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | AUTOFLUSHDIS | USEMPU | CACHEDIS | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:3 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 2 | AUTOFLUSHDIS | 0x0 | RW | Automatic Flushing Disable | | | Disables automatic flu | shing based o | on Internal Flasi | h write/erase | | 1 | USEMPU | 0x0 | RW | Use MPU | | | Use MPU to select no | n/cacheable re | egions | | | 0 | CACHEDIS | 0x0 | RW | Cache Disable | | | Disables caching for a | II regions | | | # 6.5.4.3 ICACHE\_PCHITS - Performance Counter Hits | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|------|-------|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---| | 0x008 | 31 | 30 | 53 | 78 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 9 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 5 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | 2 | OXO | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | O.L. | 2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ٥ | )<br> | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------|-------|--------|--------------------------| | 31:0 | PCHITS | 0x0 | R | Performance Counter Hits | | | Hit counter value | | | | ### 6.5.4.4 ICACHE\_PCMISSES - Performance Counter Misses | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|-------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | • | • | • | • | | • | | | | • | • | | 2 | 2 | • | | • | • | | • | | • | • | • | • | • | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | DOMINOER | SISSE | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------|-------|--------|----------------------------| | 31:0 | PCMISSES | 0x0 | R | Performance Counter Misses | | | Miss counter value | | | | ### 6.5.4.5 ICACHE\_PCAHITS - Performance Counter Advanced Hits | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|--------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | • | | | | | | 2 | 2 | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | OFILIA | Ē | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------|--------------|------------------|--------------------------------------------------| | 31:0 | PCAHITS | 0x0 | R | Performance Counter Advanced Hits | | | Hit counter value for hits | due to Advar | nced Buffering n | node. These hits are also represented in PCHITS. | ### 6.5.4.6 ICACHE\_STATUS - Status Register | Offset | Bit Position | | |--------|------------------------------------------|-----------| | 0x014 | 33 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | 0 | | Reset | | 0×0 | | Access | | 2 | | Name | | PCRUNNING | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | PCRUNNING | 0x0 | R | PC Running | | | Performance Counters a | re running | | | # 6.5.4.7 ICACHE\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---------|-------| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | œ | 7 | ဖ | 2 | 4 | က | 7 | _ | 0 | | Reset | | | ' | | | | | | | | | | | ' | | <u>'</u> | • | | | ' | | | | | | • | | | • | 0x0 | 0×0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | 8 | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | STOPPC | STARTPC | FLUSH | | Bit | Name | Reset | Access | Description | |------|------------------------|-----------------------|-------------------|------------------------------------------------------------------------| | 31:3 | Reserved | To ensure<br>ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 2 | STOPPC | 0x0 | W | Stop Performance Counters | | | Stops the Performance | Counters | | | | 1 | STARTPC | 0x0 | W | Start Performance Counters | | | Starts the Performance | Counters | | | | 0 | FLUSH | 0x0 | W | Flush | | | Clears Cached Data | | | | ### 6.5.4.8 ICACHE\_LPMODE - Low Power Mode | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----|---|---|------|---|---|---|-----------|---------| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | • | | | • | | | | | | • | | | • | | | | | | | ç | NX N | | | • | 2 | 3 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | Ž | | | | Š | ^^ | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | I DI EVEI | -<br> - | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:8 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 7:4 | NESTFACTOR | 0x2 | RW | Low Power Nest Factor | | | | | | ontrol its estimation when a branch access is likely to be accssed in ove performance in code with deeply nested loops. | | 3:2 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | LPLEVEL | 0x3 | RW | Low Power Level | | | Controls the low-power | evel of the ca | ache. In general | , the default setting is best for most applications. | | | Value | Mode | | Description | | | 0 | BASIC | | Base instruction cache functionality | | | 1 | ADVANCE | :D | Advanced buffering mode, where the cache uses the fetch pattern to predict highly accessed data and store it in low-energy memory | | | 3 | MINACTIV | TITY | 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 | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|----------|---|---|---|---|---|--------|--------|---------| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | | • | | • | • | | | | | | | | • | • | • | | | • | • | | | | 0X0 | | | | • | | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | S. | | | | | | ₩ | ₩ | RW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | RAMERROR | | | | | | AHITOF | MISSOF | HITOF | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 8 | RAMERROR | 0x0 | RW | RAM error Interrupt Flag | | | RAM parity error detected | ed | | | | 7:3 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 2 | AHITOF | 0x0 | RW | Advanced Hit Overflow Interrupt Flag | | | Advanced hit performand | ce counter ha | s overflowed | | | 1 | MISSOF | 0x0 | RW | Miss Overflow Interrupt Flag | | | Miss performance count | er has overflo | wed | | | 0 | HITOF | 0x0 | RW | Hit Overflow Interrupt Flag | | | Hit performance counter | has overflow | ed | | #### 6.5.4.10 ICACHE\_IEN - Interrupt Enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|---|--------|--------|-------------| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | • | | | | | | | | | | | | • | • | | | | • | | | | 0X0 | | • | • | • | | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | S. | | | | | | ₽ | ₩<br>M | 8<br>M<br>M | | | | | | | | | | | | | | | | | | | | | | | | | | ROR | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | RAMERROR | | | | | | AHITOF | SSOF | TOF | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | | | | | | ₹ | ₫ | 토 | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 8 | RAMERROR | 0x0 | RW | RAM error Interrupt Enable | | | Enable RAMERROR into | errupt | | | | 7:3 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 2 | AHITOF | 0x0 | RW | Advanced Hit Overflow Interrupt Enable | | | Enable AHITOF interrup | t | | | | 1 | MISSOF | 0x0 | RW | Miss Overflow Interrupt Enable | | | Enable MISSOF interrup | t | | | | 0 | HITOF | 0x0 | RW | Hit Overflow Interrupt Enable | | | 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 two 24 KB and 8 KB banks, beginning at address 0x20000000 and 0x20006000, respectively. By default both banks are retained in EM2/EM3. Sleep mode current can be significantly reduced by powering down a bank that does not need to be retained. RAMRETNCTRL in the SYSCFG DMEM0RETNCTRL register controls which banks are retained in EM2/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 DRAM0 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). FRCRAM and all or part of SEQRAM may be powered down in EM2/EM3 if not required. To control retention of these areas, set FRCRAMRETNCTRL or SEQRAMRETNCTRL in SYSCFG\_RADIORAMRETCTRL to the desired value. #### 6.6.2 ECC DMEM0, FRCRAM, and SEQRAM support one bit correction and two bit detection ECC. To enable error detection for DMEM0, set RAMECCCHKEN in SYSCFG\_DMEM0ECCCTRL. To enable error detection for FRCRAM and SEQRAM, set FRCRAMECCCHKEN and SEQRAMECCCHKEN in SYSCFG\_RADIOECCCTRL. To enable auto-correction of one bit errors in DMEM0, set RAMECCEWEN in SYSCFG\_DMEM0ECCCTRL. To enable auto-correction of one bit errors in FRCRAM and SEQRAM, set FRCRAMECCEWEN and SEQRAMECCEWEN in SYSCFG\_RADIOECCCTRL. When ECC error events 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\_DMEM0ECCADDR, SYSCFG\_FRCRAMECCADDR, or SYSCF SEQRAMECCERR depending on the source of the error. The recommend 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 | Туре | Description | |--------|----------------------------------|-------------|--------------------------------------| | 0x000 | SYSCFG_IF | RWH INTFLAG | Interrupt Flag | | 0x004 | SYSCFG_IEN | RW | Interrupt Enable | | 0x010 | SYSCFG_CHIPREVHW | RWH | Chip Revision, Hard-wired | | 0x014 | SYSCFG_CHIPREV | RW | Part Family and Revision Values | | 0x200 | SYSCFG_CTRL | RW | Memory System Control | | 0x208 | SYSCFG_DMEMORETNCTRL | RW | DMEM0 Retention Control | | 0x210 | SYSCFG_DMEM0ECCADDR | RH | DMEM0 ECC Address | | 0x214 | SYSCFG_DMEM0ECCCTRL | RW | DMEM0 ECC Control | | 0x400 | SYSCFG_RADIORAM-<br>RETNCTRL | RW | RADIO RAM Retention Control Register | | 0x408 | SYSCFG_RADIOECCCTRL | RW | RADIO RAM ECC Control Register | | 0x410 | SYSCFG_SEQRAMECCADDR | RH | SEQRAM ECC Address | | 0x414 | SYSCFG_FRCRAMECCADDR | RH | FRCRAM ECC Address | | 0x600 | SYSCFG_ROOTDATA0 | RW | Root Data Register 0 | | 0x604 | SYSCFG_ROOTDATA1 | RW | Root Data Register 1 | | 0x608 | SYSCFG_ROOTLOCKSTATUS | RH | Lock Status | | 0x1000 | SYSCFG_IF_SET | RWH INTFLAG | Interrupt Flag | | 0x1004 | SYSCFG_IEN_SET | RW | Interrupt Enable | | 0x1010 | SYSCFG_CHIPREVHW_SET | RWH | Chip Revision, Hard-wired | | 0x1014 | SYSCFG_CHIPREV_SET | RW | Part Family and Revision Values | | 0x1200 | SYSCFG_CTRL_SET | RW | Memory System Control | | 0x1208 | SYSCFG_DMEM0RETNCTRL_S<br>ET | RW | DMEM0 Retention Control | | 0x1210 | SYSCFG_DMEM0EC-<br>CADDR_SET | RH | DMEM0 ECC Address | | 0x1214 | SYSCFG_DMEM0ECCCTRL_SE<br>T | RW | DMEM0 ECC Control | | 0x1400 | SYSCFG_RADIORAM-<br>RETNCTRL_SET | RW | RADIO RAM Retention Control Register | | 0x1408 | SYSCFG_RADIO-<br>ECCCTRL_SET | RW | RADIO RAM ECC Control Register | | 0x1410 | SYSCFG_SEQRAMEC-<br>CADDR_SET | RH | SEQRAM ECC Address | | 0x1414 | SYSCFG_FRCRAMEC-<br>CADDR_SET | RH | FRCRAM ECC Address | | 0x1600 | SYSCFG_ROOTDATA0_SET | RW | Root Data Register 0 | | 0x1604 | SYSCFG_ROOTDATA1_SET | RW | Root Data Register 1 | | 0x1608 | SYSCFG_ROOTLOCKSTA-<br>TUS_SET | RH | Lock Status | | Offset | Name | Туре | Description | |--------|----------------------------------|-------------|--------------------------------------| | 0x2000 | SYSCFG_IF_CLR | RWH INTFLAG | Interrupt Flag | | 0x2004 | SYSCFG_IEN_CLR | RW | Interrupt Enable | | 0x2010 | SYSCFG_CHIPREVHW_CLR | RWH | Chip Revision, Hard-wired | | 0x2014 | SYSCFG_CHIPREV_CLR | RW | Part Family and Revision Values | | 0x2200 | SYSCFG_CTRL_CLR | RW | Memory System Control | | 0x2208 | SYSCFG_DMEM0RETNCTRL_C<br>LR | RW | DMEM0 Retention Control | | 0x2210 | SYSCFG_DMEM0EC-<br>CADDR_CLR | RH | DMEM0 ECC Address | | 0x2214 | SYSCFG_DMEM0ECCCTRL_CLR | RW | DMEM0 ECC Control | | 0x2400 | SYSCFG_RADIORAM-<br>RETNCTRL_CLR | RW | RADIO RAM Retention Control Register | | 0x2408 | SYSCFG_RADIO-<br>ECCCTRL_CLR | RW | RADIO RAM ECC Control Register | | 0x2410 | SYSCFG_SEQRAMEC-<br>CADDR_CLR | RH | SEQRAM ECC Address | | 0x2414 | SYSCFG_FRCRAMEC-<br>CADDR_CLR | RH | FRCRAM ECC Address | | 0x2600 | SYSCFG_ROOTDATA0_CLR | RW | Root Data Register 0 | | 0x2604 | SYSCFG_ROOTDATA1_CLR | RW | Root Data Register 1 | | 0x2608 | SYSCFG_ROOTLOCKSTA-<br>TUS_CLR | RH | Lock Status | | 0x3000 | SYSCFG_IF_TGL | RWH INTFLAG | Interrupt Flag | | 0x3004 | SYSCFG_IEN_TGL | RW | Interrupt Enable | | 0x3010 | SYSCFG_CHIPREVHW_TGL | RWH | Chip Revision, Hard-wired | | 0x3014 | SYSCFG_CHIPREV_TGL | RW | Part Family and Revision Values | | 0x3200 | SYSCFG_CTRL_TGL | RW | Memory System Control | | 0x3208 | SYSCFG_DMEMORETNCTRL_T<br>GL | RW | DMEM0 Retention Control | | 0x3210 | SYSCFG_DMEM0EC-<br>CADDR_TGL | RH | DMEM0 ECC Address | | 0x3214 | SYSCFG_DMEM0ECCCTRL_T<br>GL | RW | DMEM0 ECC Control | | 0x3400 | SYSCFG_RADIORAM-<br>RETNCTRL_TGL | RW | RADIO RAM Retention Control Register | | 0x3408 | SYSCFG_RADIO-<br>ECCCTRL_TGL | RW | RADIO RAM ECC Control Register | | 0x3410 | SYSCFG_SEQRAMEC-<br>CADDR_TGL | RH | SEQRAM ECC Address | | 0x3414 | SYSCFG_FRCRAMEC-<br>CADDR_TGL | RH | FRCRAM ECC Address | | 0x3600 | SYSCFG_ROOTDATA0_TGL | RW | Root Data Register 0 | | Offset | Name | Туре | Description | |--------|--------------------------------|------|----------------------| | 0x3604 | SYSCFG_ROOTDATA1_TGL | RW | Root Data Register 1 | | 0x3608 | SYSCFG_ROOTLOCKSTA-<br>TUS_TGL | RH | Lock Status | ### 6.6.6 SYSCFG Register Description # 6.6.6.1 SYSCFG\_IF - Interrupt Flag | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|-------------|-------------|----|----|-------------|-------------|----|----|----|----|----|----|----------|----------|------|----|----|----|---|----|---|----|---|---|---|---|-----|-----|---------|--------| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | 0x0 | 0x0 | | • | 0x0 | 0x0 | | | | | | • | 0x0 | 0x0 | | | | | | | | | | • | • | | 0x0 | 0x0 | 0x0 | 0x0 | | Access | | | W. | W. | | | Z. | RW | | | | | | | ₩<br>W | Z. | | | | | | | | | | | | | W. | W. | ZW<br>W | R<br>W | | Name | | | FRCRAMERR2B | FRCRAMERR1B | | | SEQRAMERR2B | SEQRAMERR1B | | | | | | | RAMERR2B | RAMERR1B | | | | | | | | | | | | | SW3 | SW2 | SW1 | SW0 | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:30 | Reserved | To ensure ventions | compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 29 | FRCRAMERR2B | 0x0 | RW | FRCRAM 2-Bit Error Interrupt Flag | | | FRCRAM 2-bit ECC Er | ror Interrupt f | lag. | | | 28 | FRCRAMERR1B | 0x0 | RW | FRCRAM 1-Bit Error Interrupt Flag | | | FRCRAM 1-bit ECC Er | ror Interrupt f | lag. | | | 27:26 | Reserved | To ensure ventions | compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 25 | SEQRAMERR2B | 0x0 | RW | SEQRAM 2-Bit Error Interrupt Flag | | | SEQRAM 2-bit ECC Er | ror Interrupt f | lag. | | | 24 | SEQRAMERR1B | 0x0 | RW | SEQRAM 1-Bit Error Interrupt Flag | | | SEQRAM 1-bit ECC Er | ror Interrupt f | lag. | | | 23:18 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 17 | RAMERR2B | 0x0 | RW | RAM 2-Bit Error Interrupt Flag | | | RAM 2-bit ECC Error Ir | nterrupt flag. | | | | 16 | RAMERR1B | 0x0 | RW | RAM 1-Bit Error Interrupt Flag | | | RAM 1-bit ECC Error Ir | nterrupt flag. | | | | 15:4 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 3 | SW3 | 0x0 | RW | Software Interrupt 3 | | | Software interrupts | | | | | 2 | SW2 | 0x0 | RW | Software Interrupt 2 | | | Software interrupts | | | | | 1 | SW1 | 0x0 | RW | Software Interrupt 1 | | | Software interrupts | | | | | 0 | SW0 | 0x0 | RW | Software Interrupt 0 | | Bit | Name | Reset | Access | Description | |-----|---------------------|-------|--------|-------------| | | Software interrupts | | | | ### 6.6.6.2 SYSCFG\_IEN - Interrupt Enable | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|-------------|-------------|----|----|-------------|-------------|----|----|----|----|----|----|----------|----------|------|----|----|----|---|----|---|---|---|---|---|---|--------|--------|---------|--------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | 000 | 0×0 | | | 000 | 0x0 | | | • | | | | 0×0 | 000 | | | | | | | | | | | | | 0X | 0x0 | 0x0 | 0x0 | | Access | | | ₩<br>M | W. | | | W. | RW | | | | | | | W. | W. | | | | | | | | | | | | | Z<br>N | W<br>M | ZW<br>W | S<br>N | | Name | | | FRCRAMERR2B | FRCRAMERR1B | | | SEQRAMERR2B | SEQRAMERR1B | | | | | | | RAMERR2B | RAMERR1B | | | | | | | | | | | | | SW3 | SW2 | SW1 | SW0 | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|--------------------|----------------------------------------------------------------------| | 31:30 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 29 | FRCRAMERR2B | 0x0 | RW | FRCRAM 2-bit Error Interrupt Enable | | | Set to enable the FRC | RAM2ERR2BI | F Interrupt | | | 28 | FRCRAMERR1B | 0x0 | RW | FRCRAM 1-bit Error Interrupt Enable | | | Set to enable the FRC | RAM2ERR1BI | F Interrupt | | | 27:26 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 25 | SEQRAMERR2B | 0x0 | RW | SEQRAM 2-bit Error Interrupt Enable | | | Set to enable the SEC | RAM2ERR2BI | F Interrupt | | | 24 | SEQRAMERR1B | 0x0 | RW | SEQRAM 1-bit Error Interrupt Enable | | | Set to enable the SEC | RAM2ERR1BI | F Interrupt | | | 23:18 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 17 | RAMERR2B | 0x0 | RW | RAM 2-bit Error Interrupt Enable | | | Set to enable the RAM | /IERR2BIF Inter | rrupt | | | 16 | RAMERR1B | 0x0 | RW | RAM 1-bit Error Interrupt Enable | | | Set to enable the RAM | /IERR1BIF Inter | rrupt | | | 15:4 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 3 | SW3 | 0x0 | RW | Software interrupt 3 | | | Set to enable the Soft | ware Interrupts | | | | 2 | SW2 | 0x0 | RW | Software interrupt 2 | | | Set to enable the Soft | ware Interrupts | | | | 1 | SW1 | 0x0 | RW | Software interrupt 1 | | | Set to enable the Soft | ware Interrupts | | | | 0 | SW0 | 0x0 | RW | Software interrupt 0 | | | Set to enable the Soft | ware Interrupts | | | ### 6.6.6.3 SYSCFG\_CHIPREVHW - Chip Revision, Hard-wired | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|-----------|---|---|---|---|----------|----------|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | • | • | | • | | • | | | • | | | | | 2 | 3 | • | | | | | Ċ | Ocxo | | | | | 5 | <u>-</u> | | | | Access | | | | | | | | | | | | | | | | <u> </u> | 2 | | | | | | Ž | ≥<br>Y | | | | | <u> </u> | 2 | | | | Name | | | | | | | | | | | | | | | | QCIVIEW | | | | | | | ) | L'AIMIL'I | | | | | a CI VM | כ | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------|--------------------|----------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 19:12 | MINOR | 0x0 | RW | Hardwired Chip Revision Minor value | | | Hardwired Chip Revision | Minor signal | value | | | 11:6 | FAMILY | 0x30 | RW | Hardwired Chip Family value | | | Hardwired Chip Family s | ignal value | | | | 5:0 | MAJOR | 0x1 | RW | Hardwired Chip Revision Major value | | | Hardwired Chip Revision | Major signal | value | | # 6.6.6.4 SYSCFG\_CHIPREV - Part Family and Revision Values | Offset | | Bit Position | | | |--------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------------------| | 0x014 | 30<br>28<br>28<br>27<br>27<br>26<br>25<br>25<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27 | 6 8 7 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>11 10 10 0 0 0 7 7 0 0</th> <th>α α α α α α α</th> | 11 10 10 0 0 0 7 7 0 0 | α α α α α α α | | Reset | | 0×0 | 0x0 | 0×0 | | Access | | RW | RW | RW | | Name | | MINOR | FAMILY | MAJOR | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|--------------------|-------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 19:12 | MINOR | 0x0 | RW | Chip Revision Minor value | | | Chip Revision Minor va | alue | | | | 11:6 | FAMILY | 0x0 | RW | Chip Family value | | | Chip Family value | | | | | 5:0 | MAJOR | 0x0 | RW | Chip Revision Major value | | | Chip Revision Major va | alue | | | # 6.6.6.5 SYSCFG\_CTRL - Memory System Control | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|------------------|---|---|---|---|-------------| | 0x200 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | • | | | | | • | | | • | • | • | | | | | | | | | | • | 0x1 | | | | | 0×1 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | | | | ₩<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | RAMECCERRFAULTEN | | | | | ADDRFAULTEN | | Bit | Name | Reset | Access | Description | |------|-----------------------------|----------------|---------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | RAMECCERRFAULTEN | 0x1 | RW | Two bit ECC Error Bus Fault Response Enable | | | When this bit is set, busfa | aults are gene | erated if a 2-bit l | ECC error occurs. | | 4:1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | ADDRFAULTEN | 0x1 | RW | Invalid Address Bus Fault Response Enable | | | When this bit is set, busfa | aults are gene | erated on acces | ses to unmapped parts of system and code address space | ### 6.6.6.6 SYSCFG\_DMEM0RETNCTRL - DMEM0 Retention Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-------------|---| | 0x208 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - | 0 | | Reset | | | | • | | • | | | | | | | • | | | • | • | | • | • | | • | | | | | | • | | • | 000 | 2 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Mar | 3 | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RAMRETNCTRL | | | Bit | Name | Reset | Access | Description | |------|--------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | RAMRETNCTRL | 0x0 | RW | DMEM0 blockset retention control | | | DMEM0 RAM blockset | retention cont | rols in EM23 wi | th full access in EM01. | | | Value | Mode | | Description | | | 0 | ALLON | | None of the RAM blocks powered down | | | 1 | BLK0 | | Power down RAM block 0 | | | 2 | BLK1 | | Power down RAM block 1 | # $6.6.6.7 \ \ SYSCFG\_DMEM0ECCADDR - DMEM0 \ ECC \ Address$ | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|--------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x210 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | • | | | | 2 | e<br>X | | | | | | | | | | | • | | | | | | Access | | | | | | | | | | | | | | | | | ۲ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | א<br>ט | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | • | Ļ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ć | בֿ | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|------------|----------------|-----------------------------| | 31:0 | DMEM0ECCADDR | 0x0 | R | DMEM0 RAM ECC Error Address | | | Indicates the address in | system RAM | at which an EC | C error has occurred. | ### 6.6.6.8 SYSCFG\_DMEM0ECCCTRL - DMEM0 ECC Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------------|----------| | 0x214 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | • | | | | | | | • | • | | | | | | | | • | • | | | • | • | | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RAMECCEWEN | RAMECCEN | | Bit | Name | Reset | Access | Description | |------|---------------------------|-----------------|-------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | RAMECCEWEN | 0x0 | RW | RAM ECC Error Writeback Enable | | | When set, 1-bit ECC erro | ors will be con | rected and writte | en back to RAM when encountered. | | 0 | RAMECCEN | 0x0 | RW | RAM ECC Enable | | | When set, this bit enable | s the generat | ion and checkin | g of ECC for RAM. | ### 6.6.6.9 SYSCFG\_RADIORAMRETNCTRL - RADIO RAM Retention Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------------|---|---|---|---|---|---|----------------| | 0x400 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | • | | | • | • | • | • | | | | | | | | • | • | • | | | | | | 0x0 | | | • | | • | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | Z. | | | | | | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | FRCRAMRETNCTRL | | | | | | | SEQRAMRETNCTRL | | Bit | Name | Reset | Access | Description | |------|--------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 8 | FRCRAMRETNCTRL | 0x0 | RW | FRCRAM Retention Control | | | FRC RAM power-down | in EM23 with | full access in EN | 101 | | | Value | Mode | | Description | | | 0 | ALLON | | FRCRAM not powered down | | | 1 | ALLOFF | | Power down FRCRAM | | 7:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | SEQRAMRETNCTRL | 0x0 | RW | SEQRAM Retention Control | | | SEQUENCER RAM pov | ver-down in E | M23 with full acc | cess 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.10 SYSCFG\_RADIOECCCTRL - RADIO RAM ECC Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---------------|-------------|---|---|---|---|---|---|---------------|-------------| | 0x408 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | • | | | | | | • | | | • | | | | | | • | 0x0 | 000 | | | • | • | • | | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | RW | RW | | | | | | | R<br>W | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | FRCRAMECCEWEN | FRCRAMECCEN | | | | | | | SEQRAMECCEWEN | SEQRAMECCEN | | Bit | Name | Reset | Access | Description | |-------|------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 9 | FRCRAMECCEWEN | 0x0 | RW | FRCRAM ECC Error Writeback Enable | | | FRC ECC Error Writebac | ck Enable. Wi | nen set, errors v | vill be corrected when encountered. | | 8 | FRCRAMECCEN | 0x0 | RW | FRCRAM ECC Enable | | | FRCRAM ECC Enable. | | | | | 7:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | SEQRAMECCEWEN | 0x0 | RW | SEQRAM ECC Error Writeback Enable | | | SEQRAM ECC Error Wr | iteback Enabl | e. When set, er | rors will be corrected when encountered. | | 0 | SEQRAMECCEN | 0x0 | RW | SEQRAM ECC Enable | | | SEQRAM ECC Enable. | | | | ### 6.6.6.11 SYSCFG\_SEQRAMECCADDR - SEQRAM ECC Address | Offset | Bit Position | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x410 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Reset | 000 | | Access | α | | Name | SEQRAMECCADDR | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|--------------------------------------------------------------|-------|--------|--------------------|--|--|--|--|--|--|--|--| | 31:0 | SEQRAMECCADDR | 0x0 | R | SEQRAM ECC Address | | | | | | | | | | | Indicates the address in SEQRAM at which ECC error occurred. | | | | | | | | | | | | ### 6.6.6.12 SYSCFG\_FRCRAMECCADDR - FRCRAM ECC Address | Offset | Bit Position | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x414 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Reset | 0×0 | | Access | α | | Name | FRCRAMECCADDR | | Bit | Name | Reset | Access | Description | | | | | | | | | | | |------|-----------------------------------------------------------------|-------|--------|--------------------------|--|--|--|--|--|--|--|--|--|--| | 31:0 | FRCRAMECCADDR | 0x0 | R | FRCRAM ECC Error Address | | | | | | | | | | | | | Indicates the address in FRCRAM at which an ECC error occurred. | | | | | | | | | | | | | | ### 6.6.6.13 SYSCFG\_ROOTDATA0 - Root Data Register 0 | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|-------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | 0x600 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | စ | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | | • | | | | | | | | | | | | 2 | 3 | | | • | | • | | • | | | • | | | • | • | | | Access | | | | | | | | | | | | | | | | 2 | 2 | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | F 4 C | <u> </u> | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|-----------------------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--|--|--| | 31:0 | DATA | 0x0 | RW | Data | | | | | | | | | | | Generic data space for user to pass to root, e.g., address of struct in mem | | | | | | | | | | | | # 6.6.6.14 SYSCFG\_ROOTDATA1 - Root Data Register 1 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|------------|----|----|----|----|----|----|----|----|----|----|----|------|----------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x604 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | 2 | 2 | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | | Name | | | | DATA RW 0) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | | |------|-----------------------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--|--|--|--|--| | 31:0 | DATA | 0x0 | RW | Data | | | | | | | | | | | | | Generic data space for user to pass to root, e.g., address of struct in mem | | | | | | | | | | | | | | # 6.6.6.15 SYSCFG\_ROOTLOCKSTATUS - Lock Status | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|--------------|----|----|----|---------------|---------------|--------------|-------------|-------------|----|---|----|----|---|----|---|-------------|---|---|---|--------------|---|---------|--------------|---------| | 0x608 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | | • | 0x1 | | | • | 0x1 | )<br>K | 0×1 | 0X1 | 0×1 | | | | | | | | X | | | | 0x0 | | 0x1 | 0 <u>×</u> 1 | 0×1 | | Access | | | | | | | | 2 | | | | 2 | 22 | 22 | 22 | 2 | | | | | | | | 2 | | | | 22 | | 2 | 22 | 22 | | Name | | | | | | | | RADIODBGLOCK | | | | USERDBGAPLOCK | USERSPNIDLOCK | USERSPIDLOCK | USERNIDLOCK | USERDBGLOCK | | | | | | | | ROOTDBGLOCK | | | | ROOTMODELOCK | | MFRLOCK | REGLOCK | BUSLOCK | | Bit | Name | Reset | Access | Description | | | | | | | | | | |-------|---------------------------------|--------------|----------------------------------------------------------------------|----------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:25 | Reserved | To ensure co | future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 24 | RADIODBGLOCK | 0x1 | R | Radio Debug Lock | | | | | | | | | | | | Locked when 1; unlocked when 0. | | | | | | | | | | | | | | 23:21 | Reserved | To ensure co | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Co | | | | | | | | | | | 20 | USERDBGAPLOCK | 0x1 | R | User Debug Access Port Lock | | | | | | | | | | | | Locked when 1; unlocked when 0. | | | | | | | | | | | | | | 19 | USERSPNIDLOCK | 0x1 | R | User Secure Non-invasive Debug Lock | | | | | | | | | | | | Locked when 1; unlocked when 0. | | | | | | | | | | | | | | 18 | USERSPIDLOCK | 0x1 | R | User Secure Invasive Debug Lock | | | | | | | | | | | | Locked when 1; unlocked when 0. | | | | | | | | | | | | | | 17 | USERNIDLOCK | 0x1 | R | User Non-invasive Debug Lock | | | | | | | | | | | | Locked when 1; unlocked when 0. | | | | | | | | | | | | | | 16 | USERDBGLOCK | 0x1 | R | User Invasive Debug Lock | | | | | | | | | | | | Locked when 1; unlocked | d when 0. | | | | | | | | | | | | | 15:9 | Reserved | To ensure co | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 8 | ROOTDBGLOCK | 0x1 | R | Root Debug Lock | | | | | | | | | | | | Locked when 1; unlocked | d when 0. | | | | | | | | | | | | | 7:5 | Reserved | To ensure co | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Co | | | | | | | | | | | 4 | ROOTMODELOCK | 0x0 | R | Root Mode Lock | | | | | | | | | | | | Locked when 1; unlocked when 0. | | | | | | | | | | | | | | 3 | Reserved | To ensure co | ompatibility with | future devices, always write bits to 0. More information in 1.2 Co | | | | | | | | | | | 2 | MFRLOCK | 0x1 | R | Manufacture Lock | | | | | | | | | | | | Locked when 1; unlocked when 0. | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-----|---------------------|--------------|--------|---------------| | 1 | REGLOCK | 0x1 | R | Register Lock | | | Locked when 1; unlo | cked when 0. | | | | 0 | BUSLOCK | 0x1 | R | Bus Lock | | | Locked when 1; unlo | cked when 0. | | | # 6.7 MSC Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|----------------------|------|-----------------------------------------| | 0x000 | MSC_IPVERSION | R | IP version ID | | 0x008 | MSC_READCTRL | RW | Read Control Register | | 0x00C | MSC_WRITECTRL | RW | Write Control Register | | 0x010 | MSC_WRITECMD | w | Write Command Register | | 0x014 | MSC_ADDRB | RW | Page Erase/Write Address Buffer | | 0x018 | MSC_WDATA | RW | 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_MISCLOCKWORD | 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 | | 0x1000 | MSC_IPVERSION_SET | R | IP version ID | | 0x1008 | MSC_READCTRL_SET | RW | Read Control Register | | 0x100C | MSC_WRITECTRL_SET | RW | Write Control Register | | 0x1010 | MSC_WRITECMD_SET | W | Write Command Register | | 0x1014 | MSC_ADDRB_SET | RW | Page Erase/Write Address Buffer | | 0x1018 | MSC_WDATA_SET | RW | 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_MISCLOCKWORD_SET | RW | Mass erase and User data page lock word | | 0x1050 | MSC_PWRCTRL_SET | RW | Power control register | | 0x1120 | MSC_PAGELOCK0_SET | RW | Main space page 0-31 lock word | | 0x1124 | MSC_PAGELOCK1_SET | RW | Main space page 32-63 lock word | | 0x2000 | MSC_IPVERSION_CLR | R | IP version ID | | 0x2008 | MSC_READCTRL_CLR | RW | Read Control Register | | 0x200C | MSC_WRITECTRL_CLR | RW | Write Control Register | | OffsetNameTypeDescription0x2010MSC_WRITECMD_CLRWWrite Command Regist0x2014MSC_ADDRB_CLRRWPage Erase/Write Addr0x2018MSC_WDATA_CLRRWWrite Data Register0x201CMSC_STATUS_CLRRHStatus Register0x2020MSC_IF_CLRRWHInterrupt Flag Register0x2024MSC_IEN_CLRRWInterrupt Enable Regist0x2034MSC_USERDATASIZE_CLRRUser Data Region Size0x2038MSC_CMD_CLRWCommand Register0x203CMSC_LOCK_CLRWConfiguration Lock Reg0x2040MSC_MISCLOCKWORD_CLRRWMass erase and User of0x2050MSC_PWRCTRL_CLRRWPower control register0x2120MSC_PAGELOCKO_CLRRWMain space page 0-310x2124MSC_PAGELOCK1_CLRRWMain space page 32-630x3000MSC_IPVERSION_TGLRIP version ID | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 0x2014MSC_ADDRB_CLRRWPage Erase/Write Addr0x2018MSC_WDATA_CLRRWWrite Data Register0x201CMSC_STATUS_CLRRHStatus Register0x2020MSC_IF_CLRRWHInterrupt Flag Register0x2024MSC_IEN_CLRRWInterrupt Enable Regist0x2034MSC_USERDATASIZE_CLRRUser Data Region Size0x2038MSC_CMD_CLRWCommand Register0x203CMSC_LOCK_CLRWConfiguration Lock Reg0x2040MSC_MISCLOCKWORD_CLRRWMass erase and User of0x2050MSC_PWRCTRL_CLRRWPower control register0x2120MSC_PAGELOCK0_CLRRWMain space page 0-310x2124MSC_PAGELOCK1_CLRRWMain space page 32-63 | | | 0x2018MSC_WDATA_CLRRWWrite Data Register0x201CMSC_STATUS_CLRRHStatus Register0x2020MSC_IF_CLRRWHInterrupt Flag Register0x2024MSC_IEN_CLRRWInterrupt Enable Regist0x2034MSC_USERDATASIZE_CLRRUser Data Region Size0x2038MSC_CMD_CLRWCommand Register0x203CMSC_LOCK_CLRWConfiguration Lock Reg0x2040MSC_MISCLOCKWORD_CLRRWMass erase and User of0x2050MSC_PWRCTRL_CLRRWPower control register0x2120MSC_PAGELOCK0_CLRRWMain space page 0-310x2124MSC_PAGELOCK1_CLRRWMain space page 32-63 | ess Buffer | | 0x201CMSC_STATUS_CLRRHStatus Register0x2020MSC_IF_CLRRWHInterrupt Flag Register0x2024MSC_IEN_CLRRWInterrupt Enable Regist0x2034MSC_USERDATASIZE_CLRRUser Data Region Size0x2038MSC_CMD_CLRWCommand Register0x203CMSC_LOCK_CLRWConfiguration Lock Reg0x2040MSC_MISCLOCKWORD_CLRRWMass erase and User of0x2050MSC_PWRCTRL_CLRRWPower control register0x2120MSC_PAGELOCK0_CLRRWMain space page 0-310x2124MSC_PAGELOCK1_CLRRWMain space page 32-63 | | | 0x2020MSC_IF_CLRRWHInterrupt Flag Register0x2024MSC_IEN_CLRRWInterrupt Enable Regist0x2034MSC_USERDATASIZE_CLRRUser Data Region Size0x2038MSC_CMD_CLRWCommand Register0x203CMSC_LOCK_CLRWConfiguration Lock Reg0x2040MSC_MISCLOCKWORD_CLRRWMass erase and User of0x2050MSC_PWRCTRL_CLRRWPower control register0x2120MSC_PAGELOCK0_CLRRWMain space page 0-310x2124MSC_PAGELOCK1_CLRRWMain space page 32-63 | | | 0x2024 MSC_IEN_CLR RW Interrupt Enable Regist 0x2034 MSC_USERDATASIZE_CLR R User Data Region Size 0x2038 MSC_CMD_CLR W Command Register 0x203C MSC_LOCK_CLR W Configuration Lock Region Size 0x203C MSC_LOCK_CLR W Configuration Lock Region Size 0x2040 MSC_MISCLOCKWORD_CLR RW Mass erase and User of the power control register 0x2050 MSC_PWRCTRL_CLR RW Power control register 0x2120 MSC_PAGELOCK0_CLR RW Main space page 0-31 0x2124 MSC_PAGELOCK1_CLR RW Main space page 32-63 | | | 0x2034 MSC_USERDATASIZE_CLR R User Data Region Size 0x2038 MSC_CMD_CLR W Command Register 0x203C MSC_LOCK_CLR W Configuration Lock Reg 0x2040 MSC_MISCLOCKWORD_CLR RW Mass erase and User of the control register 0x2050 MSC_PWRCTRL_CLR RW Power control register 0x2120 MSC_PAGELOCK0_CLR RW Main space page 0-31 0x2124 MSC_PAGELOCK1_CLR RW Main space page 32-63 | | | 0x2038 MSC_CMD_CLR W Command Register 0x203C MSC_LOCK_CLR W Configuration Lock Register 0x2040 MSC_MISCLOCKWORD_CLR RW Mass erase and User of the control register 0x2050 MSC_PWRCTRL_CLR RW Power control register 0x2120 MSC_PAGELOCK0_CLR RW Main space page 0-31 0x2124 MSC_PAGELOCK1_CLR RW Main space page 32-63 | er | | 0x203C MSC_LOCK_CLR W Configuration Lock Reg 0x2040 MSC_MISCLOCKWORD_CLR RW Mass erase and User of the control register 0x2050 MSC_PWRCTRL_CLR RW Power control register 0x2120 MSC_PAGELOCK0_CLR RW Main space page 0-31 0x2124 MSC_PAGELOCK1_CLR RW Main space page 32-63 | Register | | 0x2040 MSC_MISCLOCKWORD_CLR RW Mass erase and User of the control | | | 0x2050 MSC_PWRCTRL_CLR RW Power control register 0x2120 MSC_PAGELOCK0_CLR RW Main space page 0-31 0x2124 MSC_PAGELOCK1_CLR RW Main space page 32-63 | ister | | 0x2120 MSC_PAGELOCK0_CLR RW Main space page 0-31 0x2124 MSC_PAGELOCK1_CLR RW Main space page 32-63 | ata page lock word | | 0x2124 MSC_PAGELOCK1_CLR RW Main space page 32-63 | | | | lock word | | 0x3000 MSC_IPVERSION_TGL R IP version ID | lock word | | | | | 0x3008 MSC_READCTRL_TGL RW Read Control Register | | | 0x300C MSC_WRITECTRL_TGL RW Write Control Register | | | 0x3010 MSC_WRITECMD_TGL W Write Command Regist | er | | 0x3014 MSC_ADDRB_TGL RW Page Erase/Write Addr | ess Buffer | | 0x3018 MSC_WDATA_TGL RW Write Data Register | | | 0x301C MSC_STATUS_TGL RH Status Register | | | 0x3020 MSC_IF_TGL RWH Interrupt Flag Register | | | 0x3024 MSC_IEN_TGL RW Interrupt Enable Regist | er | | 0x3034 MSC_USERDATASIZE_TGL R User Data Region Size | Register | | 0x3038 MSC_CMD_TGL W Command Register | | | 0x303C MSC_LOCK_TGL W Configuration Lock Reg | jister | | 0x3040 MSC_MISCLOCKWORD_TGL RW Mass erase and User d | ata page lock word | | 0x3050 MSC_PWRCTRL_TGL RW Power control register | | | 0x3120 MSC_PAGELOCK0_TGL RW Main space page 0-31 | | | 0x3124 MSC_PAGELOCK1_TGL RW Main space page 32-63 | lock word | # 6.8 MSC Register Description # 6.8.1 MSC\_IPVERSION - IP version ID | Offset | Bit Position | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x000 | 33 34 35 36 37 38 38 39 30 30 30 31 41 42 43 44 45 45 46 47 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×1 | | Access | α | | Name | IPVERSION | | Bit | Name | Reset | Access | Description | |------|------------------------------------------|-------|--------|------------------------------------------------------------------| | 31:0 | IPVERSION | 0x1 | R | IP Version ID | | | The read only IPVER modules with differe | • | | or this module. There may be minor software changes required for | ## 6.8.2 MSC\_READCTRL - Read Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|-----|----------|----|----|----|------|------|----|----|-----------|---|----|---|---|---|---|---|---|---|---|---|---| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | | | • | | • | • | 5 | 7<br>N | | | | | | | | 000 | | | | | | | | | | | | | | Access | | | | | | | | | | | | 2 | | | | | | | | \<br>N | | | | | | | | | | | | | | Name | | | | | | | | | | | U C | <u> </u> | | | | | | | | DOUTBUFEN | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------------------------------------------------|--------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:22 | Reserved | To ensur<br>ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 21:20 | MODE | 0x2 | RW | Read Mode | | | vvii <del>e</del> n chanding i | o a moner neouen | | | | | switched to the hi | igher frequency. W | /hen changing t | must be set to a large number of wait states before the core clock is o a lower frequency, this register should be set to a lower number of completed The maximum frequency for each wait state setting is listed | | | switched to the hi wait states after t | igher frequency. W | /hen changing t | o a lower frequency, this register should be set to a lower number of | | | switched to the hi<br>wait states after the<br>in the datasheet. | igher frequency. Whe frequency trans | /hen changing t | o a lower frequency, this register should be set to a lower number of completed The maximum frequency for each wait state setting is listed | | | 2 | WS2 | Two wait-states inserted for eatch fetch or read transfer | |-------|----------|---------------------------------------|------------------------------------------------------------------------| | | 3 | WS3 | Three wait-states inserted for eatch fetch or read transfer | | 19:13 | Reserved | To ensure compatibility with ventions | h future devices, always write bits to 0. More information in 1.2 Con- | Flash dout buffer prefetch enable. Once disabled, every read will be a new flash read operation even the new read from the same flash entry as previous read (prefetch hit). Flash dout pipeline buffer enable | 11:0 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Con- | |------|----------|---------------------------------------------------------------------------------------------------| | | | ventions | **DOUTBUFEN** 0x0 RW 12 # 6.8.3 MSC\_WRITECTRL - Write Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---------|---|---------------|--------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | | | | | • | | | • | • | • | | • | | | | • | | | | | • | • | 000 | | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>N | | ZW<br>W | S<br>N | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LPWRITE | | IRQERASEABORT | WREN | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 3 | LPWRITE | 0x0 | RW | Low-Power Erase | | | When set, user write tir | nes might do | uble while redu | cing current consumption | | 2 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1 | IRQERASEABORT | 0x0 | RW | Abort Page Erase on Interrupt | | | When this bit is set to 1 tor from flash will halt the | | -M33 interrupt a | aborts any current page erase operation. Executing that interrupt vec- | | 0 | WREN | 0x0 | RW | Enable Write/Erase Controller | | | When this bit is set, the | MSC User v | vrite and erase | functionality is enabled | # 6.8.4 MSC\_WRITECMD - Write Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|------------|---|----|---|------------|---|---|------------|---|---|----------|-----------|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - | 0 | | Reset | | • | • | | • | | | • | | | | | • | | | | | | | 0X0 | | | | 000 | | | 000 | | • | 0x0 | 0x0 | | | Access | | | | | | | | | | | | | | | | | | | | > | | | | > | | | > | | | > | × | | | Name | | | | | | | | | | | | | | | | | | | | CLEARWDATA | | | | ERASEMAINO | | | ERASEABORT | | | WRITEEND | ERASEPAGE | | | Bit | Name | Reset | Access | Description | |-------|----------------------------------------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:13 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 12 | CLEARWDATA | 0x0 | W | Clear WDATA state | | | Will set WDATAREADY | and DMA req | uest. Should onl | y be used when no write is active. | | 11:9 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 8 | ERASEMAIN0 | 0x0 | W | Mass erase region 0 | | | Initiate mass erase of fla<br>from software, clear bit 0 | • | | C_MASSLOCK must be unlocked. To completely prevent access (MLW) | | 7:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | ERASEABORT | 0x0 | W | Abort erase sequence | | | Writing to this bit will abo | ort an ongoing | erase sequence | е. | | 4:3 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 2 | WRITEEND | 0x0 | W | End Write Mode | | | Write 1 to abort a write of | ommand. | | | | 1 | ERASEPAGE | 0x0 | W | Erase Page | | | Erase any user defined pmust be set in order to u | • | - | DDRB register. The WREN bit in the MSC_WRITECTRL register | | 0 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | # 6.8.5 MSC\_ADDRB - Page Erase/Write Address Buffer | Offset | Bit Position | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x014 | 33 34 35 36 37 38 38 48 49 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×0 | | Access | R<br>≪ | | Name | ADDRB | | Bit | Name | Reset | Access | Description | |------|---------------------------------------------------------|-------|--------------------|----------------------------------------------------------------| | 31:0 | ADDRB | 0x0 | RW | Page Erase or Write Address Buffer | | | This register holds the s<br>MSB bit is not ignored for | • | s for the erase of | or write operation. Address should be word aligned address.The | # 6.8.6 MSC\_WDATA - Write Data Register | Offset | Bit Position | | |--------|---------------------------------------|---| | 0x018 | 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | 0 | | Reset | 0<br>×0 | | | Access | S | | | Name | DATAW | | | Bit | Name | Reset | Access | Description | |------|------------------------------------------------|-------|--------|-------------------------------------------------------------------------| | 31:0 | DATAW | 0x0 | RW | Write Data | | | The data to be written to MSC_STATUS is set.Th | | _ | This register must be written when the WDATAREADY bit of<br>rrite mask. | # 6.8.7 MSC\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|------------------|----|--------|----|----|-------|----|----|----|----|----|----|----|---------|------|----|----|----|---|----|---|---|---|---------|---------|--------------|------------|---------|--------|------| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 2 | SY. | | 0x1 | | 1 | 0×0 | | | • | | | | • | 0×0 | | | • | | | | | ' | | 000 | 0x0 | 0x0 | 0x1 | 0x0 | 0x0 | 0x0 | | Access | | ۵ | ۷ | | 2 | | | 2 | | | | | | | | 2 | | | | | | | | | | 2 | 2 | 22 | 22 | 22 | 2 | ~ | | Name | | | TWACTCABUTALCOON | | WREADY | | | PWRON | | | | | | | | REGLOCK | | | | | | | | | | TIMEOUT | PENDING | ERASEABORTED | WDATAREADY | INVADDR | LOCKED | BUSY | | Bit | Name | Reset | Access | Description | |-------|-------------------------------------------------------|--------------------|---------------------|-----------------------------------------------------------------------------| | 31:28 | PWRUPCKBDFAIL-<br>COUNT | 0x0 | R | Flash power up checkerboard pattern chec | | | This field tells how ma | ny times chec | kboard pattern | check fail occured after a reset sequence. | | 27 | WREADY | 0x1 | R | Flash Write Ready | | | When this bit is set, fla | sh has comp | leted the power | up sequence and is ready for write/erase commands. | | 26:25 | Reserved | To ensure ventions | e compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | 24 | PWRON | 0x0 | R | Flash Power On Status | | | When this bit is set, fla | sh is powere | d on. If zero, flas | sh is powered off and reads from flash return indeterminate data. | | 23:17 | Reserved | To ensure ventions | e compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | 16 | REGLOCK | 0x0 | R | Register Lock Status | | | Indicates the current s | tatus of regist | er lock | | | | Value | Mode | | Description | | | 0 | UNLOCK | ED | Register lock is unlocked | | | 1 | LOCKED | | Register lock is locked. | | 15:7 | Reserved | To ensure ventions | e compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | 6 | TIMEOUT | 0x0 | R | Write Command Timeout | | | When this bit is set, it is cleared automatically was | | | mmand has completed due to a write buffer timeout. This bit is s initiated. | | 5 | PENDING | 0x0 | R | Write Command In Queue | | | When this bit is set, a find is set. | flash operatio | n has been requ | lested but not yet started. New commands are ignored when PEND- | | 4 | ERASEABORTED | 0x0 | R | Erase Operation Aborted | | | When MSC_WRITECT progress. | TRL_IRQERA | SEABORT = 1, | this bit is set because an interrupt has aborted the erase operation in | | Bit | Name | Reset | Access | Description | |-----|--------------------------|-----------------|-------------------|--------------------------------------------------------------------------------------------------------------| | 3 | WDATAREADY | 0x1 | R | WDATA Write Ready | | | | | | read by MSC Flash Write Controller and the register may be updated bit is cleared when writing to MSC_WDATA. | | 2 | INVADDR | 0x0 | R | Invalid Write Address or Erase Page | | | When this bit is set, so | ftware has att | empted to load | an invalid (unmapped) address into the MSC_ADDRB register. | | 1 | LOCKED | 0x0 | R | Access Locked | | | When set, the last eras | se or write wa | s aborted due to | o erase/write access constraints. | | 0 | BUSY | 0x0 | R | Erase/Write Busy | | | When set, an erase or | write operation | on is in progress | and new commands are ignored. | # 6.8.8 MSC\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---------|--------|---|---|---|---|---|---------|---------|-------| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | ' | • | ' | | • | | • | | • | | • | ' | ' | ' | • | • | • | • | | | 0x0 | 0x0 | | • | ' | • | | 0×0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | ZW<br>W | W. | | | | | | RW | ZW<br>W | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | PWROFF | PWRUPF | | | | | | WDATAOV | WRITE | ERASE | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|--------------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 9 | PWROFF | 0x0 | RW | Flash Power Off Sequence Complete Flag | | | Set after MSC_CMD.PV | VROFF receiv | ed, flash power | ed off complete | | 8 | PWRUPF | 0x0 | RW | Flash Power Up Sequence Complete Flag | | | Set after MSC_CMD.PV | VRUP receive | d, flash powered | d up complete and ready for read/write | | 7:3 | Reserved | To ensure ventions | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 2 | WDATAOV | 0x0 | RW | Host write buffer overflow | | | If set, flash controller wr | ite buffer over | flow detected | | | 1 | WRITE | 0x0 | RW | Host Write Done Interrupt Read Flag | | | Set when a write is done | е | | | | 0 | ERASE | 0x0 | RW | Host Erase Done Interrupt Read Flag | | | Set when erase is done | | | | # 6.8.9 MSC\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|--------|--------|---|---|---|---|---|---------|-------|--------| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | ' | | ' | | | | | | | ' | | ' | • | | | ' | | | 0x0 | 0X0 | | | | • | • | 0×0 | 0×0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | RW | R<br>W | | | | | | RW | W. | R<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | PWROFF | PWRUPF | | | | | | WDATAOV | WRITE | ERASE | | Reserved PWROFF interrupt enable | ventions | | future devices, always write bits to 0. More information in 1.2 Con-<br>Flash Power Off Seq done irq enable | |----------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | | 0x0 | RW | Flash Power Off Seg done irg enable | | interrupt enable | | | | | | | | | | PWRUPF | 0x0 | RW | Flash Power Up Seq done irq enable | | interrupt enable | | | | | Reserved | To ensure co | mpatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | WDATAOV | 0x0 | RW | write data buffer overflow irq enable | | interrupt enable | | | | | WRITE | 0x0 | RW | Write Done Interrupt enable | | interrupt enable | | | | | ERASE | 0x0 | RW | Erase Done Interrupt enable | | interrupt enable | | | | | | interrupt enable Reserved WDATAOV interrupt enable WRITE interrupt enable ERASE | interrupt enable Reserved To ensure conventions WDATAOV 0x0 interrupt enable WRITE 0x0 interrupt enable ERASE 0x0 | interrupt enable Reserved To ensure compatibility with ventions WDATAOV 0x0 RW interrupt enable WRITE 0x0 RW interrupt enable ERASE 0x0 RW | # 6.8.10 MSC\_USERDATASIZE - User Data Region Size Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|-------------------|--------------|---|---| | 0x034 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | | | • | • | • | | | | | | | | | | | | | | | | | | • | 2 | ,<br>1 | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ٥ | ۲ | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TCIO V F V CICLIO | USERDATASIZE | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|-------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 5:0 | USERDATASIZE | 0x4 | R | User Data Size | | | This field determines use | er data region | size. SIZE = 2 | 56B * USERDATASIZE. | # 6.8.11 MSC\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|---|---|---|---|---|---|--------|---|---|---|-------| | 0x038 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0x0 | | | | 000 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | | | | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | PWROFF | | | | PWRUP | | Bit | Name | Reset | Access | Description | |------|----------------------------|---------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 4 | PWROFF | 0x0 | W | Flash power off/sleep command | | | | | | should execute from RAM afterwards. Read from flash after flash or. To power up, either set CMD.PWRUP bit or try read from flash. | | 3:1 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | PWRUP | 0x0 | W | Flash Power Up Command | | | Write to this bit to power | up the Flash. | IRQ PWRUPF | will be fired when power up sequence completed. | # 6.8.12 MSC\_LOCK - Configuration Lock Register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x03C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | 3 | 7 | _ | 0 | | Reset | | | • | • | | | • | | | | | | • | ' | | | | | • | • | | | | Š | 2 | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | į | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | נ | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------|----------------------|-----------------|------------------------------------------------------------------------------------------------------------| | 31:16 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0x0 | W | Configuration Lock | | | • | | | access to MSC_CTRL, MSC_READCTRL, MSC_WRITECTRL. Write ne register, bit 0 is set when the lock is enabled. | | | Value | Mode | | Description | | | | | | · | | | 0 | LOCK | | Key to lock the register lock | # 6.8.13 MSC\_MISCLOCKWORD - Mass erase and User data page lock word | Offset | Bit Position | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------| | 0x040 | 30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40 | 4 % % T 0 | | Reset | | × × × | | Access | | RW W | | Name | | UDLOCKBIT | | Bit | Name | Reset | Access | Description | |------|--------------------|-------------------|-----------------|---------------------------------------------------------------------------| | 31:5 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 4 | UDLOCKBIT | 0x1 | RW | User Data Lock | | | Zero means host ca | n write to the us | ser data area. | Host is only allowed to write one. Root and debug can clear this bit. | | 3:1 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 0 | MELOCKBIT | 0x1 | RW | Mass Erase Lock | | | Zero means host ca | n mass erase th | ne main space | . Host is only allowed to write one. Root and debug can clear this bit. | # 6.8.14 MSC\_PWRCTRL - Power control register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|-------------|----------|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|------------------|---|---|-------------------|------------------| | 0x050 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | | | | | | | | \<br>\<br>\ | 2 40 | | | | | | | | | | | | | | | 0x0 | | | 0x1 | 0x0 | | Access | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | RW | | | RW | RW | | Name | | | | | | | | | | | | DWPOFFDI V | | | | | | | | | | | | | | | | PWROFFENTRYAGAIN | | | PWROFFONEM1PENTRY | PWROFFONEM1ENTRY | | D:4 | Nome | Dooot | A | Description | |-------|---------------------------------------------------------------|-------------------------|-------------------|----------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 31:24 | Reserved | To ensure c<br>ventions | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 23:16 | PWROFFDLY | 0x10 | RW | Power down delay | | | Defines delay cycles before lay is 64 * PWROFFDLY | | | Vorks together with PWROFFENTRYAGAIN bit. The power off de- | | 15:5 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | PWROFFENTRYAGAIN | 0x0 | RW | POWER down flash again in EM1/EM1p | | | If enabled, flash will enter<br>no flash activities occur for | | | WEROFFONEM1ENTRY/POWEROFFONEM1PENTRY is set and ROFFSTDLY. | | 3:2 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 1 | PWROFFONEM1PEN-<br>TRY | 0x1 | RW | Power down Flash macro when enter EM1P | | | If enabled, flash will be in | sleep mode | when entering E | M1P (radio-only sleep). | | 0 | PWROFFONEM1EN-<br>TRY | 0x0 | RW | Power down Flash macro when enter EM1 | | | If enabled, flash will be in | sleep mode | when entering E | M1. | ## 6.8.15 MSC\_PAGELOCK0 - Main space page 0-31 lock word | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|--------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x120 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | œ | 7 | ဖ | 2 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | 2 | 3 | | • | | l | | l | | | | | | | | | | | Access | | | | | | | | | | | | | | | | 2 | 2 | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | FIGNO | LOCABI | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------|-------|--------|---------------| | 31:0 | LOCKBIT | 0x0 | RW | page lock bit | 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.16 MSC\_PAGELOCK1 - Main space page 32-63 lock word | Offset | Bit Position | | | | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x124 | 33 34 36 37 38 39 30 30 31 31 32 33 34 35 36 37 38 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | | | | | | | | | | | | | | Reset | 0×0 | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | Name | LOCKBIT | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------|-------|--------|---------------| | 31:0 | LOCKBIT | 0x0 | RW | page lock bit | 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 ## 7. DBG - Debug Interface ### **Quick Facts** ### What? The Debug Interface is used to program and debug EFR32xG22 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. EFR32xG22 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 EFR32xG22 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\_DBGROUTEPEN 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 V3.5 (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 (TCLK): Functions as a sample clock for the trace. This pin is disabled after reset. - Trace Data 0 (TD0): The trace data pin provides the compressed trace stream. This pin is 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 EM2DBGEN bit in the EMU\_CTRL register. Setting EM2DBGEN 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. # 7.4 DBG Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|---------------|------|----------------------| | 0x1000 | DBG_DCIWDATA | RW | Write Data | | 0x1004 | DBG_DCIRDATA | R | Read Data | | 0x1008 | DBG_DCISTATUS | R | Status | | 0x10FC | DBG_DCIID | R | Identification | | 0x1110 | DBG_SYSCOM0 | R | Communication Status | | 0x1114 | DBG_SYSCOM1 | R | Communication Status | | 0x1120 | DBG_SYSPWR0 | R | Power Status | | 0x1130 | DBG_SYSCLK0 | R | Clocking Status | | 0x11FC | DBG_SYSID | R | Identification | ## 7.5 DBG Register Description # 7.5.1 DBG\_DCIWDATA - Write Data | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----------|----|----|----|----|----|----|----|----|----|----|----|---|----|-----------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | 0x1000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | 0X0<br>> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | NA<br>OX | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | V L V C/V | <u> </u> | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|--------------|--------|----------------------| | 31:0 | WDATA | 0x0 | RW | Challenge Write Data | | | Data Sent to the Challen | ge Interface | | | # 7.5.2 DBG\_DCIRDATA - Read Data | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-----------------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x1004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 000 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | <u>×</u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | \<br>F | ָּבְּ<br>בְּבְּ | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------|----------|---------------------| | 31:0 | RDATA | 0x0 | R | Challenge Read Data | | | Data Response from the | Challenge Ir | nterface | | # 7.5.3 DBG\_DCISTATUS - Status | Offset | Bit Position | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | 0x1008 | 8 9 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 <t< th=""><th>0</th></t<> | 0 | | Reset | | 000 | | Access | ٥ | <u>«</u> | | Name | CI POST | (') | | Bit | Name | Reset | Access | Description | |------|---------------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 8 | RDATAVALID | 0x0 | R | Read Data Valid | | | Response from the chall | enge interface | e is valid. Cleare | ed on a read of DCIRDATA. | | 7:1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | WPENDING | 0x0 | R | Write Pending | | | Write Request to the Chaserted. | allenge interfa | ice is pending. A | Additional writes to DCIWDATA are discarded when this bit is as- | # 7.5.4 DBG\_DCIID - Identification | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x10FC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 0XDC11D | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | 2 | _ | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|---------|--------|----------------| | 31:0 | ID | 0xDC11D | R | Identification | | | Debug Challenge Interfa | ce ID | | | # 7.5.5 DBG\_SYSCOM0 - Communication Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|-------|----|----|----|----|--------|----|----|----|----|----|----|--------------|-----------|------------|------|----|----|-----------------------------------------|------------|----|---|---|---------|---------|-------------|--------------------|-------------|-------------|--------------------|-------------| | 0x1110 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | • | | | 2 | e<br>X | | | | | | | 000 | 0×0 | 0×0 | | | | Ć | S<br>S | | | | 000 | 0×0 | 0×0 | 0×0 | 0×0 | 0x0 | 0x0 | 0x0 | | Access | | | | | | ۵ | צ | | | | | | | 22 | 22 | ~ | | | | כ | צ | | | | 2 | 22 | 2 | 22 | 22 | 2 | В | 2 | | Name | | PRS R | | | | | | | | | | | | RADIOSYNTHEN | RADIOPAEN | RADIOLNAEN | | | | H ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( | LDIMACHACI | | | | I2C1BSY | I2C0BSY | USART2TXBSY | <b>USART2RXBSY</b> | USART1TXBSY | USART1RXBSY | <b>USARTOTXBSY</b> | USARTORXBSY | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:20 | PRS | 0x0 | R | Peripheral Reflex Signals | | | Peripheral Reflex Signa | l Channel Val | ue | | | 19 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 18 | RADIOSYNTHEN | 0x0 | R | RADIO Synthesizer Enabled | | | RF Synthesiszer Enable | ed for Radio T | X and RX | | | 17 | RADIOPAEN | 0x0 | R | RADIO Power Amplifer Enabled | | | RF Power Amplifer Ena | bled for Radio | TX | | | 16 | RADIOLNAEN | 0x0 | R | RADIO Low Noise Amplifer Enabled | | | RF Low Noise Amplifer | Enabled for R | adio RX | | | 15:8 | LDMACHACT | 0x0 | R | LDMA Channel Active | | | Active LDMA Channels | | | | | 7 | I2C1BSY | 0x0 | R | I2C1 Busy | | | I2C1 Transaction in prog | gress | | | | 6 | I2C0BSY | 0x0 | R | I2C0 Busy | | | I2C0 Transaction in prog | gress | | | | 5 | USART2TXBSY | 0x0 | R | USART2 Transmit Busy | | | USART2 Transmit Activ | е | | | | 4 | USART2RXBSY | 0x0 | R | USART2 Receive Busy | | | USART2 Receive Active | e | | | | 3 | USART1TXBSY | 0x0 | R | USART1 Transmit Busy | | | USART1 Transmit Activ | е | | | | 2 | USART1RXBSY | 0x0 | R | USART1 Receive Busy | | | USART1 Receive Active | e | | | | 1 | USART0TXBSY | 0x0 | R | USART0 Transmit Busy | | | USART0 Transmit Activ | е | | | | 0 | USART0RXBSY | 0x0 | R | USART0 Receive Busy | | | | | | | | Bit | Name | Reset | Access | Description | |-----|-----------------------|-------|--------|-------------| | | USART0 Receive Active | | | | # 7.5.6 DBG\_SYSCOM1 - Communication Status | Offset | | | | | | | | | | | | | | | Bi | t Pos | tion | ) | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|-------|------|----------|------|----------|---|----|---|---|---|---|---|---|---|---|---|---| | 0x1114 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 2 2 | <u>t</u> | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | | OXO | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | Ω | <u>:</u> | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | GPIO | 5 | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:26 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 25:0 | GPIO | 0x0 | R | General Purpose Input | | | General Purpose Input | √alue | | | # 7.5.7 DBG\_SYSPWR0 - Power Status | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|----------|----------|-----|-----|-----|-----|-----|------|-----|-----| | 0x1120 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | ' | | | | | | | | | ' | | ' | | ' | | | | | 0x0 | 0X0 | 000 | 0x0 | 000 | 000 | 0x0 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | 22 | 22 | 22 | 22 | 22 | 22 | 22 | 22 | 2 | Я | | Name | | | | | | | | | | | | | | | | | | | | | | | RTNDRAM1 | RTNDRAMO | VS2 | VS1 | VS0 | EM3 | EM2 | EM1P | EM1 | EMO | | Bit | Name | Reset | Access | Description | |-------|----------------------------|----------------|-------------------|----------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 9 | RTNDRAM1 | 0x0 | R | Retained RAM0 | | | Retained RAM0 Instance | ) | | | | 8 | RTNDRAM0 | 0x0 | R | Retained RAM0 | | | Retained RAM0 Instance | ; | | | | 7 | VS2 | 0x0 | R | Voltage State 2 | | | System is in Voltage State | te 2 | | | | 6 | VS1 | 0x0 | R | Voltage State 1 | | | System is in Voltage State | te 1 | | | | 5 | VS0 | 0x0 | R | Voltage State 0 | | | System is in Voltage State | te 0 | | | | 4 | EM3 | 0x0 | R | Energy Mode 3 | | | System is in Energy Mod | le 3 | | | | 3 | EM2 | 0x0 | R | Energy Mode 2 | | | System is in Energy Mod | le 2 | | | | 2 | EM1P | 0x0 | R | Energy Mode 1 Peripheral | | | System is in Energy Mod | le 1 Periphera | ıl | | | 1 | EM1 | 0x0 | R | Energy Mode 1 | | | System is in Energy Mod | le 1 | | | | 0 | EM0 | 0x0 | R | Energy Mode 0 | | | System is in Energy Mod | le 0 | | | | | | | | | # 7.5.8 DBG\_SYSCLK0 - Clocking Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|-----------|----------|----------|----|--------------|---------|----------|---------|----|----------|-----------|-------------|------|---------|---------|---------|----------|----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|---------|----------| | 0x1130 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | ' | 000 | 0x0 | 0x0 | | 0x0 | 0×0 | 0x0 | 0×0 | | 0×0 | 0x0 | 000 | | 0×0 | 0×0 | 000 | 0×0 | 0x0 | 000 | 0x0 | 000 | 0x0 | 0×0 | 0×0 | 0×0 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | 22 | ~ | <u>~</u> | | <u>~</u> | 22 | <u>~</u> | œ | | 22 | 2 | 22 | | 22 | œ | 2 | 2 | <u>~</u> | 22 | <u>~</u> | 22 | 2 | 2 | 2 | 2 | 22 | <u>~</u> | Ж | <u>~</u> | | Name | | | | RNGULFRCO | RNGLFRCO | RNGLFXO | | RNGHFRCODPLL | RNGSYXO | RNGFSRCO | RNG12C0 | | RNGWDOG0 | RNGPRORTC | RNGLETIMERO | | RNGIADC | RNGDPLL | RNGLDMA | RNGGPCRC | RNGI2C1 | RNGUSART2 | RNGUSART1 | RNGUSARTO | RNGTIMER4 | RNGTIMER3 | RNGTIMER2 | RNGTIMER1 | RNGTIMERO | RNGRADIO | RNGRTCC | RNGBURTC | | Bit | Name | Reset | Access | Description | |-------|-------------------------|---------------------|--------------------|----------------------------------------------------------------------| | 31:29 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 28 | RNGULFRCO | 0x0 | R | Running ULFRCO Clock | | | ULFRCO Clock is running | g | | | | 27 | RNGLFRCO | 0x0 | R | Running LFRCO Clock | | | LFRCO Clock is running | | | | | 26 | RNGLFXO | 0x0 | R | Running LFXO Clock | | | LFXO Clock is running | | | | | 25 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 24 | RNGHFRCODPLL | 0x0 | R | Running HFRCODPLL Clock | | | HFRCODPLL Clock is ru | nning | | | | 23 | RNGSYXO | 0x0 | R | Running SYXO Clock | | | SYXO Clock is running | | | | | 22 | RNGFSRCO | 0x0 | R | Running FSRCO Clock | | | FSRCO Clock is running | | | | | 21 | RNGI2C0 | 0x0 | R | Running I2C0 Clock | | | I2C0 Clock is running | | | | | 20 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 19 | RNGWDOG0 | 0x0 | R | Running WDOG0 Clock | | | WDOG0 Clock is running | I | | | | 18 | RNGPRORTC | 0x0 | R | Running PRORTC Clock | | | PRORTC Clock is runnin | g | | | | 17 | RNGLETIMER0 | 0x0 | R | Running LETIMER0 Clock | | | LETIMER0 Clock is runn | ing | | | | 16 | Reserved | To ensure oventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | Bit | Name | Reset | Access | Description | |-----|--------------------------|-------|--------|----------------------| | 15 | RNGIADC | 0x0 | R | Running IADC Clock | | | IADC Clock is running | | | | | 14 | RNGDPLL | 0x0 | R | Running DPLL Clock | | | DPLL Clock is running | | | | | 13 | RNGLDMA | 0x0 | R | Running LDMA Clock | | | LDMA Clock is running | | | | | 12 | RNGGPCRC | 0x0 | R | Running GPCRC Clock | | | GPCRC Clock is running | | | | | 11 | RNGI2C1 | 0x0 | R | Running I2C1 Clock | | | I2C1 Clock is running | | | | | 10 | RNGUSART2 | 0x0 | R | Running USART2 Clock | | | USART2 Clock is running | 9 | | | | 9 | RNGUSART1 | 0x0 | R | Running USART1 Clock | | | USART1 Clock is running | 3 | | | | 8 | RNGUSART0 | 0x0 | R | Running USART0 Clock | | | USART0 Clock is running | 9 | | | | 7 | RNGTIMER4 | 0x0 | R | Running TIMER4 Clock | | | TIMER4 Clock is running | | | | | 6 | RNGTIMER3 | 0x0 | R | Running TIMER3 Clock | | | TIMER3 Clock is running | | | | | 5 | RNGTIMER2 | 0x0 | R | Running TIMER2 Clock | | | TIMER2 Clock is running | | | | | 4 | RNGTIMER1 | 0x0 | R | Running TIMER1 Clock | | | TIMER1 Clock is running | | | | | 3 | RNGTIMER0 | 0x0 | R | Running TIMER0 Clock | | | TIMER0 Clock is running | | | | | 2 | RNGRADIO | 0x0 | R | Running RADIO Clock | | | RADIO Clock is running | | | - | | 1 | RNGRTCC | 0x0 | R | Running RTCC Clock | | | RTCC Clock is running | | | - | | 0 | RNGBURTC | 0x0 | R | Running BURTC Clock | | - | BURTC Clock is running | | | | | | 201110 0100110 141111119 | | | | # 7.5.9 DBG\_SYSID - Identification | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|--------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x11FC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | 7,47,0 | т | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | ٥ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | 2 | ⊇ _ | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-----------------|---------|--------|----------------| | 31:0 | ID | 0x5451D | R | Identification | | | System Block ID | | | | ## 8. CMU - Clock Management Unit #### **Quick Facts** #### What? The CMU controls clock switching and distribution. EFR32xG22 supports 7 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. Interrupt 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 provide 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) - · 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. - FSRCO, which is asynchronous to the system clock, can be selected for IADC 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 EFR32xG22 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 135. Clock selection for peripherals with multiple high-frequency clock sources is shown in Figure 8.2 High Frequency Peripheral Clocks on page 136. Clock selection for peripherals with multiple low-frequency clock sources is shown in Figure 8.3 Low Frequency Peripheral Clocks on page 137. Figure 8.1. Bus 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.2. High Frequency Peripheral Clocks Figure 8.3. Low 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. By default, the FSRCO is selected as the bootup oscillator. 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. Example modules include the CPU, Cache, Bus Matrix, MSC, RAM, LDMA and GPIO. 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. Example modules include USART and I2C. 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 of 50 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. Example modules include I2C. LSPCLK is always prescaled by two. This prescales LSPCLK to all Low Speed APB bus clocks and is necessary to prevent LSPCLK from exceeding the maximum frequency of 25 MHz. 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 50 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, 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 EM01GRPBCLK - Energy Mode 01 Group B Clock EM01GRPBCLK is the selected clock for the Group B Peripherals operating in Energy Modes 0 or 1. These are typically high clock frequency peripheral modules. There are several selectable sources for EM01GRPBCLK: HFXO, HFRCODPLL, FSRCO, CLKINO, HFRCODPLLRT, and HFXORT. In addition, the EM01GRPBCLK can be disabled. The selection is configured using the CLKSEL field in CMU\_EM01GRPBCLKCTRL. Each High Frequency Peripheral that is clocked by EM01GRPBCLK 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 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 UARTCLK - UART Clock UARTCLK is the selected clock for the EUART peripherals, and can choose between EM01GRPACLK and EM23GRPACLK. UARTCLK is selected via the CLKSEL field in CMU\_UARTCLKCTRL. If operating in EM2, the EM23GRPACLK option must be chosen, as EM01GRPACLK will be shut down in these lower energy modes. ## 8.3.1.13 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 50 MHz maximum. Therefore, if the SYSCLK is 50 MHz or less, the default DIV1 setting may be used. When SYSCLK is above 50 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.14 WDOGCLK - Watchdog Timer Clock The Watchdog Timer (WDOG) 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.4 CMU Switching from HFRCO to HFXO before HFXO is ready on page 140 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.5 CMU Switching from HFRCO to HFXO after HFXO is ready on page 141. 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.4. CMU Switching from HFRCO to HFXO before HFXO is ready Figure 8.5. 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 (HFRCODPLL) at run-time, see Figure 8.6 Hardware Support for RC Oscillator Calibration on page 142 for an illustration of this circuit. The concept is to select a reference and compare the RC frequency 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 CAL-UP 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.6. Hardware Support for RC Oscillator Calibration The counter operation for single and continuous mode are shown in Figure 8.7 Single Calibration (CONT=0) on page 143 and Figure 8.8 Continuous Calibration (CONT=1) on page 144 respectively. Figure 8.7. Single Calibration (CONT=0) Figure 8.8. 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 (HFRCODPLL and HFXO) and high frequency clocks (SYSCLK, HCLK, PCLK, RADIOCLK, and EM01GRPACLK) 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 145. The CMU overview figure in also indicates 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 (in non-precision mode) can be requested in EM4 as needed. When the LFRCO precision mode is used, this oscillator cannot operate in EM4. 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 (EM23GRPACLK, EM4GRPACLK, WDOGCLK, RTCCCLK, and PRORTCCLK) 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 145. 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 | | FSRCO | 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> , <sup>4</sup> | | ULFRCO | On | On | On | On <sup>3</sup> | | SYSCLK, HCLK, PCLK, LSPCLK, RHCLK, EM01GRPACLK | On <sup>1</sup> | Off | Off | Off | | IADCCLK | On <sup>1</sup> | On <sup>2</sup> | On <sup>2</sup> | Off | | EM23GRPACLK, UARTCLK, WDOGCLK, RTCCCLK, PRORTCCLK | On <sup>1</sup> | On <sup>1</sup> | On <sup>5</sup> | Off | | EM4GRPACLK | On <sup>1</sup> | On <sup>1</sup> | On <sup>5</sup> | On <sup>3</sup> | - 1 Under software control. - 2 Default off, but kept active if used by the IADC. - 3 Default off, but kept active if used by BURTC. - 4 LFRCO not available in EM4 when precision mode enabled. - 5 On only if ULFRCO is used as clock source. #### 8.3.5 Clock Output on a Pin It is possible to configure the CMU to output clocks on the CMU\_CLK pins. This clock selection is done using the CLKOUTSEL bitfields in CMU\_EXPORTCLKCTRL. The required output pins must be enabled in the GPIO\_DBUSCMU\_ROUTEEN register and the pin locations can be configured in the GPIO\_DBUSCMU\_CLKOUT ROUTE register. The following clocks can be output on a pin: - HCLK and EXPCLK. The HCLK is the high frequency clock for AHB. The EXPCLK is a prescaled version of HCLK as controlled by the PRESC bitfield in the CMU EXPORTCLKCTRL register. - The qualified clock from any of the oscillators. A qualified clock will not have any glitches or skewed duty-cycle during startup. 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 not have a 50-50 duty cycle when any other division factor than 1 is used for HCLKPRESC bitfield in CMU\_SYSCLKCTRL (i.e. if HCLKPRESC is not equal to 0). In such a case, the exported EXPCLK will also not be 50-50 when its division factor is not set to an even number in the PRESC bitfield of the CMU\_EXPORTCLKCTRL register. #### 8.3.6 Clock Input from a Pin It is possible to configure the CMU to input a clock from the CMU\_CLKI0. 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\_DBUSCMU\_CLKINOROUTE register. ### 8.3.7 Clock Output on PRS The CMU can be used as a PRS producer. It can output clocks onto PRS which can be selected by a consumer as CMUCLKOUT. The clocks which can be produced via CMUCLKOUT are selected via the CLKOUTSEL fields in CMU EXPORTCLKCTRL. Note that the CLKOUTSEL fields are also used for selecting which clock is output onto a pin as described in 8.3.5 Clock Output on a Pin. In contrast with clock output on a pin however, output of a clock onto PRS does not depend on any configuration of the GPIO DBUSCMU ROUTEEN and GPIO DBUSCMU CLKOUT ROUTE registers. ### 8.3.8 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.9 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 | Туре | 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 | | 0x124 | CMU_EM01GRPBCLKCTRL | RW | EM01 Peripheral Group B 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 | | 0x220 | CMU_EUART0CLKCTRL | RW | UART Clock Control | | 0x240 | CMU_RTCCCLKCTRL | RW | RTCC Clock Control | | 0x260 | CMU_CRYPTOACCCLKCTRL | RW | CRYPTOACC Clock Control | | 0x280 | CMU_RADIOCLKCTRL | RW | Radio 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 | | 0x1054 | CMU_CALCTRL_SET | RW | Calibration Control Register | | 0x1058 | CMU_CALCNT_SET | R | Calibration Result Counter Register | | 0x1064 | CMU_CLKEN0_SET | RW | Clock Enable Register 0 | | Offset | Name | Туре | Description | |--------|-------------------------------|-------------|---------------------------------------| | 0x1068 | CMU_CLKEN1_SET | RW | Clock Enable Register 1 | | 0x1070 | CMU_SYSCLKCTRL_SET | RW | System Clock Control | | 0x1080 | CMU_TRACECLKCTRL_SET | RW | Debug Trace Clock Control | | 0x1090 | CMU_EXPORTCLKCTRL_SET | RW | Export Clock Control | | 0x1100 | CMU_DPLLREFCLKCTRL_SET | RW | Digital PLL Reference Clock Control | | 0x1120 | CMU_EM01GRPACLKCTRL_SE<br>T | RW | EM01 Peripheral Group A Clock Control | | 0x1124 | CMU_EM01GRPBCLKCTRL_SE<br>T | RW | EM01 Peripheral Group B Clock Control | | 0x1140 | CMU_EM23GRPACLKCTRL_SE<br>T | RW | EM23 Peripheral Group A Clock Control | | 0x1160 | CMU_EM4GRPACLKCTRL_SET | RW | EM4 Peripheral Group A Clock Control | | 0x1180 | CMU_IADCCLKCTRL_SET | RW | IADC Clock Control | | 0x1200 | CMU_WDOG0CLKCTRL_SET | RW | Watchdog0 Clock Control | | 0x1220 | CMU_EUART0CLKCTRL_SET | RW | UART Clock Control | | 0x1240 | CMU_RTCCCLKCTRL_SET | RW | RTCC Clock Control | | 0x1260 | CMU_CRYP-<br>TOACCCLKCTRL_SET | RW | CRYPTOACC Clock Control | | 0x1280 | CMU_RADIOCLKCTRL_SET | RW | Radio Clock Control | | 0x2000 | CMU_IPVERSION_CLR | R | IP version ID | | 0x2008 | CMU_STATUS_CLR | RH | Status Register | | 0x2010 | CMU_LOCK_CLR | W | Configuration Lock Register | | 0x2014 | CMU_WDOGLOCK_CLR | W | WDOG Configuration Lock Register | | 0x2020 | CMU_IF_CLR | RWH INTFLAG | Interrupt Flag Register | | 0x2024 | CMU_IEN_CLR | RW | Interrupt Enable Register | | 0x2050 | CMU_CALCMD_CLR | W | Calibration Command Register | | 0x2054 | CMU_CALCTRL_CLR | RW | Calibration Control Register | | 0x2058 | CMU_CALCNT_CLR | R | Calibration Result Counter Register | | 0x2064 | CMU_CLKEN0_CLR | RW | Clock Enable Register 0 | | 0x2068 | CMU_CLKEN1_CLR | RW | Clock Enable Register 1 | | 0x2070 | CMU_SYSCLKCTRL_CLR | RW | System Clock Control | | 0x2080 | CMU_TRACECLKCTRL_CLR | RW | Debug Trace Clock Control | | 0x2090 | CMU_EXPORTCLKCTRL_CLR | RW | Export Clock Control | | 0x2100 | CMU_DPLLREFCLKCTRL_CLR | RW | Digital PLL Reference Clock Control | | 0x2120 | CMU_EM01GRPACLKCTRL_CLR | RW | EM01 Peripheral Group A Clock Control | | 0x2124 | CMU_EM01GRPBCLKCTRL_CL R | RW | EM01 Peripheral Group B Clock Control | | 0x2140 | CMU_EM23GRPACLKCTRL_CLR | RW | EM23 Peripheral Group A Clock Control | | Offset | Name | Туре | Description | |--------|-------------------------------|-------------|---------------------------------------| | 0x2160 | CMU_EM4GRPACLKCTRL_CLR | RW | EM4 Peripheral Group A Clock Control | | 0x2180 | CMU_IADCCLKCTRL_CLR | RW | IADC Clock Control | | 0x2200 | CMU_WDOG0CLKCTRL_CLR | RW | Watchdog0 Clock Control | | 0x2220 | CMU_EUART0CLKCTRL_CLR | RW | UART Clock Control | | 0x2240 | CMU_RTCCCLKCTRL_CLR | RW | RTCC Clock Control | | 0x2260 | CMU_CRYP-<br>TOACCCLKCTRL_CLR | RW | CRYPTOACC Clock Control | | 0x2280 | CMU_RADIOCLKCTRL_CLR | RW | Radio 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 | RW | EM01 Peripheral Group A Clock Control | | 0x3124 | CMU_EM01GRPBCLKCTRL_TG | RW | EM01 Peripheral Group B Clock Control | | 0x3140 | CMU_EM23GRPACLKCTRL_TG | RW | EM23 Peripheral Group A Clock Control | | 0x3160 | CMU_EM4GRPACLKCTRL_TGL | RW | EM4 Peripheral Group A Clock Control | | 0x3180 | CMU_IADCCLKCTRL_TGL | RW | IADC Clock Control | | 0x3200 | CMU_WDOG0CLKCTRL_TGL | RW | Watchdog0 Clock Control | | 0x3220 | CMU_EUART0CLKCTRL_TGL | RW | UART Clock Control | | 0x3240 | CMU_RTCCCLKCTRL_TGL | RW | RTCC Clock Control | | 0x3260 | CMU_CRYP-<br>TOACCCLKCTRL_TGL | RW | CRYPTOACC Clock Control | | 0x3280 | CMU_RADIOCLKCTRL_TGL | RW | Radio Clock Control | ### 8.5 CMU Register Description # 8.5.1 CMU\_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 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | × × × × × × × × × × × × × × × × × × × | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | <u> </u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | PVERSION R | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|---------------|--|--|--|--|--|--|--|--| | 31:0 | IPVERSION | 0x1 | 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. | | | | | | | | | | | | ### 8.5.2 CMU\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|--------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | တ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 000 | 0x0 | | | | | | | | | | | | | | | • | | • | | | | | | • | | • | | | | | 000 | | Access | 2 | œ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ~ | | Name | LOCK | WDOGLOCK | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CALRDY | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|----------------------|-------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------|--|--|--|--|--|--|--|--| | 31 | LOCK | 0x0 | R | Configuration Lock Status | | | | | | | | | | | Indicates the curren | t status of config | uration lock | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | 0 | UNLOCKE | ED | Configuration lock is unlocked | | | | | | | | | | | 1 | LOCKED | | Configuration lock is locked | | | | | | | | | | 30 | WDOGLOCK | 0x0 | R | Configuration Lock Status for WDOG | | | | | | | | | | | Indicates the curren | t status of WDO0 | G configuration | lock | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | 0 | UNLOCKE | ED | WDOG configuration lock is unlocked | | | | | | | | | | | 1 | LOCKED | | WDOG configuration lock is locked | | | | | | | | | | 29:1 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 ventions | | | | | | | | | | | | 0 | CALRDY | 0x0 | R | Calibration Ready | | | | | | | | | | | Calibration is Ready | / (0 when calibrat | ). | | | | | | | | | | ### 8.5.3 CMU\_LOCK - Configuration Lock Register | Offset | Bit Pos | sition | |--------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x010 | 31<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30 | 6 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | | Reset | | 0x93F7 | | Access | | | | Name | | LOCKKEY | | Bit | Name | Reset | Access | Description | | | | | | | |-------|---------------------------|--------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--|--| | 31:16 | Reserved | To ensure c | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 15:0 | LOCKKEY | 0x93F7 | W | Configuration Lock Key | | | | | | | | | Write any other value tha | n the unlock | code to lock reg | isters 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 | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------------------------------------|--------|---|---|---|---|---|---|---| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | • | | | • | | | | • | 0.50 | /czcx0 | • | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | 3 | > | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | \ \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | LOCKA | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------|----------------------|---------------|---------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0x5257 | W | Configuration Lock Key | | | Write any other va | alue 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 | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-------|--------| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | ' | | | | | | | | | • | | ' | | • | | ' | | • | | ' | | | | • | | • | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CALOF | CALRDY | | Bit | Name | Reset | Access | Description | |------|----------------------------|---------------|---------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | CALOF | 0x0 | RW | Calibration Overflow Interrupt Flag | | | Set when calibration ove | rflow has occ | urred (i.e. if a ne | ew calibration completes before CMU_CALSTATUS has been read) | | 0 | CALRDY | 0x0 | RW | Calibration Ready Interrupt Flag | | | Set when calibration is co | ompleted | | | ## 8.5.6 CMU\_IEN - Interrupt Enable Register | Offset | Bit Position | | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x024 | 33 34 4 5 5 2 4 4 4 4 5 6 6 6 7 7 7 8 8 8 8 8 8 8 8 8 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | _ | 0 | | Reset | | 0x0 | 0x0 | | Access | | ₹ | RW | | Name | | CALOF | CALRDY | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | CALOF | 0x0 | RW | Calibration Overflow Interrupt Enable | | | Enable/disable CALOF in | nterrupt | | | | 0 | CALRDY | 0x0 | RW | Calibration Ready Interrupt Enable | | | Enable/disable CALRDY | interrupt | | | # 8.5.7 CMU\_CALCMD - Calibration Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|---------|----------| | 0x050 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CALSTOP | CALSTART | | Bit | Name | Reset | Access | Description | |------|------------------------|----------------------|-----------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1 | CALSTOP | 0x0 | W | Calibration Stop | | | Stops the calibratio | n counters. | | | | 0 | CALSTART | 0x0 | W | Calibration Start | | | Starts the calibration | on, effectively load | ding the CMU | _CALCTRL.CALCNT into the down-counter and start decrementing. | ### 8.5.8 CMU\_CALCTRL - Calibration Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------------------------------------------|--------------|----|----|----|----|-------|----|------|----|----|----|----|----|----|------|------|----|----|----|---|----|---------------------------------------|---|---|---|---|---|---|---|---|---| | 0x054 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0X 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | W | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | I I SIN/VIOL | | | | | UPSEL | | CONT | | | | | | | | | | | | | | Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------------------|-------------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:28 | DOWNSEL | 0x0 | RW | Calibration Down-counter Select | | | Selects clock sour | ce for the calibratio | n down-count | er. 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 | HFRCODF | PLL PLL | HFRCODPLL 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 | Calibration Up-counter Select | | | Selects clock sour | ce for the calibration | n up-counter. | Changing this while calibration is running results in bus fault. | | | | | | | | | Value | Mode | | Description | | | Value 0 | Mode<br>DISABLED | ) | Description Up-counter is not clocked | | | | | ) | | | | 0 | DISABLED | ) | Up-counter is not clocked | | | 0 | DISABLED<br>PRS | ) | Up-counter is not clocked PRS CMU_CALUP consumer is clocking up-counter | | | 0 1 2 | DISABLED<br>PRS<br>HFXO | | Up-counter is not clocked PRS CMU_CALUP consumer is clocking up-counter HFXO is clocking up-counter | | | 0<br>1<br>2<br>3 | DISABLED<br>PRS<br>HFXO<br>LFXO | | Up-counter is not clocked PRS CMU_CALUP consumer is clocking up-counter HFXO is clocking up-counter LFXO is clocking up-counter | | | 0<br>1<br>2<br>3<br>4 | DISABLED PRS HFXO LFXO HFRCODE | | Up-counter is not clocked PRS CMU_CALUP consumer is clocking up-counter HFXO is clocking up-counter LFXO is clocking up-counter HFRCODPLL is clocking up-counter | | | 0<br>1<br>2<br>3<br>4<br>8 | DISABLED PRS HFXO LFXO HFRCODF FSRCO | | Up-counter is not clocked PRS CMU_CALUP consumer is clocking up-counter HFXO is clocking up-counter LFXO is clocking up-counter HFRCODPLL is clocking up-counter FSRCO is clocking up-counter | | 23 | 0<br>1<br>2<br>3<br>4<br>8<br>9 | DISABLED PRS HFXO LFXO HFRCODF FSRCO LFRCO | | Up-counter is not clocked PRS CMU_CALUP consumer is clocking up-counter HFXO is clocking up-counter LFXO is clocking up-counter HFRCODPLL is clocking up-counter FSRCO is clocking up-counter LFRCO is clocking up-counter | | 23 | 0<br>1<br>2<br>3<br>4<br>8<br>9<br>10 | DISABLED PRS HFXO LFXO HFRCODE FSRCO LFRCO ULFRCO 0x0 | PLL | Up-counter is not clocked PRS CMU_CALUP consumer is clocking up-counter HFXO is clocking up-counter LFXO is clocking up-counter HFRCODPLL is clocking up-counter FSRCO is clocking up-counter LFRCO is clocking up-counter ULFRCO is clocking up-counter | | Bit | Name | Reset | Access | Description | |------|---------------------------|-----------------|-------------------|------------------------------------------------| | 19:0 | CALTOP | 0x0 | RW | Calibration Counter Top Value | | | Write top value before ca | alibration. Cha | anging this while | e calibration is running results in bus fault. | # 8.5.9 CMU\_CALCNT - Calibration Result Counter Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---------|----------|---|---|---|---|---|---|---|---|---| | 0x058 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | 0 | 2 | | | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | Ω | <u> </u> | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | TNO IAO | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|---------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:0 | CALCNT | 0x0 | R | Calibration Result Counter Value | | | Read calibration result w | hen Calibrati | on Ready flag h | as been set. | # 8.5.10 CMU\_CLKEN0 - Clock Enable Register 0 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|--------|---------|--------|--------|-----|------|--------|--------|--------|------|--------|-------|---------|--------|--------|--------|--------|------|-------|----------|---------|--------|--------|--------|--------|--------|--------|--------|-------|----------|----------|------| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | 0×0 | 0X0 | 000 | 000 | 000 | 0x0 | 000 | 0x0 | 000 | 0x0 | 0X0 | 0x0 | 0X0 | 0X0 | 000 | 000 | 000 | 0×0 | 0x0 | 0X0 | 0x0 | 000 | 000 | 000 | 000 | 0X0 | 000 | 000 | 0x0 | 0x0 | 000 | 0x0 | | Access | ₩<br>M | RW<br>W | ₩<br>M | ₩<br>N | S. | W. | ₩<br>W | W. | S. | RW | R<br>W | RW | RW<br>W | W. | ₩<br>N | S. | ₩<br>N | Z. | RW | ₩<br>W | ₩. | ₩<br>N | ₩. | W. | S. | RW | S. | ₩<br>M | W. | W. | W. | RW | | Name | DCDC | RTCC | BURTC | BURAM | PRS | GPIO | PDM | EUART0 | ULFRCO | LFXO | LFRCO | FSRCO | HFX00 | HFRC00 | DPLL0 | SYSCFG | I2C1 | 12C0 | WDOG0 | LETIMER0 | AMUXCP0 | IADC0 | USART1 | USART0 | TIMER3 | TIMER2 | TIMER1 | TIMERO | GPCRC | RADIOAES | LDMAXBAR | LDMA | | Bit | Name | Reset | Access | Description | |-----|-----------------------|-------|--------|------------------| | 31 | DCDC | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 30 | RTCC | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 29 | BURTC | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 28 | BURAM | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 27 | PRS | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 26 | GPIO | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 25 | PDM | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 24 | EUART0 | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 23 | ULFRCO | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 22 | LFXO | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 21 | LFRCO | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 20 | FSRCO | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 19 | HFXO0 | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | 18 | HFRCO0 | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/h | HCLK | | | | Bit | Name Reset | Access | Description | |-----|--------------------------|--------|------------------| | 17 | DPLL0 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 16 | SYSCFG 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 15 | I2C1 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 14 | I2C0 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 13 | WDOG0 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 12 | LETIMERO 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 11 | AMUXCP0 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 10 | IADC0 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 9 | USART1 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 8 | USARTO 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 7 | TIMER3 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 6 | TIMER2 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 5 | TIMER1 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 4 | TIMER0 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 3 | GPCRC 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 2 | RADIOAES 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 1 | LDMAXBAR 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | 0 | LDMA 0x0 | RW | Enable Bus Clock | | | Enables module PCLK/HCLK | | | | | | | | # 8.5.11 CMU\_CLKEN1 - Clock Enable Register 1 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-----|---------|------|---------|-----------|------------|------|--------|------------|------------|--------------|-------|-----|----------|-----|-------|---------|--------| | 0x068 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | | • | • | | | | • | | | 000 | 000 | 000 | 000 | 000 | 0x0 | 0X0 | 0x0 | 000 | 0x0 | 000 | 000 | 000 | 000 | 000 | 0x0 | 000 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | W. | W. | W. | RW | W. | ₩. | W. | RW | W. | RW | W. ZW<br>W | R<br>W | | Name | | | | | | | | | | | | | | TIMER4 | MSC | ICACHE0 | SMU | RFSENSE | CRYPTOACC | IFADCDEBUG | BUFC | PRORTC | RDMAILBOX1 | RDMAILBOX0 | RDSCRATCHPAD | SYNTH | RAC | PROTIMER | FRC | RFCRC | MODEM | AGC | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:19 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 18 | TIMER4 | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 17 | MSC | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 16 | ICACHE0 | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 15 | SMU | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 14 | RFSENSE | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 13 | CRYPTOACC | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 12 | IFADCDEBUG | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 11 | BUFC | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 10 | PRORTC | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 9 | RDMAILBOX1 | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 8 | RDMAILBOX0 | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 7 | RDSCRATCHPAD | 0x0 | RW | Enable Bus Clock | | | Enables module PCLK | /HCLK | | | | 6 | SYNTH | 0x0 | RW | Enable Bus Clock | | | | | | | | D:4 | Nome | Paget | A | Description | |-----|-------------------|----------|--------|------------------| | Bit | Name | Reset | Access | Description | | | Enables module Po | CLK/HCLK | | | | 5 | RAC | 0x0 | RW | Enable Bus Clock | | | Enables module Po | CLK/HCLK | | | | 4 | PROTIMER | 0x0 | RW | Enable Bus Clock | | | Enables module Po | CLK/HCLK | | | | 3 | FRC | 0x0 | RW | Enable Bus Clock | | | Enables module Po | CLK/HCLK | | | | 2 | RFCRC | 0x0 | RW | Enable Bus Clock | | | Enables module Po | CLK/HCLK | | | | 1 | MODEM | 0x0 | RW | Enable Bus Clock | | | Enables module Po | CLK/HCLK | | | | 0 | AGC | 0x0 | RW | Enable Bus Clock | | | Enables module Po | CLK/HCLK | | | | | | | | | ### 8.5.12 CMU\_SYSCLKCTRL - System Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|----|------------|------|-------------|-----------|----|---|-----------|---|---|---|---|---|---|---|---|--------|---| | 0x070 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | <u>'</u> | | ' | | ' | | | | ' | | ' | 0×0 | | 2 | OX<br>N | | | 000 | | | • | ' | 1 | ' | | | 0x1 | | | Access | | | | | | | | | | | | | | | | ₩<br>M | | 20 | <u>}</u> | | | ₩<br>M | | | | | | | | | Z<br>N | | | Name | | | | | | | | | | | | | | | | RHCLKPRESC | | 7 0 0 0 0 0 | HOLKPRESO | | | PCLKPRESC | | | | | | | | | CLKSEL | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:17 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 16 | RHCLKPRESC | 0x0 | RW | Radio HCLK Prescaler | | | Specifies the clock of | livider 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 | HCLK Prescaler | | | Specifies the clock of | livider 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 | To ensure ventions | e compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 10 | PCLKPRESC | 0x0 | RW | PCLK Prescaler | | | Specifies the clock of | livider for PCLK | | | | | Value | Mode | | Description | | | 0 | DIV1 | | PCLK is HCLK divided by 1 | | | 1 | DIV2 | | PCLK is HCLK divided by 2 | | 9:3 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 2:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock so | urce for SYSCLI | Κ. | | | 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 | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|----------|----------|---|---|---|---| | 0x080 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | | • | | | | • | | • | | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | <u> </u> | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | 0000 | 200 | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|-----------------|-------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | PRESC | 0x0 | RW | TRACECLK Prescaler | | | Clock prescaler for debu | ıg trace logic. | | | | | Value | Mode | | Description | | | 0 | DIV1 | | TRACECLK is SYSCLK divided by 1 | | | 1 | DIV2 | | TRACECLK is SYSCLK divided by 2 | | | 3 | DIV4 | | TRACECLK is SYSCLK divided by 4 | | 3:0 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | ### 8.5.14 CMU\_EXPORTCLKCTRL - Export Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|-------|----|----|----|----|----|----|----|----------|----------|------|------|----|----|----|---|----------|----------|---|---|---|---|---|---|------------|---|---| | 0x090 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | 0×0 | | | | | | | | 2 | 2 | | | | | | | 5 | )<br>X | | | • | ' | | | ÖXO | 2 | | | Access | | | | | | ₽ | | | | | | | | 2 | <u>}</u> | | | | | | | <u> </u> | <u>}</u> | | | | | | | 8 | | | | Name | | | | | | PRESC | | | | | | | | CHOFFICA | J 35 L | | | | | | | 1 HOLLON | LYOUISEL | | | | | | | CIRCHISELO | ) | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:29 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 28:24 | PRESC | 0x0 | RW | EXPORTCLK Prescaler | | | Specifies the clock d | ivider for EXPO | RTCLK (relative | e to SYSCLK). | | 23:20 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | CLKOUTSEL2 | 0x0 | RW | Clock Output Select 2 | | | Controls the clock or | ıtput 2 multiplex | er. | | | | Value | Mode | | Description | | | 0 | DISABLE | D | CLKOUT2 is not clocked | | | 1 | HCLK | | HCLK is clocking CLKOUT2 | | | 2 | HFEXPCL | -K | HFEXPCLK is clocking CLKOUT2 | | | 3 | ULFRCO | | ULFRCO is clocking CLKOUT2 | | | 4 | LFRCO | | LFRCO is clocking CLKOUT2 | | | 5 | LFXO | | LFXO is clocking CLKOUT2 | | | 6 | HFRCOD | PLL | HFRCODPLL is clocking CLKOUT2 | | | 7 | HFXO | | HFXO is clocking CLKOUT2 | | | 8 | FSRCO | | FSRCO is clocking CLKOUT2 | | 15:12 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 11:8 | CLKOUTSEL1 | 0x0 | RW | Clock Output Select 1 | | | Controls the clock or | ıtput 1 multiplex | er. | | | | Value | Mode | | Description | | | 0 | DISABLE | D | CLKOUT1 is not clocked | | | 1 | HCLK | | HCLK is clocking CLKOUT1 | | | 2 | HFEXPCL | .K | HFEXPCLK is clocking CLKOUT1 | | | 3 | ULFRCO | | ULFRCO is clocking CLKOUT1 | | Bit | Name | Reset | Access | Description | |-----|-----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | | 4 | LFRCO | | LFRCO is clocking CLKOUT1 | | | 5 | LFXO | | LFXO is clocking CLKOUT1 | | | 6 | HFRCODI | PLL | HFRCODPLL is clocking CLKOUT1 | | | 7 | HFXO | | HFXO is clocking CLKOUT1 | | | 8 | FSRCO | | FSRCO is clocking CLKOUT1 | | 7:4 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | CLKOUTSEL0 | 0x0 | RW | Clock Output Select 0 | | | Controls the clock of | utput 0 multiplex | er. | | | | Value | Mode | | Description | | | 0 | DISABLE | ) | CLKOUT0 is not clocked | | | 1 | HCLK | | HCLK is clocking CLKOUT0 | | | 2 | HFEXPCL | K | HFEXPCLK is clocking CLKOUT0 | | | 3 | ULFRCO | | ULFRCO is clocking CLKOUT0 | | | 4 | LFRCO | | LFRCO is clocking CLKOUT0 | | | 5 | LFXO | | LFXO is clocking CLKOUT0 | | | 6 | HFRCODI | PLL | HFRCODPLL is clocking CLKOUT0 | | | 7 | HFXO | | HFXO is clocking CLKOUT0 | | | 8 | FSRCO | | FSRCO is clocking CLKOUT0 | | | | | | | ### 8.5.15 CMU\_DPLLREFCLKCTRL - Digital PLL Reference Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|----------| | 0x100 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | • | | | | | | • | | | | • | | • | | | | | | | | | | | | | ç | OX<br>OX | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7 | CLKSEL | | Bit | Name | Reset | Access | Description | |------|-------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility ( | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | CLKSEL | 0x0 | RW | Clock Select | | | Selects the clock | source for DPLL re | ference. Chan | ging this while DPLL is enabled results in bus fault. | | | Value | Mode | | Description | | | 0 | DISABLE | ) | 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 | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|--------| | 0x120 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0x1 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CLKSEL | | Bit | Name | Reset | Access | Description | |------|-------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock | source for EM01 G | roup A Clock. | | | | Value | Mode | | Description | | | 1 | HFRCODE | PLL | HFRCODPLL is clocking EM01GRPACLK | | | 2 | HFXO | | HFXO is clocking EM01GRPACLK | | | 3 | FSRCO | | FSRCO is clocking EM01GRPACLK | | | | | | | # 8.5.17 CMU\_EM01GRPBCLKCTRL - EM01 Peripheral Group B Clock Control | Offset | Bit Position | | |--------|----------------------------------------------------------------------------------------------------------------------------------------|----------| | 0x124 | 31<br>31<br>31<br>32<br>33<br>33<br>34<br>34<br>35<br>36<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37 | 0 7 | | Reset | | <u>×</u> | | Access | | Z. | | Name | | CLKSEL | | Bit | Name | Reset | Access | Description | |------|--------------------------|---------------|-------------------|-------------------------------------------------------------------------| | 31:3 | Reserved | To ensure o | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 2:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock source | e for EM01 Gr | oup B Clock. | | | | Value | Mode | | Description | | | 1 | HFRCODP | LL | HFRCODPLL is clocking EM01GRPBCLK | | | 2 | HFXO | | HFXO is clocking EM01GRPBCLK | | | 3 | FSRCO | | FSRCO is clocking EM01GRPBCLK | | | 4 | CLKIN0 | | CLKIN0 is clocking EM01GRPBCLK | | | 5 | HFRCODP | LLRT | HFRCODPLL (re-timed) is clocking EM01GRPBCLK | | | 6 | HFXORT | | HFXO (re-timed) is clocking EM01GRPBCLK | ### 8.5.18 CMU\_EM23GRPACLKCTRL - EM23 Peripheral Group A Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|---|------------| | 0x140 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 | Š | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <br>}<br>Y | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CLKSEL | | Bit | Name | Reset | Access | Description | |------|---------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock s | source for EM23 G | roup A Clock. | | | | 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 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <td>1 0</td> | 1 0 | | Reset | | 0×1 | | Access | | A<br>W | | Name | | CLKSEL | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock so | ource for EM4 Gro | oup A Clock. | | | | 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 | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|---|------------| | 0x180 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | • | | | | | | | | | • | | | | | | | | | | | | | | | | 3 | Š | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <br>}<br>Y | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CLKSEL | | Bit | Name | Reset | Access | Description | |------|-----------------------------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock source bling the EM01GRACLK | | | K should never be selected as clock source for IADC when disa-). | | | Value | Mode | | Description | | | 1 | EM01GRPA | ACLK | EM01GRPACLK is clocking IADCCLK | | | 2 | FSRCO | | FSRCO is clocking IADCCLK | # 8.5.21 CMU\_WDOG0CLKCTRL - Watchdog0 Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------|---| | 0x200 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | • | | | | | • | | | | | | | | | | | • | | | | | | | | | | 0X | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R<br>≪ | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CLKSEL | | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:3 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 2:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock se | ource for WDOG0 | | | | | Value | Mode | | Description | | | 1 | LFRCO | | LFRCO is clocking WDOG0CLK | | | 2 | LFXO | | LFXO is clocking WDOG0CLK | | | 3 | ULFRCO | | ULFRCO is clocking WDOG0CLK | | | 4 | HCLKDIV1 | 1024 | HCLKDIV1024 is clocking WDOG0CLK | ### 8.5.22 CMU\_EUART0CLKCTRL - UART Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|-----|----------| | 0x220 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | တ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | • | | | | | | | | | • | | | | | | | • | | | | • | • | • | | | 2 | Š | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 100 | CLASEL | | Bit | Name | Reset | Access | Description | |------|----------|--------------------------------------|-----------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | CLKSEL | 0x1 | RW | Clock Select | | | | hich clock is used for EM01GRACLK (e | | DIGRPACLK should never be selected as clock source for UART EM23 entry). | | | Value | Mode | | Description | | | 0 | DISABLED | ı | UART is not clocked | | | 1 | EM01GRP | ACLK | EM01GRPACLK is clocking UART | | | 2 | EM23GRP | ACLK | EM23GRPACLK is clocking UART | | | | | | <u> </u> | ### 8.5.23 CMU\_RTCCCLKCTRL - RTCC Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|------------| | 0x240 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | • | | • | | | | | | | • | | | | | | | | | | • | | | | | | • | | | 3 | Š | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <br>}<br>Y | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | CLKSEL | | Bit | Name | Reset | Access | Description | |------|-------------------|--------------------|---------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | CLKSEL | 0x1 | RW | Clock Select | | | Selects the clock | source for RTCC. | | | | | Value | Mode | | Description | | | 1 | LFRCO | | LFRCO is clocking RTCCCLK | | | 2 | LFXO | | LFXO is clocking RTCCCLK | | | 3 | ULFRCO | | ULFRCO is clocking RTCCCLK | | | | | | | ### 8.5.24 CMU\_CRYPTOACCCLKCTRL - CRYPTOACC Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|--------| | 0x260 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | • | | • | • | • | | | | | | | | | | | | | | | | | | | | | | | • | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | ₩<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | AESEN | PKEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | AESEN | 0x0 | RW | AES Enable | | | Enables clock to the AES | S sub-module | | | | 0 | PKEN | 0x0 | RW | PK Enable | | | Enables clock to the PK | sub-module | | | ### 8.5.25 CMU\_RADIOCLKCTRL - Radio Clock Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------| | 0x280 | 33 | 30 | 29 | 78 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | Reset | 0x0 | | • | | | • | | | | • | | | | | | • | | | | | | | • | • | • | | • | | | | | 0x0 | | Access | ₩<br>M | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>W | | Name | DBGCLK | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N<br>N | | Bit | Name | Reset | Access | Description | |------|---------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31 | DBGCLK | 0x0 | RW | Enable Clock for Debugger | | | When set to 1, this force | s radio busma | atrix and RAC c | ocks to run, allowing RAC sequencer debugger to stay attached. | | 30:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | Enable | | | Enables radio bridge clo | ck | | | #### 9. Oscillators #### **Quick Facts** #### What? The EFR32xG22 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 EFR32xG22 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 38.4 MHz crystals - Multiple programming options of start-up parameters to enable optimization of different crystals, supporting a wide range of ESR and ESL - · 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 173. 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. A typical use scenario of the on-demand feature is as follows. Set up the PRORTC to periodically generate a compare match. Setup a PRS channel which uses this PRORTC compare match as its source to cause a wake-up into EM1. Setup the RAC to use the PRS channel as its source for TXEN or RXEN. Now, when the EFR32 is in EM2 and the RTCC generates a compare match, a wake-up into EM1 occurs, and the HFXO will automatically start. When HFXO is ready, the RAC performs its work and triggers a transition back into EM2 when finished. The system starts, uses, and stops the HFXO without ever being in EM0. 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. Next, issue the MANUALOVERRIDE command in the HFXO\_CMD register to update the control registers and configuration registers with FSM values, allowing software direct control of the oscillator. 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 38.4 MHz MHz crystal. There may also be specific crystal tolerance requirements for each RF protocol supported by the radio. # 9.2.4 HFXO Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|--------------------|-------------|--------------------------------| | 0x000 | HFXO_IPVERSION | R | IP version ID | | 0x010 | HFXO_XTALCFG | RWH | Crystal Configuration Register | | 0x018 | HFXO_XTALCTRL | RWH | Crystal Control Register | | 0x020 | HFXO_CFG | RWH | Configuration Register | | 0x028 | HFXO_CTRL | RWH | Control Register | | 0x050 | HFXO_CMD | W | 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 | RWH | Crystal Configuration Register | | 0x1018 | HFXO_XTALCTRL_SET | RWH | Crystal Control Register | | 0x1020 | HFXO_CFG_SET | RWH | Configuration Register | | 0x1028 | HFXO_CTRL_SET | RWH | Control Register | | 0x1050 | HFXO_CMD_SET | W | 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 | RWH | Crystal Configuration Register | | 0x2018 | HFXO_XTALCTRL_CLR | RWH | Crystal Control Register | | 0x2020 | HFXO_CFG_CLR | RWH | Configuration Register | | 0x2028 | HFXO_CTRL_CLR | RWH | Control Register | | 0x2050 | HFXO_CMD_CLR | W | Command Register | | 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 | RWH | Crystal Configuration Register | | 0x3018 | HFXO_XTALCTRL_TGL | RWH | Crystal Control Register | | 0x3020 | HFXO_CFG_TGL | RWH | Configuration Register | | 0x3028 | HFXO_CTRL_TGL | RWH | Control Register | | Offset | Name | Туре | Description | |--------|-----------------|-------------|-----------------------------| | 0x3050 | HFXO_CMD_TGL | W | 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 | | | | | | | | | | | | | |--------|----------------------------------------------------|--------------|--|--|--|--|--|--|--|--|--|--|--|--| | 0x000 | 30 29 30 30 31 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | | | | | | | | | | | | | | | Reset | | 800 | | | | | | | | | | | | | | Access | | <u>~</u> | | | | | | | | | | | | | | Name | | IPVERSION R | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x2 | R | IP Version ID | | | The read only IPVERSIOn modules with different values | • | | this module. There may be minor software changes required for | # 9.2.5.2 HFXO\_XTALCFG - Crystal Configuration Register | Offset | Bit Position | | | | | | | | | | | | |--------|--------------|----------------------|---------------|----------------|----------------|----------------------|------------------|--|--|--|--|--| | 0x010 | 30 29 28 | 27<br>26<br>25<br>24 | 22 21 20 20 | 19 17 17 16 | 5 4 6 2 | 11 10 10 9 8 8 7 7 6 | ω 4 ε α τ ο | | | | | | | Reset | | 0x4 | 0x4 | 0x3 | 0x3 | 0x13 | 0×B | | | | | | | Access | | RW | A.W. | RW | RW<br>W | RW | RW | | | | | | | Name | | TIMEOUTCBLSB | TIMEOUTSTEADY | CTUNEXOSTARTUP | CTUNEXISTARTUP | COREBIASSTARTUP | COREBIASSTARTUPI | | | | | | | Bit | Name | Reset Access | | Description | | | | | | | | | |-------|---------------------------|--------------|--------------------|-------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:28 | Reserved | To ensure o | compatibility witl | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 27:24 | TIMEOUTCBLSB | 0x4 | RW | Core Bias LSB Change Timeout | | | | | | | | | | | wait duration for the COI | REBIAS chan | ge 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 | 0x4 | RW | Steady State Timeout | | | wait duration for the ste | ady state sett | ings to settle out | t | | | Value | Mode | | Description | | | 0 | T16US | | The steady state timeout is set to 16 us minimum. The maximum can be +40%. | | | 1 | T41US | | The steady state timeout is set to 41 us minimum. The maximum can be +40%. | | | 2 | T83US | | The steady state timeout is set to 83 us minimum. The maximum can be +40%. | | | 3 | T125US | | The steady state timeout is set to 125 us minimum. The maximum can be +40%. | | | 4 | T166US | | The steady state timeout is set to 166 us minimum. The maximum can be +40%. | | | 5 | T208US | | The steady state timeout is set to 208 us minimum. The maximum can be +40%. | | | 6 | T250US | | The steady state timeout is set to 250 us minimum. The maximum can be +40%. | | | 7 | T333US | | The steady state timeout is set to 333 us minimum. The maximum can be +40%. | | | 8 | T416US | | The steady state timeout is set to 416 us minimum. The maximum can be +40%. | | | 9 | T500US | | The steady state timeout is set to 500 us minimum. The maximum can be +40%. | | | 10 | T666US | | The steady state timeout is set to 666 us minimum. The maximum can be +40%. | | | 11 | T833US | | The steady state timeout is set to 833 us minimum. The maximum can be +40%. | | | 12 | T1666US | | The steady state timeout is set to 1666 us minimum. The maximum can be +40%. | | | 13 | T2500US | | The steady state timeout is set to 2500 us minimum. The maximum can be +40%. | | | 14 | T4166US | | The steady state timeout is set to 4166 us minimum. The maximum can be +40%. | | | 15 | T7500US | | The steady state timeout is set to 7500 us minimum. The maximum can be +40%. | | 19:16 | CTUNEXOSTARTUP | 0x3 | RW | Startup Tuning Capacitance on XO | | | 4 most significant bits of | of CTUNEXOA | NA applied duri | ng startup phase | | 15:12 | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|----------------------------|-----------|------------------|----------------------------------------|--|--|--|--|--|--|--|--| | | 4 most significant bits of | CTUNEXIAN | A applied during | g startup phase | | | | | | | | | | 11:6 | COREBIASSTARTUP | 0x13 | RW | Startup Core Bias Current | | | | | | | | | | | 6 most significant bits of | COREBIASA | NA applied duri | ng startup phase | | | | | | | | | | 5:0 | COREBIASSTARTUPI | 0xB | RW | Intermediate Startup Core Bias Current | | | | | | | | | | | 6 most significant bits of | COREBIASA | NA applied duri | ng intermediate startup phase | | | | | | | | | ### 9.2.5.3 HFXO\_XTALCTRL - Crystal Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | | | |--------|-----------------|----|----|----|--------------|------------|--------------|-------------|----|-------------------------------------|--|--|--|--|----|------|-------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|--|--|--|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--|--|--|---|--|--|--| | 0x018 | 31 | 30 | 59 | 28 | 27 | 26 | 25 | 24 | 23 | 22 22 23 23 24 19 19 19 19 19 19 19 | | | | | | | | | 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 <th colspan="7">7 9 4 6 7 1 1 2 1 2 2 4 5 6 7 7 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10<!--</th--></th> | | | | | | | 7 9 4 6 7 1 1 2 1 2 2 4 5 6 7 7 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 </th | | | | | | | | | | Reset | 0x0 | | | • | 2 | S | 2,2 | S | | 0X<br>8C | | | | | | | | | 0x8C | | | | | | | | 0×10 | | | | | | | | | Access | Z<br>N | | | | 20 | 2 | 2 | <u>}</u> | | Z.W. | | | | | | | | RW | | | | | | | | W.W. | | | | | | | | | | Name | SKIPCOREBIASOPT | | | | COBEDCENIANA | CONFIDENCE | VIA VIA DIVI | CIONETIANIA | | CTUNEXOANA | | | | | | | | | | L<br>L | CLUNEXIANA | | | | COREBIASANA | | | | | | _ | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|---------------------------|--------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31 | SKIPCOREBIASOPT | 0x0 | RW | Skip Core Bias Optimization | | | | | | | | | | | | | | m at next startup. Reuse the value stored in COREBIASANA. At the on algorithm, hardware sets this bit to skip optimization during sub- | | | | | | | | | | 30:28 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 27:26 | COREDGENANA | 0x3 | RW | Core Degeneration | | | | | | | | | | | Core degeneration control | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | 0 | NONE | | Do not apply core degeneration resistence | | | | | | | | | | | 1 | DGEN33 | | Apply 33 ohm core degeneration resistence | | | | | | | | | | | 2 | DGEN50 | | Apply 50 ohm core degeneration resistence | | | | | | | | | | | 3 | DGEN100 | | Apply 100 ohm core degeneration resistence | | | | | | | | | | 25:24 | CTUNEFIXANA | 0x3 | RW | Fixed Tuning Capacitance | | | | | | | | | | | Adds or removes fixed | capacitance o | on XI or XO | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | 0 | NONE | | Remove fixed capacitance on XI and XO nodes | | | | | | | | | | | 1 | XI | | Adds fixed capacitance on XI node | | | | | | | | | | | 2 | XO | | Adds fixed capacitance on XO node | | | | | | | | | | | 3 | вотн | | Adds fixed capacitance on both XI and XO nodes | | | | | | | | | | 23:16 | CTUNEXOANA | 0x8C | RW | Tuning Capacitance on XO | | | | | | | | | | | Approximately 80fF per | step. 0 is mir | n. 255 is max. | | | | | | | | | | | 15:8 | CTUNEXIANA | 0x8C | RW | Tuning Capacitance on XI | | | | | | | | | | | Approximately 80fF per | step. 0 is mir | n. 255 is max. | | | | | | | | | | | 7:0 | COREBIASANA | 0x10 | RW | Core Bias Current | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-----|------------------------|-------|--------|-------------| | | Approximately 10uA per | step | | | # 9.2.5.4 HFXO\_CFG - Configuration Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|----------------|---------------|---|--------| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | • | | • | | | • | | | | | | | | | | • | • | • | | | | | | | • | | 0X0 | 0×0 | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | §<br>S | R<br>M | | ₩<br>N | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | SQBUFSCHTRGANA | ENXIDCBIASANA | | MODE | | Bit | Name | Reset | Access | Description | |------|---------------------------|--------------------|--------------------|------------------------------------------------------------------------| | ы | Itanie | | | | | 31:4 | Reserved | To ensure ventions | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 3 | SQBUFSCHTRGANA | 0x0 | RW | Squaring Buffer Schmitt Trigger | | | Used in EXTCLK mode | to prevent se | If oscillation | | | | Value | Mode | | Description | | | 0 | DISABLE | | Squaring buffer schmitt trigger is disabled | | | 1 | ENABLE | | Squaring buffer schmitt trigger is enabled | | 2 | ENXIDCBIASANA | 0x0 | RW | Enable XI Internal DC Bias | | | Set to enable internal D | C bias. Bit is i | gnored in XTAL | mode. | | 1 | Reserved | To ensure ventions | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | MODE | 0x0 | RW | Crystal Oscillator Mode | | | Set this to configure the | external sour | ce for the HFXC | ). | | | Value | Mode | | Description | | | 0 | XTAL | | crystal oscillator | | | 1 | EXTCLK | | external sinusoidal clock can be supplied on XI pin. | | | | | | | # 9.2.5.5 HFXO\_CTRL - Control Register | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|----------------|----------------|---|----------|-------------|---------| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | • | • | • | | | | | | • | • | • | • | | | | | | | | • | • | 0X0 | 0x0 | | 0x0 | 0x1 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | Z. | W. | | Z. | ZW<br>W | A.W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | FORCEX02GNDANA | FORCEXIZGNDANA | | KEEPWARM | DISONDEMAND | FORCEEN | | Bit | Name | Reset | Access | Description | |------|------------------------------------------------------|--------------------|--------------------|-------------------------------------------------------------------------| | | | | | | | 31:6 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 5 | FORCEXO2GNDANA | 0x0 | RW | Force XO Pin to Ground | | | Set to enable grounding | g of XO pin. | | | | | Value | Mode | | Description | | | 0 | DISABLE | | Disabled (not pulled) | | | 1 | ENABLE | | Enabled (pulled) | | 4 | FORCEXI2GNDANA | 0x0 | RW | Force XI Pin to Ground | | | Set to enable grounding | g of XI pin. Do | not enable if Mo | ODE=EXTCLK and an external source is supplied. | | | Value | Mode | | Description | | | 0 | DISABLE | | Disabled (not pulled) | | | 1 | ENABLE | | Enabled (pulled) | | 3 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 2 | KEEPWARM | 0x0 | RW | Keep Warm | | | Upon disable, if this bit effect until the next disa | | oscillator will ke | ep running, while clock output is shutoff. Clearing this bit has no | | 1 | DISONDEMAND | 0x1 | RW | Disable On-demand Mode | | | Set to ignore hardware CTRL registers while F | | | scillator. This bit must be set in order to modify various CFG and | | 0 | FORCEEN | 0x0 | RW | Force Enable | | | | | | | # 9.2.5.6 HFXO\_CMD - Command Register | Offset | Bit Position | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------| | 0x050 | 33 34 36 37 38 39 30 30 30 31 32 33 34 35 36 37 38 39 30 30 30 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>- 0</th> | - 0 | | Reset | | 000 | | Access | | 3 3 | | Name | | MANUALOVERRIDE<br>COREBIASOPT | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1 | MANUALOVERRIDE | 0x0 | W | Manual Override | | | | | | ate completes, switch analog control signals from FSM to APB, aly issue this command when COREBIASOPTRDY is asserted, or the | | 0 | COREBIASOPT | 0x0 | W | Core Bias Optimizaton | | | ture changes by more th | nan 40degC. | Do not run this | and runs it one time. Optimization should be executed if the tempera-<br>command while the radio is in RX or TX modes. Do not issue this<br>Y is asserted, or the previous command may be cancelled. | # 9.2.5.7 HFXO\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------|---------|----|----|----|----|----|----|----|----|----|----|--------|----|-------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|----------------|-----| | 0x058 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | 0×0 | | • | • | | | | | | • | • | 000 | | 0x0 | 0x0 | | • | | | | • | | | | • | • | • | | | 0X0 | 0x0 | | Access | 2 | 22 | | | | | | | | | | | œ | | 22 | œ | | | | | | | | | | | | | | | œ | ~ | | Name | LOCK | FSMLOCK | | | | | | | | | | | ISWARM | | HWREQ | ENS | | | | | | | | | | | | | | | COREBIASOPTRDY | RDY | | Bit | Name | Reset | Access | Description | |-------|----------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31 | LOCK | 0x0 | R | Configuration Lock Status | | | Indicates the current sta | atus of config | uration lock | | | | Value | Mode | | Description | | | 0 | UNLOCK | ED | Configuration lock is unlocked | | | 1 | LOCKED | | Configuration lock is locked | | 30 | FSMLOCK | 0x0 | R | FSM Lock Status | | | Indicates the current sta | atus of config | uration locked by | y FSM running | | | Value | Mode | | Description | | | 0 | UNLOCK | ΞD | FSM lock is unlocked | | | 1 | LOCKED | | FSM lock is locked | | 29:20 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 19 | ISWARM | 0x0 | R | Oscillator Is Kept Warm | | | Oscillator is currently ke | ept in warm s | tate. Re-eable fr | om warm state skips startup sequence | | 18 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 17 | HWREQ | 0x0 | R | Oscillator Requested by Hardware | | | Oscillator is requested by | oy hardware. | | | | 16 | ENS | 0x0 | R | Enabled Status | | | Oscillator is enabled. | | | | | 15:2 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 1 | COREBIASOPTRDY | 0x0 | R | Core Bias Optimization Ready | | | Core bias optimization a | algorithm is c | omplete. New co | ore bias value updated to XTALCTRL. | | 0 | RDY | 0x0 | R | Ready Status | | | Oscillator is enabled an | d start-up tim | ne has exceeded | | # 9.2.5.8 HFXO\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----------------|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|----------------|--------| | 0x070 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 000 | | 000 | | • | | ' | | | | | | ' | | | <u>'</u> | | | | ' | | ' | | ' | • | | ' | ' | ' | ' | 000 | 0x0 | | Access | R<br>W | | ₩<br>M | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | A<br>W | | Name | COREBIASOPTERR | | DNSERR | | | | | | | | | | | | | | | | | | | | | | | | | | | | COREBIASOPTRDY | RDY | | Bit | Name | Reset | Access | Description | |------|-----------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31 | COREBIASOPTERR | 0x0 | RW | Core Bias Optimization Error Interrupt | | | Core bias current optimiz | zation algorith | m fails to compl | ete. | | 30 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 29 | DNSERR | 0x0 | RW | Did Not Start Error Interrupt | | | Crystal oscillator fails to | startup. | | | | 28:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | COREBIASOPTRDY | 0x0 | RW | Core Bias Optimization Ready Interrupt | | | Core bias current optimiz | zation algorith | m is complete. | | | 0 | RDY | 0x0 | RW | Ready Interrupt | | | Oscillator is ready (start- | up time excee | eded). | | # 9.2.5.9 HFXO\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----------------|----|--------|----|----|----|----|----|----|----|---|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|----------------|--------| | 0x074 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 41 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | | 000 | | | • | • | | | | | | | • | | • | | • | | | | | | | | | • | • | • | | 0x0 | 0x0 | | Access | ₩<br>M | | Z. | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | A<br>M | | Name | COREBIASOPTERR | | DNSERR | | | | | | | | | | | | | | | | | | | | | | | | | | | | COREBIASOPTRDY | RDY | | Bit | Name | Reset | Access | Description | | | | | | | |------|-----------------------------|------------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--| | 31 | COREBIASOPTERR | 0x0 | RW | Core Bias Optimization Error Interrupt | | | | | | | | | Core bias current optimiz | zation algorith | m fails to compl | ete. | | | | | | | | 30 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 29 | DNSERR | 0x0 | RW | Did Not Start Error Interrupt | | | | | | | | | Crystal oscillator fails to | startup. | | | | | | | | | | 28:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 1 | COREBIASOPTRDY | 0x0 | RW | Core Bias Optimization Ready Interrupt | | | | | | | | | Core bias current optimiz | zation algorith | m is complete. | | | | | | | | | 0 | RDY | 0x0 RW Ready Interrupt | | | | | | | | | | | Oscillator is ready (start- | up time excee | eded). | | | | | | | | ### 9.2.5.10 HFXO\_LOCK - Configuration Lock Register | Offset | Bit Po | sition | |--------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x080 | 33<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>3 | 4 6 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | | Reset | | 0x580E | | Access | | > | | Name | | LOCKKEY | | Name | Reset | Access | Description | |--------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------| | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | LOCKKEY | 0x580E | W | Configuration Lock Key | | Write any other value th | an the unlock | code to lock reg | gisters from editing. Write the unlock code to unlock. | | Value | Mode | | Description | | 22542 | UNLOCK | | Write this value to unlock | | | Reserved LOCKKEY Write any other value th | Reserved To ensure of ventions LOCKKEY 0x580E Write any other value than the unlock Value Mode | Reserved To ensure compatibility with ventions LOCKKEY 0x580E W Write any other value than the unlock code to lock reg Value Mode | ### 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 (HFRCODPLL) - · 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 Hardware can request to enable the HFRCO by setting the HFRCO\_STATUS.HWREQ bit field. The HFRCO can also optionally be configured via the HFRCO\_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. 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 the which peripheral is requesting the clock.) ### 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. Band-change would de-assert RDY as it would go through another ### 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 the it. Which in most cases is whenever the module 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 | Туре | 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 | | | | | | | | | | | | |--------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x000 | 0 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | | | | | | | | | | | | | Reset | 8 | | | | | | | | | | | | | Access | <u>~</u> | | | | | | | | | | | | | Name | IPVERSION | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x1 | R | IP Version | | | The read only IPVERSION | • | | this module. There may be minor software changes required for | # 9.3.5.2 HFRCO\_CTRL - Ctrl Register | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|-------------|---------| | 0x004 | 33 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 41 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | • | • | • | | | | | | • | | | • | • | | • | | | | | | | | | • | • | | • | • | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | RW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DISONDEMAND | FORCEEN | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|----------------------------|------------------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 1 | DISONDEMAND | 0x0 | RW | Disable On-demand | | | | | | | | | | | Setting this bit disable H | FRCO on-der | nand feature | | | | | | | | | | | 0 | FORCEEN | 0x0 | RW | Force Enable | | | | | | | | | | | Setting this bit force HFF | 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 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 2 | X<br>X | | 5 | 7 | 5 | OXO | | 0x3 | | | • | 0x8 | | • | 0x1 | | | | 2 | | | | | | 0x7F | | | | | | | Access | | 7 | ≥<br>Ľ | | 2 | <u>}</u> | 2 | ≥<br>Y | | R<br>≪ | | | | R | | | RW | | RW | | | | | | | | RW | | | | | | | Name | | CTO | - | | CMD | CINITORI | 3 3 | CLAU! | | CMPBIAS | | | | FREQRANGE | | | ГРОНР | | | | CININI | _ | | | | | | | TUNING | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | | |-------|-------------------------|--------------------|-------------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | | | | | · | | | | | | | | | | | | 31:28 | IREFTC | 0xA | RW | Tempco Trim on Comparator Current | | | | | | | | | | | | | Writing this field adju | usts the tempera | ture coefficient | trim on comparator current. | | | | | | | | | | | | 27:26 | CMPSEL | 0x2 | RW | Comparator Load Select | | | | | | | | | | | | | Writing this field adju | usts the active lo | ad for compara | ators. | | | | | | | | | | | | 25:24 | CLKDIV | 0x0 | RW | Locally Divide HFRCO Clock Output | | | | | | | | | | | | | Writing this field con | figures the HFR | CO clock outpu | it divider. | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | 0 | DIV1 | | Divide by 1. | | | | | | | | | | | | | 1 | DIV2 | | Divide by 2. | | | | | | | | | | | | | 2 | DIV4 | | Divide by 4. | | | | | | | | | | | | 23:21 | CMPBIAS | 0x3 | RW | Comparator Bias Current | | | | | | | | | | | | | Writing this field adju | usts the HFRCO | comparator bia | as current. | | | | | | | | | | | | 20:16 | FREQRANGE | 0x8 | RW | Frequency Range | | | | | | | | | | | | | Writing this field adju | usts the HFRCO | frequency rang | ge. | | | | | | | | | | | | 15 | LDOHP | 0x1 | RW | LDO High Power Mode | | | | | | | | | | | | | Settings this bit puts | the HFRCO LD | O in high powe | r mode. | | | | | | | | | | | | 14 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 13:8 | FINETUNING | 0x1F | RW | Fine Tuning Value | | | | | | | | | | | | | Writing this field adju | usts the HFRCC | fine tuning valu | ue. Higher value means lower frequency. | | | | | | | | | | | | 7 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 6:0 | TUNING | 0x7F | RW | Tuning Value | | | | | | | | | | | | | Writing this field adju | usts the HFRCO | tuning value. H | ligher value means lower frequency. | | | | | | | | | | | | | • | | - | • | | | | | | | | | | | # 9.3.5.4 HFRCO\_STATUS - Status Register | Offset | | Bit Po | | | | | | | | | | | | | t Po | siti | on | | | | | | | | | | | | | | | | |--------|------|--------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|---|----|----|---|----|---|---|---|---|---|---|---|----------|---------|----------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | 0x0 | | • | • | | • | | | | • | | | • | | | 000 | | | | | | | | | | • | • | | • | 0x0 | 000 | 0x0 | | Access | 2 | | | | | | | | | | | | | | | œ | | | | | | | | | | | | | | œ | œ | <u>~</u> | | Name | LOCK | | | | | | | | | | | | | | | ENS | | | | | | | | | | | | | | SYNCBUSY | FREQBSY | RDY | | Bit | Name | Reset | Access | Description | |-------|----------------------------|-----------------|--------------------|----------------------------------------------------------------------| | 31 | LOCK | 0x0 | R | Lock Status | | | If set, all HFRCO lockab | le registers ar | e locked. | | | | Value | Mode | | Description | | | 0 | UNLOCKE | ) | HFRCO is unlocked | | | 1 | LOCKED | | HFRCO is locked | | 30:17 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 16 | ENS | 0x0 | R | Enable Status | | | HFRCO is enabled. | | | | | 15:3 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 2 | SYNCBUSY | 0x0 | R | Synchronization Busy | | | This bit is set when there | e is an ongoin | g synchronizatio | n of CAL register bitfields. | | 1 | FREQBSY | 0x0 | R | Frequency Updating Busy | | | HFRCO is busy updating | g frequency. | | | | 0 | RDY | 0x0 | R | Ready | | | HFRCO is enabled and | start-up time h | nas exceeded. | | # 9.3.5.5 HFRCO\_IF - Interrupt Flag Register | Offset | Bit Position | | |--------|-----------------------------------------|-------| | 0x010 | 3 3 4 4 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 | 0 7 2 | | Reset | | 0x0 | | Access | | RW | | Name | | RDY | | Bit | Name | Reset | Access | Description | |------|-----------------------|------------------|--------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | RDY | 0x0 | RW | Ready Interrupt Flag | | | Set when HFRCO is rea | dy (start-up tii | me 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 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | | | | | | | | | | • | | | | | | | | | | | • | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RDY | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | RDY | 0x0 | RW | RDY Interrupt Enable | | | Enable/disable the RDY | interrupt | | | ### 9.3.5.7 HFRCO\_LOCK - Lock Register | Offset | Bit Pos | sition | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x01C | 33 34 35 36 37 38 39 30 31 32 33 34 35 36 37 38 39 30 30 30 31 32 33 34 36 37 37 38 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>7 4 8 7 7 7 0 8 6 0 4 8 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6</th> | 7 4 8 7 7 7 0 8 6 0 4 8 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 | | Reset | | 0x8195 | | Access | | <u> </u> | | Name | | LOCKKEY | | Bit | Name | Reset | Access | Description | |-------|--------------------|----------------------|---------------|---------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0x8195 | W | Lock Key | | | Write any other va | llue 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<sub>REF</sub>\*(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. - 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 FRSCO 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 should be used unless specific phase requirement exists. ### 9.4.3.3 Configurations The formula for the DPLL output frequency is FREF\*(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. DPLLLOCKFAILLOW is set when the DPLL fails to lock because the period lower boundary is hit. DPLLLOCKFAILHIGH 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 DPLLLOCKFAILLOW 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 DPLLLOCKFAILHIGH 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 DPLLLOCKFAILLOW or DPLLLOCKFAILHIGH 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 DPLLLOCKFAILLOW or DPLLLOCKFAILHIGH 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 | Туре | 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 | 33 34 4 5 6 6 6 7 7 8 8 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | | Reset | 0×0 | | Access | α | | Name | IPVERSION | | Bit | Name | Reset | Access | Description | |------|------------------------|---------------|-------------------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP Version ID | | | The read only IPVERSIO | N field gives | the version for t | this module. There may be minor software changes required for | modules with different values of IPVERSION. # 9.4.5.2 DPLL\_EN - Enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|-----| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | | | | • | | | | | | | | | | | | • | | | | | | | | | | | | 0×0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₽ | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z | | Bit | Name | Reset | Access | Description | |------|----------|-------------|--------------------|--------------------------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | Module Enable | | | | | | d write to CONFIG type registers before setting the ENABLE bit. er setting the ENABLE bit. | # 9.4.5.3 DPLL\_CFG - Config | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----------|------|----|----|----|---|----|---|---|---|--------|---|---|---|-------------|---------|------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | ' | | | | | | | | ' | • | | <u>'</u> | • | | | ' | | ' | | • | ' | 0X0 | | | • | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | | | | W. | ₹ | W. | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | DITHEN | | | | AUTORECOVER | EDGESEL | MODE | | Bit | Name | Reset | Access | Description | |------|--------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:7 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 6 | DITHEN | 0x0 | RW | Dither Enable Control | | | Set to enable dither ful | nction | | | | 5:3 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 2 | AUTORECOVER | 0x0 | RW | Automatic Recovery Control | | | Set to enable automati | c recovery fun | ction | | | 1 | EDGESEL | 0x0 | RW | Reference Edge Select | | | This bit controls which | edge of refere | nce is detected | | | 0 | MODE | 0x0 | RW | Operating Mode Control | | | This bit controls which | mode DPLL is | operating when | enabled | | | Value | Mode | | Description | | | 0 | FLL | | Frequency Lock Mode | | | 1 | PLL | | Phase Lock Mode | | | | | | | # 9.4.5.4 DPLL\_CFG1 - Config1 | Offset | | | | | | | | | | | | | | | Bi | t Po | ositi | on | | | | | | | | | | | | | | | |--------|----|----|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|---|----|------|-------|----|----|----|----|----|---|---|---|---|----------|---|---|---|---|---| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - | 0 | | Reset | | | χ<br>ω ψ ψ ψ ψ ψ ψ ψ ψ ψ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | 2 | 2 | | | | | | | | | | | | | | | i | <b>≷</b> | | | | | | | Name | | | | | | | | | | Z | 2 | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|----------------|-------------------|------------------------------------------------------------------------| | 31:28 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 27:16 | N | 0x0 | RW | Factor N | | | The locked DCO freque | ncy is given b | y: Fdco = Fref * | (N + 1)/(M+1). N is required to be larger than 300. | | 15:12 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 11:0 | M | 0x0 | RW | Factor M | | | The locked DCO freque | ncy is given b | y: Fdco = Fref * | (N + 1)/(M+1). M can be any value. | # 9.4.5.5 DPLL\_IF - Interrupt Flag | Offset | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|-------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------------|-------------|------| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | • | • | • | | | • | | | | | | • | | | | | | | | | | • | | | | | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | RW | S. | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LOCKFAILHIGH | LOCKFAILLOW | LOCK | | Bit | Name | Reset | Access | Description | |------|--------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:3 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 2 | LOCKFAILHIGH | 0x0 | RW | Lock Failure High Interrupt Flag | | | Set when DPLL fail to lo | ck because of | period overflow | <i>1</i> . | | 1 | LOCKFAILLOW | 0x0 | RW | Lock Failure Low Interrupt Flag | | | Set when DPLL fail to lo | ck because of | period underflo | w. | | 0 | LOCK | 0x0 | RW | Lock Interrupt Flag | | | Set when DPLL achieve | the lock. | | | # 9.4.5.6 DPLL\_IEN - Interrupt Enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----|---|---|---|---|---|--------------|-------------|--------| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | | | | | | | • | | ' | • | | | | | | | ' | ' | | ' | | | | • | ' | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | W. | S<br>N | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LOCKFAILHIGH | LOCKFAILLOW | LOCK | | Bit | Name | Reset | Access | Description | |------|-----------------------|-----------------------|------------------|-------------------------------------------------------------------------| | 31:3 | Reserved | To ensure<br>ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 2 | LOCKFAILHIGH | 0x0 | RW | LOCKFAILHIGH Interrupt Enable | | | LOCKFAILHIGH Interru | ıpt Enable | | | | 1 | LOCKFAILLOW | 0x0 | RW | LOCKFAILLOW Interrupe Enable | | | LOCKFAILLOW Interru | pe Enable | | | | 0 | LOCK | 0x0 | RW | LOCK interrupt Enable | | | LOCK interrupt Enable | | | | # 9.4.5.7 DPLL\_STATUS - Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-----|-----| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | ∞ | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | 000 | | • | • | | | | | • | | • | • | | | | • | | • | | | | | | • | | • | • | | • | | 0x0 | 0x0 | | Access | 2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Я | ~ | | Name | LOCK | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ENS | RDY | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31 | LOCK | 0x0 | R | Lock Status | | | Indicates the current sta | tus of configu | ration lock | | | | Value | Mode | | Description | | | 0 | UNLOCKE | D | DPLL is unlocked | | | 1 | LOCKED | | DPLL is locked | | 30:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | ENS | 0x0 | R | Enable Status | | | DPLL is enabled. | | | | | 0 | RDY | 0x0 | R | Ready Status | | | DPLL is enabled and loo | cked. | | | # 9.4.5.8 DPLL\_LOCK - Lock | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|----------------------------------------|---------|---|---|---|---|---|---|---| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | • | • | | | | | | | | • | | | • | • | | | | • | | 701./X0 | | • | | • | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | \ \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | LOCKNEY | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | |-------|--------------------|----------------------|---------------|---------------------------------------------------------------------------|--|--|--|--|--|--| | 31:16 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 15:0 | LOCKKEY | 0x7102 | W | Lock Key | | | | | | | | | Write any other va | alue than the unlock | code to lock | k 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 BUFEXTCLK, 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 DIGEXTCLK, 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 The clock should not be used immediately after enabling LFXO, until the clock 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 TIMEOUT bit field in the LFXO\_CFG register. The TIMEOUT default value is set the 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 DIGEXTCLK 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 POSEDG-EIEN 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 FORCE-OFF 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 | Туре | 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 | Туре | 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 | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x000 | 33 34 37 38 39 30 30 31 32 33 34 35 36 37 38 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×0 | | Access | α | | Name | IPVERSION | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------|---------------|--|--|--|--|--|--|--|--| | 31:0 | IPVERSION | 0x0 | R | IP Version ID | | | | | | | | | | | The read only IPVERSIOn modules with different values | ON field gives the version for this module. There may be minor software changes required for values of IPVERSION. | | | | | | | | | | | # 9.5.5.2 LFXO\_CTRL - LFXO Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|----------------|-----------|---|---|--------------|---------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | • | | | | | • | | | • | | | • | • | | | • | | | | • | 0x0 | 0×0 | | | 0 <u>×</u> 1 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | Z. | RW | | | %<br>M | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | FAILDETEM4WUEN | FAILDETEN | | | DISONDEMAND | FORCEEN | | Bit | Name | Reset | Access | Description | |------|----------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 5 | FAILDETEM4WUEN | 0x0 | RW | LFXO Failure Detection EM4WU Enable | | | Set this bit to enable EM | 14 exit on the | oscillator failure | detection. | | 4 | FAILDETEN | 0x0 | RW | LFXO Failure Detection Enable | | | Set this bit to enable the | oscillator fail | ure detection fea | ature. Note that setting this bit will enable the oscillator core. | | 3:2 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | DISONDEMAND | 0x1 | RW | LFXO Disable On-demand requests | | | Set this bit to disable Or | n-demand requ | uests. | | | 0 | FORCEEN | 0x0 | RW | LFXO Force Enable | | | Set this bit to enable the | oscillator cor | e. The oscillator | core is enabled regardless of On-demand requests. | # 9.5.5.3 LFXO\_CFG - LFXO Configuration Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---------|---|---|---|------|---|---|---|----------|-----| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | • | | | • | | • | | | | • | | • | | | | | 0x7 | | | | 2 | 3 | | • | 0x0 | 0x1 | | Access | | | | | | | | | | | | | | | | | | | | | | | RW | | | | 2 | 2 | | | RW | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | TIMEOUT | | | | ПСОМ | 7 | | | HIGHAMPL | AGC | | Bit | Name | Reset | Access | Description | | | | | | | | |-------|--------------------|--------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:11 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 10:8 | TIMEOUT | 0x7 | RW | LFXO Start-up Delay | | | | | | | | | | Configures the sta | rt-up delay for LF | XO. | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 0 | CYCLES2 | 2 | Timeout period of 2 cycles | | | | | | | | | | 1 | CYCLES | 256 | Timeout period of 256 cycles | | | | | | | | | | 2 | CYCLES | 1K | Timeout period of 1024 cycles | | | | | | | | | | 3 | CYCLES2 | 2K | Timeout period of 2048 cycles | | | | | | | | | | 4 | CYCLES4 | 4K | Timeout period of 4096 cycles | | | | | | | | | | 5 | CYCLES | ЗК | Timeout period of 8192 cycles | | | | | | | | | | 6 | CYCLES | 16K | Timeout period of 16384 cycles | | | | | | | | | | 7 | CYCLES | 32K | Timeout period of 32768 cycles | | | | | | | | | 7:6 | Reserved | To ensure ventions | e compatibility w | ith future devices, always write bits to 0. More information in 1.2 Co | | | | | | | | | 5:4 | MODE | 0x0 | RW | LFXO Mode | | | | | | | | | | 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 | BUFEXTO | CLK | 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 | DIGEXTO | CLK | 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 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 1 | HIGHAMPL | 0x0 | RW | LFXO High Amplitude Enable | | | | | | | | | | | Set this bit to enable | high XTAL osci | llation amplitud | de. | | | | | | | | | | 0 | AGC | 0x1 RW LFXO AGC Enable | | | | | | | | | | | | | Set this bit to enable automatic gain control which limits XTAL oscillation amplitude. | | | | | | | | | | | | # 9.5.5.4 LFXO\_STATUS - LFXO Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|-----| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | | | | | • | | | | • | | | • | | | 0x0 | | • | • | | | | | • | • | • | • | | | | | 0x0 | | Access | œ | | | | | | | | | | | | | | | œ | | | | | | | | | | | | | | | | ~ | | Name | LOCK | | | | | | | | | | | | | | | ENS | | | | | | | | | | | | | | | | RDY | | Bit | Name | Reset | Access | Description | |-------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31 | LOCK | 0x0 | R | LFXO Locked Status | | | If set, all LFXO lockable | registers are | locked. | | | | Value | Mode | | Description | | | 0 | UNLOCKE | D | LFXO lockable registers are not locked | | | 1 | LOCKED | | LFXO lockable registers are locked | | 30:17 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 16 | ENS | 0x0 | R | LFXO Enable Status | | | LFXO is enabled. | | | | | 15:1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | RDY | 0x0 | R | LFXO Ready Status | | | LFXO is enabled and sta | art-up time ha | s 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 | 7 | 9 | 6 | ∞ | 7 | 9 | 2 | 4 | 3 | 2 | - ( | 0 | | Reset | | | | | | | | | • | | | | | | | • | | | | • | | | Ç | X | | | | | 0x0 | | • | | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | W<br>M | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | - | ZIK 5 | | | | | CAPTUNE | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------------------|----------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | e compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | GAIN | 0x2 | RW | LFXO Startup Gain | | | The optimal value dep | ends on the c | hosen crystal. | | | 7 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 6:0 | CAPTUNE | 0x0 | RW | Internal Capacitance Tuning | | | tuning capacitances or<br>value must only be inc | n both pins sy<br>cremented or c | mmetrically. CA<br>decremented by | een X_N pin and ground and X_P pin and ground. The bus affects PTUNE value must not exceed 0x4F. When updating CAPTUNE, its 1 which provides a tuning step of 0.25pF. The maximum value is tasheet for more information. | # 9.5.5.6 LFXO\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|---|---|---|---|---|---------|---------|---------|-----| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | • | • | | ' | | | | | | | | ' | • | | <u>'</u> | | ' | | | | ' | • | | • | | ' | | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | S.<br>≷ | W. | ₩<br>M | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | FAIL | NEGEDGE | POSEDGE | RDY | | Bit | Name | Reset | Access | Description | |------|-------------------|----------------------|-----------------|---------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 3 | FAIL | 0x0 | RW | LFXO Failure Interrupt Flag | | | Set when LFXO fa | ilure is detected. \ | Write 1 to clea | r the interrupt flag. | | 2 | NEGEDGE | 0x0 | RW | Falling Edge Interrupt Flag | | | Triggers on every | negative edge of t | he LFXO cloc | k. | | 1 | POSEDGE | 0x0 | RW | Rising Edge Interrupt Flag | | | Triggers on every | positive edge of th | ne LFXO clock | | | 0 | RDY | 0x0 | RW | LFXO Ready Interrupt Flag | | | Set when LFXO is | ready (start-up tin | ne exceeded) | . Write 1 to clear the interrupt flag. | # 9.5.5.7 LFXO\_IEN - Interrupt Enable Register | Offset | Bit Position | | | |--------|------------------------------------------|---------|---------------------------------------| | 0x01C | 33 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | 2 0 | - 0 | | Reset | 98 | 000 | 0% | | Access | | N N | % % % % % % % % % % % % % % % % % % % | | Name | EA | NEGEDGE | POSEDGE<br>RDY | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3 | FAIL | 0x0 | RW | LFXO Failure Interrupt Enable | | | Write 1 to enable FAILIF | | | | | 2 | NEGEDGE | 0x0 | RW | Falling Edge Interrupt Enable | | | Write 1 to enable NEGE | OGEIF. | | | | 1 | POSEDGE | 0x0 | RW | Rising Edge Interrupt Enable | | | Write 1 to enable POSEI | OGEIF. | | | | 0 | RDY | 0x0 | RW | LFXO Ready Interrupt Enable | | | Write 1 to enable RDYIF | | | | # 9.5.5.8 LFXO\_SYNCBUSY - LFXO Sync Busy Register | Offset | Bit Position | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | 0x020 | 33 34 35 36 37 38 39 30 30 31 32 33 34 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 5 6 6 6 6 6 7 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 | - 0 | | Reset | | 0x0 | | Access | | <u>~</u> | | Name | | CAL | | Bit | Name | Reset | Access | Description | |------|----------------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:1 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 0 | CAL | 0x0 | R | LFXO Synchronization status | | | This bit is set when bit is set. | there is an ongo | oing synchroniz | zation of CAL register bitfields. Do not write to CAL register while this | ### 9.5.5.9 LFXO\_LOCK - Configuration Lock Register | Offset | Bit Po | sition | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x024 | 33 34 35 36 37 38 39 30 30 31 32 33 34 35 36 37 38 39 30 30 30 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>2 4 5 4 6 7 7 7 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10</th> | 2 4 5 4 6 7 7 7 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | | Reset | | 0x1A20 | | Access | | > | | Name | | LOCKKEY | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0x1A20 | W | Lock Key | | | Write any other value t | han 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 interenal 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 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. Please 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 startup, it may take two cycles for the clock to propagate through the CMU to the peripherals. ### 9.6.3.2 On-Demand Clocking Hardware can request to enable the LFRCO by setting the LFRCO\_STATUS.HWREQ bit field. The LFRCO can also optionally be configured via the LFRCO\_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. ### 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 automatilcally 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\_STA-TUS\_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. By default, a 38.4 MHz crystal clock source is assumed. 38.4 MHz is the only frequency supported by many of Silicon Labs' RF software stacks, and the default value should not normally be changed. Precision mode does support operation with different frequency crystals, however. Two registers (LFRCO\_NOMCALCNT and LFRCO\_NOMCALCNTINV) are used to specify the nominal relationship between the reference clock and the LFRCO frequency as shown in Figure 9.2 LFRCO\_NOMCALCNT Calculation on page 214 and Figure 9.3 LFRCO\_NOMCALCNTINV Calculation on page 214. NOMCALCNT and NOMCALCNTINV must be set up while the LFRCO is not enabled. $NOMCALCNT = (320 * f_{HFXO}) / 32768$ Where f<sub>HFXO</sub> is the reference crystal frequency in Hz Figure 9.2. LFRCO NOMCALCNT Calculation NOMCALCNTINV = (1 / NOMCALCNT) \* 233 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 SCHEDERRIF 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 | Туре | 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 | Туре | 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 | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----|-------------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x000 | 33 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | | | | | | | | | | 2 | 5 | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | ואטוספטייפו | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------|----------------|-----------------|---------------| | 31:0 | IPVERSION | 0x1 | R | IP version ID | | | Reading this register retu | urns the ip ve | rsion number of | LFRCO. | # 9.6.5.2 LFRCO\_CTRL - Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-------------|---------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | | • | | | | | | | | • | | | | • | | | | • | • | | • | • | • | • | | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z. | RW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DISONDEMAND | FORCEEN | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | DISONDEMAND | 0x0 | RW | Disable On-Demand | | | Disable on demand func | tionality | | | | 0 | FORCEEN | 0x0 | RW | Force Enable | | | Force the LFRCO core of | n | | | # 9.6.5.3 LFRCO\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---|-----| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0X0 | | | | | | | | | | | | ' | | | 0x0 | | | | | | | | ' | | | | | • | | ' | 0x0 | | Access | 2 | | | | | | | | | | | | | | | ~ | | | | | | | | | | | | | | | | 2 | | Name | LOCK | | | | | | | | | | | | | | | ENS | | | | | | | | | | | | | | | | RDY | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|--------------------|------------------------------------------------------------------------| | 31 | LOCK | 0x0 | R | Lock Status | | | This bit is set when LF | RCO is locked | | | | | Value | Mode | | Description | | | 0 | UNLOCKE | :D | Access to configuration registers not locked | | | 1 | LOCKED | | Access to configuration registers locked | | 30:17 | Reserved | To ensure ventions | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 16 | ENS | 0x0 | R | Enabled Status | | | This bit is set when LF | RCO is enablir | ng the analog co | re. | | 15:1 | Reserved | To ensure ventions | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | RDY | 0x0 | R | Ready Status | | | This bit is set when qua | alification is do | one and LFRCO i | s ready. | # 9.6.5.4 LFRCO\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-------|----------|------|----|----|----|---|------------|---------|--------|---|---|---|---|---|---------|---------|-----| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | 80 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | 0×0 | 0x0 | 000 | | | | | | 0×0 | 0×0 | 0×0 | | | | | | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | W. | W. | Z. | | | | | | Z. | ₩<br>M | RW | | | | | | W. | ₩<br>M | W. | | Name | | | | | | | | | | | | | | CALOOR | TCOOR | SCHEDERR | | | | | | TEMPCHANGE | CALDONE | TCDONE | | | | | | NEGEDGE | POSEDGE | RDY | | Bit | Name | Reset | Access | Description | |-------|-----------------------------------------|-----------------|--------------------|----------------------------------------------------------------------| | 31:19 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 18 | CALOOR | 0x0 | RW | Calibration Out Of Range Flag | | | Triggers if Calibration me | easure is out o | of range | | | 17 | TCOOR | 0x0 | RW | Temperature Check Out Of Range Flag | | | Triggers if Temperature | Check measu | re is out of range | 9 | | 16 | SCHEDERR | 0x0 | RW | Scheduling Error Flag | | | Triggers if a scheduled I not complete. | Temperature C | Check can not be | handeled because prior Termperature Check or Calibration did | | 15:11 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 10 | TEMPCHANGE | 0x0 | RW | Temperature Change Flag | | | Triggers when Temperat | ture Check de | tects a change i | n temperature | | 9 | CALDONE | 0x0 | RW | Calibration Done Flag | | | Triggers on completion of | of Calibration | | | | 8 | TCDONE | 0x0 | RW | Temperature Check Done Flag | | | Triggers on completion of | of Temperature | e Check | | | 7:3 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 2 | NEGEDGE | 0x0 | RW | Falling Edge Flag | | | Triggers on every negati | ve edge of the | e LFRCO clock. | F will only be set when corresponding IEN is set. | | 1 | POSEDGE | 0x0 | RW | Rising Edge Flag | | | Triggers on every positive | e edge of the | LFRCO clock. If | will only be set when corresponding IEN is set. | | 0 | RDY | 0x0 | RW | Ready Flag | | | Triggers when the oscilla | ator becomes | ready | | # 9.6.5.5 LFRCO\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-------|----------|------|----|----|----|---|------------|---------|--------|---|---|---|---|---|---------|---------|-----| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | 80 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | 0X0 | 0x0 | 000 | | | | | | 000 | 0X0 | 0×0 | | | | | | 0X0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | W. | W. | Z. | | | | | | W. | ₩<br>M | RW | | | | | | RW | ₩<br>M | W. | | Name | | | | | | | | | | | | | | CALOOR | TCOOR | SCHEDERR | | | | | | TEMPCHANGE | CALDONE | TCDONE | | | | | | NEGEDGE | POSEDGE | RDY | | Bit | Name | Reset | Access | Description | |-------|---------------------------|----------------|--------------------|----------------------------------------------------------------------| | 31:19 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 18 | CALOOR | 0x0 | RW | Calibration Out Of Range Enable | | | Enables the Calibration | Out Of Range | interrupt | | | 17 | TCOOR | 0x0 | RW | Temperature Check Out Of Range Enable | | | Enables the Temperatur | e Check Out | Of Range interru | pt | | 16 | SCHEDERR | 0x0 | RW | Scheduling Error Enable | | | Enables the Scheduling | Error interrup | t | | | 15:11 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 10 | TEMPCHANGE | 0x0 | RW | Temperature Change Enable | | | Enables the Temperatur | e Change inte | errupt | | | 9 | CALDONE | 0x0 | RW | Calibration Done Enable | | | Enables the Calibration | Done interrup | t | | | 8 | TCDONE | 0x0 | RW | Temperature Check Done Enable | | | Enables the Temperatur | e Check Done | e interrupt | | | 7:3 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 2 | NEGEDGE | 0x0 | RW | Falling Edge Enable | | | Enables the negedge int | errupt and wil | I cause the oscil | lator to run | | 1 | POSEDGE | 0x0 | RW | Rising Edge Enable | | | Enables the posedge int | errupt and wil | I cause the oscill | lator to run | | 0 | RDY | 0x0 | RW | Ready Enable | | | Enables the ready interre | upt | | | | | | | | | ## 9.6.5.6 LFRCO\_LOCK - Configuration Lock Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|-----------|--------|---|---|---|---|---|---|---| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 41 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | • | | • | • | • | | • | | | | | • | | | | | | | | | | Š | )<br>X | | • | | | • | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | 7 1 2 2 2 | CANE | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | _ | | | | | | | | | | | Reset | Access | Description | | | | | | | |-----------------------------|---------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | LOCKKEY | 0x0 | W | Lock Key | | | | | | | | Writing the lock key will u | inlock the LFF | RCO configurati | on registers. Writing any other value will lock them. | | | | | | | | Value | Mode | | Description | | | | | | | | 0 | LOCK | OCK Lock Configuration Registers | | | | | | | | | 3987 | UNLOCK | | Unlock Configuration Registers | | | | | | | | | LOCKKEY Writing the lock key will u Value 0 | Ventions LOCKKEY 0x0 Writing the lock key will unlock the LFF Value Mode 0 LOCK | Ventions LOCKKEY 0x0 W Writing the lock key will unlock the LFRCO configuration Value Mode 0 LOCK | | | | | | | # 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 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | | | • | | | | | | | | | | | | | | | | | • | | | • | | | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | S. | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | HIGHPRECEN | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|------------------------------|------------------------------------------------------------------------------------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 0 | HIGHPRECEN | 0x0 | RW | High Precision Enable | | | | | | | | | | | LFRCO operates in High bled. | ligh Precision Mode when this bit is set. HIGHPRECEN should not be written while LFRCO is ena- | | | | | | | | | | | ## 9.6.5.8 LFRCO\_NOMCAL - Nominal Calibration Register | Offset | Bit Position | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x02C | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Reset | 0x5B8D8 | | Access | ≥ | | Name | NOMCALCNT | | Bit | Name | Reset | Access | Description | |-------|-----------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------| | 31:21 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 20:0 | NOMCALCNT | 0x5B8D8 | RW | Nominal Calibration Count | | | | | | ed on HFXO frequency; NOMCALCNT = 2 * f(HFXO) / (32.768 kHz / requency. NOMCALCNT should not be written while LFRCO is ena- | ## 9.6.5.9 LFRCO\_NOMCALINV - Nominal Calibration Inverted Register | Offset | Bit Position | |--------|-----------------------------------------| | 0x030 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | Reset | 0x597A | | Access | RW . | | Name | NOMCALCNTINV | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|--------------|--------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:17 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information ventions | | | | | | | | | | | 16:0 | NOMCALCNTINV | 0x597A | RW | Nominal Calibration Count Inverted | | | | | | | | | | | | | | NOMCALCNT value. Due to format of this register, integer value * (2**33). NOMCALCNTINV should not be written while LFRCO is en- | | | | | | | | | ### 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 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | | | | | | | | • | | | | | | | | • | | | • | | | | • | | | 000 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | REDUCETCINT | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------|-----------------------------------|--|--|--|--|--|--|--|--| | 31:1 | Reserved | To ensure o | To ensure compatibility with future devices, always write bits to 0. More ventions | | | | | | | | | | | 0 | REDUCETCINT | 0x0 | W | Reduce Temperature Check Interval | | | | | | | | | | | 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 | Туре | Description | |--------|---------------------|------|-------------| | 0x000 | FSRCO_IPVERSION | R | IP Version | | 0x1000 | FSRCO_IPVERSION_SET | R | IP Version | | 0x2000 | FSRCO_IPVERSION_CLR | R | IP Version | | 0x3000 | FSRCO_IPVERSION_TGL | R | IP Version | ### 9.7.5 FSRCO Register Description ### 9.7.5.1 FSRCO\_IPVERSION - IP Version | Offset | Bit Position | | | | | | | | | | | |--------|------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 0x000 | 33 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | | | | | | | | | | | | Reset | 0XO | | | | | | | | | | | | Access | α | | | | | | | | | | | | Name | IPVERSION | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--|--| | 31:0 | IPVERSION | 0x0 | R | IP Version | | | | | | | | | | 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 a ultra low power 1 kHz oscillator which is always on in all energy modes except EM4. 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. ### 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 will stop on EM4 entry and restart automatically on EM4 exit. ### 10. SMU - Security Management Unit #### **Quick Facts** #### What? The Security Management Unit (SMU) provides configuration and status reporting for ARM TrustZone on the EFR32xG22. #### Why? Enables a robust solution at the system level. #### How? 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 master privileged and secure attributes - · Separate interrupt flags for privileged, secure, or instruction access exceptions. - · Separate interrupt flag for secure master 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 Master Protect Unit (BMPU), and the Peripheral Protection Unit (PPU) as highlighted in Figure 10.1 Bus Level Security Implementation on page 227. 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 masters (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 masters. The Cortex-M33 has BMPU functionality built into the TrustZone implementation. The PPU is primarily responsible for blocking access to privileged peripherals from unprivileged masters. 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 masters 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 masters 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 228. 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 | Master 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 masters 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 228 Secure access is computed using the secure attribute of the master 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 | Master 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 in to 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 Masters The SMU provides the ability to configure the current secure and privileged attribute of all bus masters except for the CPU which is controlled as described in 10.3.4 ARM TrustZone. To configure the privileged attribute of a master set the appropriate bit in SMU\_BMPUPATDn. To configure the secure attribute of a master 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 an 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 (0x4000000) and one non-secure (0x5000000) region for peripherals and one secure (0xA000000) 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\_ESAURMBRxy registers as shown in Table 10.3 Memory Configuration Regions on page 230. Region sizes are adjusted in 4 kB increments with the lower 12 bits of SMU\_ESAURMBRxy 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_ESAURMBR01 | | 1 | FLASH | non-secure-callable | SMU_ESAURMBR01 | SMU_ESAURMBR12 | | 2 | FLASH | non-secure | SMU_ESAURMBR12 | 0x0FE00000 | | 3 | FLASH (info page) | secure or non-secure | 0x0FE00000 | 0x0FFFFFF | | 4 | RAM | secure | 0x20000000 | SMU_ESAURMBR45 | | 5 | RAM | non-secure-callable | SMU_ESAURMBR45 | SMU_ESAURMBR56 | | 6 | RAM | non-secure | SMU_ESAURMBR56 | 0x2FFFFFF | | 7 | Peripherals | secure | 0x40000000 | 0x4FFFFFF | | 8 | Peripherals | non-secure | 0x50000000 | 0x5FFFFFF | | 9 | SEQRAM/<br>FRCRAM | secure | 0xA0000000 | 0xAFFFFFF | | 10 | SEQRAM/<br>FRCRAM | non-secure | 0xB0000000 | 0xBFFFFFF | | 11 | EPPB | secure or non-secure | 0xE0044000 | 0xE00FDFFF | | 12 | Cortex-M33<br>Processor<br>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 masters. 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 masters outside the Cortex-M33, extreme care must be taken to ensure the SAU regions can not be trivially by bypassed through use of another master 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 master attempting to access a secure address, the BMPUSECIF in SMU\_IF is set and the ID of the Master 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, PPUSECIF in SMU\_IF is set and the ID of the peripheral being accessed is written to SMU\_PPUFS. If PPUSECIEN 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 master, 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 trigged 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\_ESAURMBR01 to a value larger than SMU\_ESAURMBR23. 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 | Туре | Description | |--------|-------------------|-------------|----------------------------------| | 0x000 | SMU_IPVERSION | R | IP Version | | 0x004 | SMU_STATUS | RH | Status | | 0x008 | SMU_LOCK | w | Lock | | 0x00C | SMU_IF | RWH INTFLAG | Interrupt Flag | | 0x010 | SMU_IEN | RW | Interrupt Enable | | 0x020 | SMU_M33CTRL | RW | M33 Control | | 0x040 | SMU_PPUPATD0 | RW | PPU PATD Register 0 | | 0x044 | SMU_PPUPATD1 | RW | PPU PATD Register 1 | | 0x060 | SMU_PPUSATD0 | RW | PPU SATD Register 0 | | 0x064 | SMU_PPUSATD1 | RW | PPU SATD Register 1 | | 0x140 | SMU_PPUFS | RH | PPU Fault Status | | 0x150 | SMU_BMPUPATD0 | RW | BMPU PATD Register 0 | | 0x170 | SMU_BMPUSATD0 | RW | BMPU SATD Register 0 | | 0x250 | SMU_BMPUFS | RH | BMPU Fault Status | | 0x254 | SMU_BMPUFSADDR | RH | BMPU Fault Status Address | | 0x260 | SMU_ESAURTYPES0 | RW | ESAU Region Types Register 0 | | 0x264 | SMU_ESAURTYPES1 | RW | ESAU Region Types Register 1 | | 0x270 | SMU_ESAUMRB01 | RW | ESAU Movable Region Boundary 0-1 | | 0x274 | SMU_ESAUMRB12 | RW | ESAU Movable Region Boundary 1-2 | | 0x280 | SMU_ESAUMRB45 | RW | ESAU Movable Region Boundary 4-5 | | 0x284 | SMU_ESAUMRB56 | RW | ESAU Movable Region Boundary 5-6 | | 0x1000 | SMU_IPVERSION_SET | R | IP Version | | 0x1004 | SMU_STATUS_SET | RH | Status | | 0x1008 | SMU_LOCK_SET | W | Lock | | 0x100C | SMU_IF_SET | RWH INTFLAG | Interrupt Flag | | 0x1010 | SMU_IEN_SET | RW | Interrupt Enable | | 0x1020 | SMU_M33CTRL_SET | RW | M33 Control | | 0x1040 | SMU_PPUPATD0_SET | RW | PPU PATD Register 0 | | 0x1044 | SMU_PPUPATD1_SET | RW | PPU PATD Register 1 | | 0x1060 | SMU_PPUSATD0_SET | RW | PPU SATD Register 0 | | 0x1064 | SMU_PPUSATD1_SET | RW | PPU SATD Register 1 | | 0x1140 | SMU_PPUFS_SET | RH | PPU Fault Status | | 0x1150 | SMU_BMPUPATD0_SET | RW | BMPU PATD Register 0 | | 0x1170 | SMU_BMPUSATD0_SET | RW | BMPU SATD Register 0 | | 0x1250 | SMU_BMPUFS_SET | RH | BMPU Fault Status | | Offset | Name | Туре | Description | |--------|---------------------|-------------|----------------------------------| | 0x1254 | SMU_BMPUFSADDR_SET | RH | BMPU Fault Status Address | | 0x1260 | SMU_ESAURTYPES0_SET | RW | ESAU Region Types Register 0 | | 0x1264 | SMU_ESAURTYPES1_SET | RW | ESAU Region Types Register 1 | | 0x1270 | SMU_ESAUMRB01_SET | RW | ESAU Movable Region Boundary 0-1 | | 0x1274 | SMU_ESAUMRB12_SET | RW | ESAU Movable Region Boundary 1-2 | | 0x1280 | SMU_ESAUMRB45_SET | RW | ESAU Movable Region Boundary 4-5 | | 0x1284 | SMU_ESAUMRB56_SET | RW | ESAU Movable Region Boundary 5-6 | | 0x2000 | SMU_IPVERSION_CLR | R | IP Version | | 0x2004 | SMU_STATUS_CLR | RH | Status | | 0x2008 | SMU_LOCK_CLR | W | Lock | | 0x200C | SMU_IF_CLR | RWH INTFLAG | Interrupt Flag | | 0x2010 | SMU_IEN_CLR | RW | Interrupt Enable | | 0x2020 | SMU_M33CTRL_CLR | RW | M33 Control | | 0x2040 | SMU_PPUPATD0_CLR | RW | PPU PATD Register 0 | | 0x2044 | SMU_PPUPATD1_CLR | RW | PPU PATD Register 1 | | 0x2060 | SMU_PPUSATD0_CLR | RW | PPU SATD Register 0 | | 0x2064 | SMU_PPUSATD1_CLR | RW | PPU SATD Register 1 | | 0x2140 | SMU_PPUFS_CLR | RH | PPU Fault Status | | 0x2150 | SMU_BMPUPATD0_CLR | RW | BMPU PATD Register 0 | | 0x2170 | SMU_BMPUSATD0_CLR | RW | BMPU SATD Register 0 | | 0x2250 | SMU_BMPUFS_CLR | RH | BMPU Fault Status | | 0x2254 | SMU_BMPUFSADDR_CLR | RH | BMPU Fault Status Address | | 0x2260 | SMU_ESAURTYPES0_CLR | RW | ESAU Region Types Register 0 | | 0x2264 | SMU_ESAURTYPES1_CLR | RW | ESAU Region Types Register 1 | | 0x2270 | SMU_ESAUMRB01_CLR | RW | ESAU Movable Region Boundary 0-1 | | 0x2274 | SMU_ESAUMRB12_CLR | RW | ESAU Movable Region Boundary 1-2 | | 0x2280 | SMU_ESAUMRB45_CLR | RW | ESAU Movable Region Boundary 4-5 | | 0x2284 | SMU_ESAUMRB56_CLR | RW | ESAU Movable Region Boundary 5-6 | | 0x3000 | SMU_IPVERSION_TGL | R | IP Version | | 0x3004 | SMU_STATUS_TGL | RH | Status | | 0x3008 | SMU_LOCK_TGL | w | Lock | | 0x300C | SMU_IF_TGL | RWH INTFLAG | Interrupt Flag | | 0x3010 | SMU_IEN_TGL | RW | Interrupt Enable | | 0x3020 | SMU_M33CTRL_TGL | RW | M33 Control | | 0x3040 | SMU_PPUPATD0_TGL | RW | PPU PATD Register 0 | | 0x3044 | SMU_PPUPATD1_TGL | RW | PPU PATD Register 1 | | 0x3060 | SMU_PPUSATD0_TGL | RW | PPU SATD Register 0 | | Offset | Name | Туре | Description | |--------|---------------------|------|----------------------------------| | 0x3064 | SMU_PPUSATD1_TGL | RW | PPU SATD Register 1 | | 0x3140 | SMU_PPUFS_TGL | RH | PPU Fault Status | | 0x3150 | SMU_BMPUPATD0_TGL | RW | BMPU PATD Register 0 | | 0x3170 | SMU_BMPUSATD0_TGL | RW | BMPU SATD Register 0 | | 0x3250 | SMU_BMPUFS_TGL | RH | BMPU Fault Status | | 0x3254 | SMU_BMPUFSADDR_TGL | RH | BMPU Fault Status Address | | 0x3260 | SMU_ESAURTYPES0_TGL | RW | ESAU Region Types Register 0 | | 0x3264 | SMU_ESAURTYPES1_TGL | RW | ESAU Region Types Register 1 | | 0x3270 | SMU_ESAUMRB01_TGL | RW | ESAU Movable Region Boundary 0-1 | | 0x3274 | SMU_ESAUMRB12_TGL | RW | ESAU Movable Region Boundary 1-2 | | 0x3280 | SMU_ESAUMRB45_TGL | RW | ESAU Movable Region Boundary 4-5 | | 0x3284 | SMU_ESAUMRB56_TGL | RW | ESAU Movable Region Boundary 5-6 | ## 10.5 SMU Register Description # 10.5.1 SMU\_IPVERSION - IP Version | Offset | | Bit Position | | | | | | | | | | | | |--------|----|------------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x000 | 31 | 33 30 30 30 30 30 30 30 30 30 30 30 30 3 | | | | | | | | | | | | | Reset | | 8 | | | | | | | | | | | | | Access | | <u>~</u> | | | | | | | | | | | | | Name | | IPVERSION R | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | |------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--| | 31:0 | IPVERSION | 0x1 | R | IP Version | | | | | | | | | The read only IPVERSION field gives the version for this module. There may be minor software changes req modules with different values of IPVERSION. | | | | | | | | | | ## 10.5.2 SMU\_STATUS - Status | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|---|----|----|----|---|----|----|---|----|---|---|---|---|---|---|---|---|-----------|---------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | ' | | 1 | | | | | | • | • | • | • | 1 | | • | | | | | • | | • | • | ' | • | • | ' | | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ~ | ~ | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | SMUPRGERR | SMULOCK | | Bit | Name | Reset | Access | Description | | | | | | |------|---------------------|--------------------|-------------------|---------------------------------------------------------------------------|--|--|--|--|--| | 31:2 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 1 | SMUPRGERR | 0x0 | R | SMU Programming Error | | | | | | | | Indicates if SMU Re | gisters were pro | grammed incor | rectly. | | | | | | | 0 | SMULOCK | 0x0 | R | SMU Lock | | | | | | | | Indicates if SMU Re | gisters are locke | ed. | | | | | | | | | Value | Mode | | Description | | | | | | | | 0 | UNLOCK | ED | SMULOCK is Unlocked | | | | | | | | 1 | LOCKED | | SMULOCK is Locked | | | | | | | | | | | | | | | | | ## 10.5.3 SMU\_LOCK - Lock | Offset | Bit Position | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x008 | 33 34 35 36 37 38 38 39 30 30 30 31 32 33 34 45 46 47 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×0 | | Access | * | | Name | SMULOCKKEY | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:24 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 23:0 | SMULOCKKEY | 0x0 | W | SMU Lock/Key | | | Write anything but UN | NLOCK to lock I | egisters. | | | | Value | Mode | | Description | | | 11325013 | UNLOCK | | Unlocks Registers | ## 10.5.4 SMU\_IF - Interrupt Flag | Offset | Bit Position | | | | | | | | | |--------|--------------|--------------------|--|--|--|--|--|--|--| | 0x00C | 33 | 0 7 0 | | | | | | | | | Reset | 000 | 000 | | | | | | | | | Access | WA WA | W W | | | | | | | | | Name | BMPUSEC | PPUINST<br>PPUPRIV | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |-------|----------------------------------------------------------------------------|-----------------|------------------------------------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:18 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 17 | BMPUSEC | 0x0 | RW | BMPU Security Interrupt Flag | | | | | | | | | | | | Triggered when a securi | ty fault occurs | ault occurs in the Bus Master Protection Unit. | | | | | | | | | | | | 16 | PPUSEC | 0x0 | RW | PPU Security Interrupt Flag | | | | | | | | | | | | Triggered when a security fault occurs in the Peripheral Protection Unit. | | | | | | | | | | | | | | 15:3 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 2 | PPUINST | 0x0 | RW | PPU Instruction Interrupt Flag | | | | | | | | | | | | Triggered when a instruc | ction fault occ | urs in the Periph | neral Protection Unit. | | | | | | | | | | | 1 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 0 | PPUPRIV | 0x0 | RW | PPU Privilege Interrupt Flag | | | | | | | | | | | | Triggered when a privilege fault occurs in the Peripheral Protection Unit. | | | | | | | | | | | | | ## 10.5.5 SMU\_IEN - Interrupt Enable | Offset | Bit Position | | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--|--|--|--| | 0x010 | 33 34 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 5 6 6 6 7 7 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 9 9 | t 0 | | | | | | | Reset | 000000000000000000000000000000000000000 | 0x0 | | | | | | | Access | R RW | RW | | | | | | | Name | BMPUSEC PPUSEC | PPUPRIV | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:18 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 17 | BMPUSEC | 0x0 | RW | BMPU Security Interrupt Enable | | | Set to enable the BMPU | SECIF Interru | ıpt | | | 16 | PPUSEC | 0x0 | RW | PPU Security Interrupt Enable | | | Set to enable the PPUS | ECIF Interrup | t. | | | 15:3 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 2 | PPUINST | 0x0 | RW | PPU Instruction Interrupt Enable | | | Set to enable the PPUIN | ISTIF Interrup | t. | | | 1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | PPUPRIV | 0x0 | RW | PPU Privilege Interrupt Enable | | | Set to enable the PPUP | RIVIF Interrup | ot. | | ## 10.5.6 SMU\_M33CTRL - M33 Control | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|---|---|---|---|---|---|---------|-----------|----------|------------|--------------| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | | • | | | | | | | • | | • | | • | | | | • | • | • | | | • | 0×0 | 000 | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | W. | W. | Z. | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | LOCKSAU | LOCKNSMPU | LOCKSMPU | LOCKNSVTOR | LOCKSVTAIRCR | | Bit | Name | Reset | Access | Description | |------|----------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 4 | LOCKSAU | 0x0 | RW | LOCKSAU control of M33 CPU | | | Set to 1 lock security att | ribution unit. | | | | 3 | LOCKNSMPU | 0x0 | RW | LOCKNSMPU control of M33 CPU | | | Set to 1 lock non-secure | MPU configu | ration. | | | 2 | LOCKSMPU | 0x0 | RW | LOCKSMPU control of M33 CPU | | | Set to 1 lock secure MP | U configuratio | n. | | | 1 | LOCKNSVTOR | 0x0 | RW | LOCKNSVTOR control of M33 CPU | | | Set to 1 lock non-secure | VTOR. | | | | 0 | LOCKSVTAIRCR | 0x0 | RW | LOCKSVTAIRCR control of M33 CPU | | | Set to 1 lock secure VT/ | AIRCR. | | | ## 10.5.7 SMU\_PPUPATD0 - PPU PATD Register 0 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|-----|-------|------------|-------|--------|-------------|--------------|------|-------|--------|--------|--------|---------|--------|--------|----------|----------|------|------|-----|---------|-----|--------|-------|------|-------|-------|---------|-------|-----|-----|---| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | X | X | 0X | 0X1 | % | 0x1 | 0X | 0X | 0X | 0x1 | 0X | 0×1 | 0X | 0X | 0X | <u>X</u> | 0X | 0X | 0X1 | 0×1 | 0X1 | 0X | 0X | 0X | 0×1 | 0X | 0X | 0X | 0×1 | 0X1 | 0X | | | Access | RW | W. | ₩<br>M | W. | ₩<br>M | RW | ₩<br>W | ₩. | S. | RW | ₩. | W. | RW<br>W | W. | ₩<br>N | ₩<br>M | ₩<br>N | W. | RW | Z. | RW | W. | ₩. | W. | W. | RW | S. | RW<br>W | Z. | ₩. | W. | | | Name | DCI | GPCRC | IFADCDEBUG | BURAM | SYSCFG | SYSCFGCFGNS | CHIPTESTCTRL | I2C1 | BURTC | USART1 | USART0 | TIMER4 | TIMER3 | TIMER2 | TIMER1 | TIMERO | LDMAXBAR | LDMA | GPIO | PRS | ICACHE0 | MSC | ULFRCO | LFRCO | LFXO | DPLL0 | FSRCO | HFRC00 | HFXO0 | СМU | ЕМО | | | Bit | Name | Reset | Access | Description | |-----|------------------------|------------|--------|--------------------------------| | 31 | DCI | 0x1 | RW | DCI Privileged Access | | | DCI Privileged Access | | | | | 30 | GPCRC | 0x1 | RW | GPCRC Privileged Access | | | GPCRC Privileged Acce | ess | | | | 29 | IFADCDEBUG | 0x1 | RW | IFADCDEBUG Privileged Access | | | IFADCDEBUG Privilege | d Access | | | | 28 | BURAM | 0x1 | RW | BURAM Privileged Access | | | BURAM Privileged Acce | ess | | | | 27 | SYSCFG | 0x1 | RW | SYSCFG Privileged Access | | | SYSCFG Privileged Acc | ess | | | | 26 | SYSCFGCFGNS | 0x1 | RW | SYSCFGCFGNS Privileged Access | | | SYSCFGCFGNS Privile | ged Access | | | | 25 | CHIPTESTCTRL | 0x1 | RW | CHIPTESTCTRL Privileged Access | | | CHIPTESTCTRL Privile | ged Access | | | | 24 | I2C1 | 0x1 | RW | I2C1 Privileged Access | | | I2C1 Privileged Access | | | | | 23 | BURTC | 0x1 | RW | BURTC Privileged Access | | | BURTC Privileged Acces | ss | | | | 22 | USART1 | 0x1 | RW | USART1 Privileged Access | | | USART1 Privileged Acco | ess | | | | 21 | USART0 | 0x1 | RW | USART0 Privileged Access | | | USART0 Privileged Acco | ess | | | | 20 | TIMER4 | 0x1 | RW | TIMER4 Privileged Access | | | TIMER4 Privileged Acce | ess | | | | 19 | TIMER3 | 0x1 | RW | TIMER3 Privileged Access | | | TIMER3 Privileged Acce | ess | | | | 18 | TIMER2 | 0x1 | RW | TIMER2 Privileged Access | | Bit | Name | Reset | Access | Description | |-----|------------------------|--------------------|-------------------|------------------------------------------------------------------------| | | TIMER2 Privileged Acce | ess | | | | 17 | TIMER1 | 0x1 | RW | TIMER1 Privileged Access | | | TIMER1 Privileged Acce | ess | | | | 16 | TIMER0 | 0x1 | RW | TIMER0 Privileged Access | | | TIMER0 Privileged Acce | ess | | | | 15 | LDMAXBAR | 0x1 | RW | LDMAXBAR Privileged Access | | | LDMAXBAR Privileged A | Access | | | | 14 | LDMA | 0x1 | RW | LDMA Privileged Access | | | LDMA Privileged Access | 3 | | | | 13 | GPIO | 0x1 | RW | GPIO Privileged Access | | | GPIO Privileged Access | | | | | 12 | PRS | 0x1 | RW | PRS Privileged Access | | | PRS0 Privileged Access | ; | | | | 11 | ICACHE0 | 0x1 | RW | ICACHE0 Privileged Access | | | ICACHE0 Privileged Acc | cess | | | | 10 | MSC | 0x1 | RW | MSC Privileged Access | | | IMEM Privileged Access | ; | | | | 9 | ULFRCO | 0x1 | RW | ULFRCO Privileged Access | | | ULFRCO Privileged Acc | ess | | | | 8 | LFRCO | 0x1 | RW | LFRCO Privileged Access | | | LFRCO Privileged Acces | ss | | | | 7 | LFXO | 0x1 | RW | LFXO Privileged Access | | | LFXO Privileged Access | i | | | | 6 | DPLL0 | 0x1 | RW | DPLL0 Privileged Access | | | DPLL0 Privileged Acces | S | | | | 5 | FSRCO | 0x1 | RW | FSRCO Privileged Access | | | FSRCO Privileged Acce | ss | | | | 4 | HFRCO0 | 0x1 | RW | HFRCO0 Privileged Access | | | HFRCO0 Privileged Acc | ess | | | | 3 | HFXO0 | 0x1 | RW | HFXO0 Privileged Access | | | SYXO0 Privileged Acces | ss | | | | 2 | CMU | 0x1 | RW | CMU Privileged Access | | | CMU Privileged Access | | | | | 1 | EMU | 0x1 | RW | EMU Privileged Access | | | EMU Privileged Access | | | | | 0 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | ## 10.5.8 SMU\_PPUPATD1 - PPU PATD Register 1 | Offset | Bit Position | | | | | | | | |--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--| | 0x044 | 1 | 2 4 5 7 1 1 0 6 8 7 9 9 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | - 0 | | | | | | | Reset | | | Š | | | | | | | Access | | M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M | À. | | | | | | | Name | | AHBRADIO CRYPTOACC EUARTO AMUXCPO WDOGO IZCO IADCO LETIMERO RTCC SMU RADIOAES SMU RABIOAES PDM | 3 | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|---------------------|-------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | e compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 15 | AHBRADIO | 0x1 | RW | AHBRADIO Privileged Access | | | AHBRADIO Privileged | Access | | | | 14 | CRYPTOACC | 0x1 | RW | CRYPTOACC Privileged Access | | | CRYPTOACC Privileg | ed Access | | | | 13 | EUART0 | 0x1 | RW | EUART0 Privileged Access | | | EUART0 Privileged Ac | cess | | | | 12 | AMUXCP0 | 0x1 | RW | AMUXCP0 Privileged Access | | | AMUXCP0 Privileged | Access | | | | 11 | WDOG0 | 0x1 | RW | WDOG0 Privileged Access | | | WDOG0 Privileged Ac | cess | | | | 10 | I2C0 | 0x1 | RW | I2C0 Privileged Access | | | I2C0 Privileged Access | 5 | | | | 9 | IADC0 | 0x1 | RW | IADC0 Privileged Access | | | IADC0 Privileged Acce | ess | | | | 8 | LETIMER0 | 0x1 | RW | LETIMER0 Privileged Access | | | LETIMER0 Privileged | Access | | | | 7 | RTCC | 0x1 | RW | RTCC Privileged Access | | | RTCC Privileged Acce | SS | | | | 6 | SMUCFGNS | 0x1 | RW | SMUCFGNS Privileged Access | | | SMUCFGNS Privilege | d Access | | | | 5 | SMU | 0x1 | RW | SMU Privileged Access | | | SMU Privileged Acces | S | | | | 4 | RADIOAES | 0x1 | RW | RADIOAES Privileged Access | | | RADIOAES Privileged | Access | | | | 3 | RFSENSE | 0x1 | RW | RFSENSE Privileged Access | | | RFSENSE Privileged A | Access | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | |-----|-----------------------|--------------------|----------------------------------------------------------------------------------------------------------|------------------------|--|--|--|--|--| | 2 | PDM | 0x1 | RW | PDM Privileged Access | | | | | | | | PDM Privileged Access | | | | | | | | | | 1 | DCDC | 0x1 | RW | DCDC Privileged Access | | | | | | | | DCDC Privileged Acces | S | | | | | | | | | 0 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Conventions | | | | | | | # 10.5.9 SMU\_PPUSATD0 - PPU SATD Register 0 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|-----|-------|------------|-------|--------|-------------|--------------|------|-------|--------|--------|--------|--------|--------|--------|----------|----------|------|------|-----|---------|-----|--------|-------|------|----------|-------|----------------|---------|-----|---------|---| | 0x060 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x1 | 0X | 0X | 0X1 | 0X | 0×1 | 0X | 0X | 0X | 0x1 | 0X | 0X | 0X | 0X | 0X | <u>X</u> | 0X % | 0×1 | <u>×</u> | 0×1 | <u>X</u> | 0X1 | 0x1 | 0X | | | Access | RW | Z. | ₩<br>M | W. | W. | RW | ₩<br>M | RW | W. | RW | W. | RW | W. | W. | W. | ₩<br>M | W. | W. | RW | W. | RW | W. | RW | W. | W. | W. | W. | R <sub>W</sub> | ZW<br>W | RW | ZW<br>W | | | Name | DCI | GPCRC | IFADCDEBUG | BURAM | SYSCFG | SYSCFGCFGNS | CHIPTESTCTRL | I2C1 | BURTC | USART1 | USART0 | TIMER4 | TIMER3 | TIMER2 | TIMER1 | TIMERO | LDMAXBAR | LDMA | GPIO | PRS | ICACHE0 | MSC | ULFRCO | LFRCO | LFXO | DPLL0 | FSRCO | HFRC00 | HFX00 | СМО | ЕМО | | | Bit | Name | Reset | Access | Description | |-----|----------------------|----------|--------|----------------------------| | 31 | DCI | 0x1 | RW | DCI Secure Access | | | DCI Secure Access | | | | | 30 | GPCRC | 0x1 | RW | GPCRC Secure Access | | | GPCRC Secure Access | | | | | 29 | IFADCDEBUG | 0x1 | RW | IFADCDEBUG Secure Access | | | IFADCDEBUG Secure A | ccess | | | | 28 | BURAM | 0x1 | RW | BURAM Secure Access | | | BURAM Secure Access | | | | | 27 | SYSCFG | 0x1 | RW | SYSCFG Secure Access | | | SYSCFG Secure Access | 5 | | | | 26 | SYSCFGCFGNS | 0x1 | RW | SYSCFGCFGNS Secure Access | | | SYSCFGCFGNS Secure | e Access | | | | 25 | CHIPTESTCTRL | 0x1 | RW | CHIPTESTCTRL Secure Access | | | CHIPTESTCTRL Secure | Access | | | | 24 | I2C1 | 0x1 | RW | I2C1 Secure Access | | | I2C1 Secure Access | | | | | 23 | BURTC | 0x1 | RW | BURTC Secure Access | | | BURTC Secure Access | | | | | 22 | USART1 | 0x1 | RW | USART1 Secure Access | | | USART1 Secure Access | i | | | | 21 | USART0 | 0x1 | RW | USART0 Secure Access | | | USART0 Secure Access | i | | | | 20 | TIMER4 | 0x1 | RW | TIMER4 Secure Access | | | TIMER4 Secure Access | | | | | 19 | TIMER3 | 0x1 | RW | TIMER3 Secure Access | | | TIMER3 Secure Access | | | | | 18 | TIMER2 | 0x1 | RW | TIMER2 Secure Access | | Bit | Name | Reset | Access | Description | |-----|-----------------------|-------------|--------------------|------------------------------------------------------------------------| | | TIMER2 Secure Access | | | | | 17 | TIMER1 | 0x1 | RW | TIMER1 Secure Access | | | TIMER1 Secure Access | | | | | 16 | TIMER0 | 0x1 | RW | TIMER0 Secure Access | | | TIMER0 Secure Access | | | | | 15 | LDMAXBAR | 0x1 | RW | LDMAXBAR Secure Access | | | LDMAXBAR Secure Acc | ess | | | | 14 | LDMA | 0x1 | RW | LDMA Secure Access | | | LDMA Secure Access | | | | | 13 | GPIO | 0x1 | RW | GPIO Secure Access | | | GPIO Secure Access | | | | | 12 | PRS | 0x1 | RW | PRS Secure Access | | | PRS Secure Access | | | | | 11 | ICACHE0 | 0x1 | RW | ICACHE0 Secure Access | | | ICACHE0 Secure Access | 3 | | | | 10 | MSC | 0x1 | RW | MSC Secure Access | | | MSC Secure Access | | | | | 9 | ULFRCO | 0x1 | RW | ULFRCO Secure Access | | | ULFRCO Secure Access | i | | | | 8 | LFRCO | 0x1 | RW | LFRCO Secure Access | | | LFRCO Secure Access | | | | | 7 | LFXO | 0x1 | RW | LFXO Secure Access | | | LFXO Secure Access | | | | | 6 | DPLL0 | 0x1 | RW | DPLL0 Secure Access | | | DPLL0 Secure Access | | | | | 5 | FSRCO | 0x1 | RW | FSRCO Secure Access | | | FSRCO Secure Access | | | | | 4 | HFRCO0 | 0x1 | RW | HFRCO0 Secure Access | | | HFRCO0 Secure Access | i | | | | 3 | HFXO0 | 0x1 | RW | HFXO0 Secure Access | | | HFXO0 Secure Access | | | | | 2 | CMU | 0x1 | RW | CMU Secure Access | | | CMU Secure Access | | | | | 1 | EMU | 0x1 | RW | EMU Secure Access | | | EMU Secure Access | | | | | 0 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | ## 10.5.10 SMU\_PPUSATD1 - PPU SATD Register 1 | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----------|-----------|---------|---------|--------|------|--------|-------------|--------|-------------|-----|----------|---------|--------|--------|---| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | 0X1 | 0X | )X | 0X1 | 0x1 | 0X1 | 0x1 | 0X | 0X | 0X | 0X1 | 0X1 | )X | X | )X | | | Access | | | | | | | | | | | | | | | | | ₩<br>N | Z. | RW<br>W | R<br>≷ | R<br>N | S. | R<br>N | R<br>N<br>N | R<br>W | R<br>M<br>M | S. | ₩<br>N | §<br>N | ¥<br>M | ¥<br>M | | | Name | | | | | | | | | | | | | | | | | AHBRADIO | CRYPTOACC | EUART0 | AMUXCP0 | WDOG0 | I2C0 | IADC0 | LETIMERO | RTCC | SMUCFGNS | SMU | RADIOAES | RFSENSE | PDM | DCDC | | | Bit | Name | Reset | Access | Description | |-------|--------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 15 | AHBRADIO | 0x1 | RW | AHBRADIO Secure Access | | | AHBRADIO Secure A | Access | | | | 14 | CRYPTOACC | 0x1 | RW | CRYPTOACC Secure Access | | | CRYPTOACC Secure | e Access | | | | 13 | EUART0 | 0x1 | RW | EUART0 Secure Access | | | EUART0 Secure Acc | ess | | | | 12 | AMUXCP0 | 0x1 | RW | AMUXCP0 Secure Access | | | AMUXCP0 Secure Ad | ccess | | | | 11 | WDOG0 | 0x1 | RW | WDOG0 Secure Access | | | WDOG0 Secure Acce | ess | | | | 10 | I2C0 | 0x1 | RW | I2C0 Secure Access | | | I2C0 Secure Access | | | | | 9 | IADC0 | 0x1 | RW | IADC0 Secure Access | | | IADC0 Secure Acces | s | | | | 8 | LETIMER0 | 0x1 | RW | LETIMER0 Secure Access | | | LETIMER0 Secure A | ccess | | | | 7 | RTCC | 0x1 | RW | RTCC Secure Access | | | RTCC Secure Access | S | | | | 6 | SMUCFGNS | 0x1 | RW | SMUCFGNS Secure Access | | | SMUCFGNS Secure | Access | | | | 5 | SMU | 0x1 | RW | SMU Secure Access | | | SMU Secure Access | | | | | 4 | RADIOAES | 0x1 | RW | RADIOAES Secure Access | | | RADIOAES Secure A | ccess | | | | 3 | RFSENSE | 0x1 | RW | RFSENSE Secure Access | | | RFSENSE Secure Ac | ccess | | | | Bit | Name | Reset | Access | Description | |-----|--------------------|-------------|-------------------|------------------------------------------------------------------------| | 2 | PDM | 0x1 | RW | PDM Secure Access | | | PDM Secure Access | | | | | 1 | DCDC | 0x1 | RW | DCDC Secure Access | | | DCDC Secure Access | | | | | 0 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | # 10.5.11 SMU\_PPUFS - PPU Fault Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|----------|---|---|---|---------------|---|---|-----| | 0x140 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <b>ω</b> | 7 | 9 | 2 | 4 | က | 2 | ~ c | | Reset | | | • | | • | | • | • | | | | | | | | • | | | | | | • | | | | | | 000 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ď | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | IPHID | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | PPUFSPERIPHID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ЬР | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|---------------|-------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | PPUFSPERIPHID | 0x0 | R | Peripheral ID | | | ID of the peripheral that | caused the fa | ult. | | ## 10.5.12 SMU\_BMPUPATD0 - BMPU PATD Register 0 | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|----------|----|---|---|---|---|---|--------|-----------------|----------------|-----------|----------| | 0x150 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | | | • | | ' | | ' | | | | ' | • | ' | <u>'</u> | | ' | | • | <u>'</u> | | • | • | | | ' | 0X1 | <u>×</u> | 0×1 | 0X | 0×1 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | ₩<br>M | Z. | Z. | RW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | LDMA | RADIOIFADCDEBUG | RADIOSUBSYSTEM | CRYPTOACC | RADIOAES | | Bit | Name | Reset | Access | Description | |------|-----------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 4 | LDMA | 0x1 | RW | MCU LDMA privileged mode | | | MCU LDMA privileged m | node | | | | 3 | RADIOIFADCDEBUG | 0x1 | RW | RADIO IFADC debug privileged mode | | | RADIO IFADC debug wr | ite privileged | mode | | | 2 | RADIOSUBSYSTEM | 0x1 | RW | RADIO subsystem masters privileged mode | | | RADIO subsystem maste | ers (FRC and | SEQ) privileged | d mode | | 1 | CRYPTOACC | 0x1 | RW | CRYPTOACC DMA privileged mode | | | CRYPTOACC DMA privi | ileged mode | | | | 0 | RADIOAES | 0x1 | RW | RADIO AES DMA privileged mode | | | RADIOAES DMA privile | ged mode | | | ## 10.5.13 SMU\_BMPUSATD0 - BMPU SATD Register 0 | Offset | | | | | | | | | | | | | | | В | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|------|-----------------|----------------|--------------|----------| | 0x170 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | | • | • | | | | | • | | • | • | | | | | | | • | | • | • | • | 0X1 | <u>×</u> | 0X1 | 0 <u>X</u> 1 | 0×1 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | ₩<br>M | RW | W. | RW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | LDMA | RADIOIFADCDEBUG | RADIOSUBSYSTEM | CRYPTOACC | RADIOAES | | Bit | Name | Reset | Access | Description | |------|-----------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 4 | LDMA | 0x1 | RW | MCU LDMA secure mode | | | MCU LDMA secure mod | е | | | | 3 | RADIOIFADCDEBUG | 0x1 | RW | RADIO IFADC debug secure mode | | | RADIO IADC debug writ | e secure mod | е | | | 2 | RADIOSUBSYSTEM | 0x1 | RW | RADIO subsystem masters secure mode | | | RADIO subsystem mast | ers (FRC and | SEQ) secure m | ode | | 1 | CRYPTOACC | 0x1 | RW | CRYPTOACC DMA secure mode | | | CRYPTOACC DMA sec | ure mode | | | | 0 | RADIOAES | 0x1 | RW | RADIOAES DMA secure mode | | | RADIOAES DMA secure | mode | | | ## 10.5.14 SMU\_BMPUFS - BMPU Fault Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|----------------|---|---|---| | 0x250 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 9 | ဝ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | ( | 0<br>0<br>0 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ı | Y | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | BMPUFSMASTERID | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | BMPUFSMASTERID | 0x0 | R | Master ID | | | ID of master that triggere | ed fault. | | | # 10.5.15 SMU\_BMPUFSADDR - BMPU Fault Status Address | Offset | Bit Position | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---| | 0x254 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>0</th> | 0 | | Reset | 000 | | | Access | β C | | | Name | BMPUFSADDR | | | Bit | Name | Reset | Access | Description | |------|---------------------------|--------------|--------|---------------| | 31:0 | BMPUFSADDR | 0x0 | R | Fault Address | | | Access address that trigg | gered fault. | | | # 10.5.16 SMU\_ESAURTYPES0 - ESAU Region Types Register 0 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----------|---|----|---|---|---|---|---|---|---|---|---|---| | 0x260 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | | | | | | | | • | | | • | • | | • | | 0X0 | | | | • | • | • | • | | • | | | | | Access | | | | | | | | | | | | | | | | | | | | ₹<br>N | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | ESAUR3NS | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:13 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 12 | ESAUR3NS | 0x0 | RW | Region 3 Non-Secure Type | | | Set to 1 to configure Reg | ion 3 as Non | -secure. | | | 11:0 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | ## 10.5.17 SMU\_ESAURTYPES1 - ESAU Region Types Register 1 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|-----------|---|----|---|---|---|---|---|---|---|---|---|---| | 0x264 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | • | | • | | • | | • | • | • | • | • | • | | • | 0×0 | | | | • | • | | • | | • | • | | | | Access | | | | | | | | | | | | | | | | | | | | ₹<br>Š | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | ESAUR11NS | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|---------------|-------------------|------------------------------------------------------------------------| | 31:13 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 12 | ESAUR11NS | 0x0 | RW | Region 11 Non-Secure Type | | | Set to 1 to configure Reg | gion 11 as No | n-secure. | | | 11:0 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | ## 10.5.18 SMU\_ESAUMRB01 - ESAU Movable Region Boundary 0-1 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|------------|----|----|------|------|----|----|----|---|----|---|----|---|---|---|---|---|---|---|---| | 0x270 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | 00000000000000000000000000000000000000 | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | 2 | ≩<br>Ƴ | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | ESAUMIKBUT | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:28 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 27:12 | ESAUMRB01 | 0x2000 | RW | Moveable Region Boundary 0-1 | | | Moveable Region Bound | ary between l | Region 0 and R | egion 1. Address Represents the start of Region 1 at a 4kB offset. | | 11:0 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | ## 10.5.19 SMU\_ESAUMRB12 - ESAU Movable Region Boundary 1-2 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----------|----|----|----|----|------------|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|--------| | 0x274 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | 3 | 2 | _ | _<br>o | | Reset | | | | | | | V 0×4000 | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | Š | 2 | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | ESALIMBB12 | Ī | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:28 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 27:12 | ESAUMRB12 | 0x4000 | RW | Moveable Region Boundary 1-2 | | | Moveable Region Bour | ndary between | Region 1 and F | Region 2. Address Represents the start of Region 2 at a 4kB offset. | | 11:0 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | ## 10.5.20 SMU\_ESAUMRB45 - ESAU Movable Region Boundary 4-5 | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------|--|--|--|--|--|--|--|--|--|---|----|---|---|---|---|---|---|---|---|---|---|--| | 0x280 | 31 | 30 | 30<br>22<br>30<br>30<br>30<br>30<br>30<br>4<br>4<br>5<br>5<br>5<br>5<br>7<br>7<br>7<br>8<br>7<br>8<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | | | | | | | | | | | | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | | Reset | | | | 000000 | | | | | | | | | | | | | ' | ' | ' | • | | | • | | | | | | Access | | | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | | | | | | | | | | | | | | | | | | | | | | | Name | | ESAUMRB45 F | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |-------|-----------------------|---------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:28 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 27:12 | ESAUMRB45 | 0x2000 | RW | Moveable Region Boundary 4-5 | | | | | | | | | | Moveable Region Bound | ary between | Regions 4 and 5 | 5. This represents the starting address of Region 5. | | | | | | | | | 11:0 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Coventions | | | | | | | | | | # 10.5.21 SMU\_ESAUMRB56 - ESAU Movable Region Boundary 5-6 | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|-----|----------------------------------------------|--|--|--|--|--|--|--|--|--|--|---|----|---|----|---|---|---|---|---|---|-----| | 0x284 | 31 | 30 | 29 | 28 | 27 27 57 57 57 57 57 57 57 57 57 57 57 57 57 | | | | | | | | | | | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | | | 0x4000 | | | | | | | | | | | | | | | | | | | | | | | Access | | | | Z X | | | | | | | | | | | | | | | | | | | | | | | | Name | | ESAUMRB56 | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | |-------|------------------------------------------------------------------------------------------------------------------|--------------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--| | 31:28 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 27:12 | ESAUMRB56 | 0x4000 | RW | Moveable Region Boundary 5-6 | | | | | | | | Moveable Region Boun | dary between | Regions 5 and | 6. This represents the starting address of Region 6. | | | | | | | 11:0 | Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Coventions | | | | | | | | | #### 11. CRYPTOACC - Cryptographic Accelerator #### **Quick Facts** #### What? The Cryptographic Accelerator provides fast, energy-efficient hardware for symmetric-key cryptographic operations, a Public Key Engine (PKE) for asymmetric key operations, and non-deterministic random number generation (RNG). #### Why? Efficient hardware-based cryptography helps to meet the speed and energy demands of secure applications while providing additional protection against common attacks. #### How? Dedicated hardware allows fast processing with little to no CPU intervention. #### 11.1 Introduction The CRYPTOACC (Cryptographic Accelerator) includes hardware for symmetric-key cryptographic operations such as AES, a Public Key Engine (PKE) for asymmetric key operations, and a non-deterministic random number generator (RNG), suitable for key generation. CRYPTOACC also provides a DMA bus master for efficient data transfer into and out of the block. #### 11.2 Features - · Acceleration of cryptographic functions - · AES encryption and decryption with 128, 192, or 256-bit keys - SHA-1 and SHA-2 up to 256-bit - Supported block cipher modes of operation for AES include: ECB, CTR, CBC, CBC-MAC, CMAC, CCM, and GCM. - · ECC over GF(P) up to 256-bit - Supported ECC NIST recommended curves include P-192 and P-256 - · True Random Number Generation - · Entropy Source complies to NIST 800-90B requirements - · Online Health tests comply to NIST 800-90B and AIS31 requirements - Random Data Passes NIST 800-22 and NIST 800-90B test suites #### 11.3 Cryptographic Functions The CRYPTOACC allows efficient acceleration of common cryptographic operations with a low CPU load. CRYPTOACC can implement or accelerate Elliptic Curve Cryptography (ECC), Secure Hash Algorithm (SHA-1, SHA-224, SHA-256), and various block cipher modes based on the Advanced Encryption Standard (AES). Extensive software support is provided via mbed TLS plugins. Many security systems fail due to mistakes in the implementation. Therefore implementations should be left to experts in cryptographic algorithms. The implemented security functions are described in the mbed TLS documentation located at <a href="http://docs.silabs.com">http://docs.silabs.com</a>. Control and access registers for the cryptographic acceleration functions are described in the following sections. Although the register interface is provided here, it is highly recommended to use the APIs provided by mbed TLS. ### 11.3.1 CRYPTOACC\_PKCTRL Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|--------------------|------|-------------| | 0x000 | CRYPTOACC_POINTER | RW | Pointers | | 0x004 | CRYPTOACC_COMMAND | RW | Command | | 0x008 | CRYPTOACC_PKCTRL | W | Control | | 0x00C | CRYPTOACC_PKSTATUS | RH | Status | | 0x010 | CRYPTOACC_VERSION | R | Version | | 0x014 | CRYPTOACC_TIMER | RH | Timer | #### 11.3.2 CRYPTOACC\_PKCTRL Register Description ## 11.3.2.1 CRYPTOACC\_POINTER - Pointers | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|--------|-------------|----|----|----|----|----|----|--------|----------|------|-------|----|----|----|---|--------|----------|---|---|---|---|---|---|--------|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | <b>о</b> | ω | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | • | | | 2 | 2 | | | | | | | 2 | 2 | | | | | | | > | 2 | | | | • | | | 2 | 2 | | | Access | | | | | | 2 | <u>}</u> | | | | | | | 2 | <u>}</u> | | | | | | | 2 | 2 | | | | | | | 2 | 2 | | | Name | | | | | | Natago | Z<br>Z<br>L | | | | | | | Cataac | <u> </u> | | | | | | | адтадо | - | | | | | | | Vatado | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------|----------------------|------------------|----------------------------------------------------------------------------| | 31:28 | Reserved | To ensur<br>ventions | | with future devices, always write bits to 0. More information in 1.2 Con- | | 27:24 | OPPTRN | 0x0 | RW | OpPtrN | | | When executing p (location 0 or 0xF) | | operations, th | is pointer defines the location where the modulus is located in memory | | 23:20 | Reserved | To ensur<br>ventions | re compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | OPPTRC | 0x0 | RW | OpPtrC | | | When executing p in memory. | rimitive arithmetion | c operations, th | is pointer defines the location (0 to 0xF) where the result will be stored | | 15:12 | Reserved | To ensur<br>ventions | re compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 11:8 | OPPTRB | 0x0 | RW | OpPtrB | | | When executing p 0xF). | rimitive arithmetion | c operations, th | is Pointer defines where operand B is located in memory (location 0 to | | 7:4 | Reserved | To ensur<br>ventions | re compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | OPPTRA | 0x0 | RW | OpPtrA | | | When executing p 0xF). | rimitive arithmetion | operations, th | is Pointer defines where operand A is located in memory (location 0 to | # 11.3.2.2 CRYPTOACC\_COMMAND - Command | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|--------|-------|--------|-----------|--------|---------|----|----|----|----|----------|----|----|----|----|------|------|----|--------|----|---|----|---|---|-------|---|---|---|-----------|---|---|---| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | ဖ | 2 | 4 | က | 2 | ~ | 0 | | Reset | 0x0 | 0% | 000 | 000 | 000 | 0x0 | | | • | | 0X | | | | 1 | ' | | | 0X0 | | | | | | 0x0 | | | | 0X0 | | ľ | | | Access | RW | ₹ | R<br>W | R<br>≪ | ₽ | ₽ | | | | | ₩<br>M | | | | | | | | R<br>M | | | | | | ₽ | | | | ₽ | | | | | Name | CALCR2 | FLAGB | FLAGA | SWAPBYTES | BUFSEL | EDWARDS | | | | | SELCURVE | | | | | | | | SIZE | | | | | | FIELD | | | | OPERATION | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------------------|--------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------| | 31 | CALCR2 | 0x0 | RW | Calculate R2 | | | | | | N for the next operation. This bit must be set to '1' when a new prime primitive operations and ignored for the other operations | | | Value | Mode | | Description | | | 0 | FALSE | | don't recalculate R² mod N | | | 1 | TRUE | | re-calculate R² mod N | | 30 | FLAGB | 0x0 | RW | Flag B | | | Flag B | | | | | 29 | FLAGA | 0x0 | RW | Flag A | | | Flag A | | | | | 28 | SWAPBYTES | 0x0 | RW | Swap bytes | | | Swap the bytes on A doc section 4.2.1 | AHB interface. T | his bit must be | programmed before writing/reading any data in data memory. See | | | Value | Mode | | Description | | | 0 | NATIVE | | Native format (little endian) | | | 1 | SWAPPE | :D | Byte swapped (big endian) | | 27 | BUFSEL | 0x0 | RW | Buffer Select | | | Buffer Select | | | | | | Value | Mode | | Description | | | 0 | MEM0 | | use data in data memory 0 | | 26 | EDWARDS | 0x0 | RW | Edwards Curve Enable | | | Edwards | | | | | 25:23 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con | | 22:20 | SELCURVE | 0x0 | RW | Select Curve | | | Enable accelerator tincluded. | for specific curve | e modulus. This | field has no effect when the optional acceleration hardware is not | | Bit | Name | Reset | Access | Description | |------|-----------------------|-------------------|-------------------|--------------------------------------------------------------------------------------------| | | Value | Mode | | Description | | | 0 | NONE | | No acceleration | | | 1 | P256 | | P256 | | | 2 | P384 | | P384 | | | 3 | P521 | | P521/E-521 | | | 4 | P192 | | P192 | | | 5 | C25519 | | Curve25519/Ed25519 | | 19 | Reserved | To ensur | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 18:8 | SIZE | 0x0 | RW | Size of Operands in data memory | | | | | | s one) of the operands for the current operation. Possible values are ee doc for examples. | | 7 | FIELD | 0x0 | RW | Field | | | Field | | | | | | Value | Mode | | Description | | | 0 | GFP | | Field is GF(p) | | | 1 | GF2M | | Field is GF(2 <sup>n</sup> m) | | 6:0 | OPERATION | 0x0 | RW | Type of Operation | | | This field defines th | e operation to be | e performed. Se | ee BA414EP documentation for exhaustive enumeration listing | ## 11.3.2.3 CRYPTOACC\_PKCTRL - Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-----|---------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ≥ | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | IFC | PKSTART | | Bit | Name | Reset | Access | Description | |------|-----------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | IFC | 0x0 | W | ClearIRQ | | | Writing a '1' clears the IF | RQ output | | | | 0 | PKSTART | 0x0 | W | PK Start | | | Writing a '1' starts the pr | ocessing | | | ### 11.3.2.4 CRYPTOACC\_PKSTATUS - Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|--------|------|----|---------|-----------|---------------|-----------------|-------------|----------------|----------------|----------------|------------|------------|---|-----------|---|---| | 0x00C | 31 | 30 | 29 | ργ | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | • | · | | • | | | | | | | • | 000 | 0×0 | | • | 0x0 | 0X0 | 0x0 | 0×0 | 0x0 | 000 | 0x0 | 000 | 0x0 | 0x0 | | Š | 3 | | | Access | | | | | | | | | | | | | | | œ | œ | | | 22 | 2 | <u>~</u> | œ | ~ | 22 | œ | œ | 22 | œ | | Ω | | | | Name | | | | | | | | | | | | | | | PKIF | PKBUSY | | | NOTQUAD | COMPOSITE | NOTINVERTIBLE | PARAMABNOTVALID | SIGNOTVALID | NOTIMPLEMENTED | PARAMNNOTVALID | COUPLENOTVALID | ATINFINITY | NOTONCURVE | | FAII ADDR | | | | Bit | Name | Reset | Access | Description | |-------|------------------------------------|-----------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------| | 31:18 | Reserved | To ensure<br>ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 17 | PKIF | 0x0 | R | Interrupt status | | | This bit reflects the IRQ | output value | . It is set to '1' v | when the operation is finished. It is cleared by writing IFC | | 16 | PKBUSY | 0x0 | R | PK busy | | | This bit reflects the BUS finished | Y output valu | ue. It is set to '1 | when the operation starts and it is cleared when the operation is | | 15:14 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 13 | NOTQUAD | 0x0 | R | Not quadratic residue | | | set to '1' when executing | g a modular s | square root if the | e operand is not a quadratic residue. | | 12 | COMPOSITE | 0x0 | R | Composite | | | updated after the Rabin- | -Miller Primal | lity test | | | | Value | Mode | | Description | | | 0 | FALSE | | random number under test is probably prime | | | 1 | TRUE | | random number under test is composite | | 11 | NOTINVERTIBLE | 0x0 | R | Not invertible | | | set to '1' when executing | g a modular i | nversion (PK_C | commandReg[3:0] = 0x6 or 0x9) if the operand is not invertible | | 10 | PARAMABNOTVALID | 0x0 | R | Param AB not valid | | | set to 1 when parameter Check_AB | rs A and B ar | re not valid, i.e 4 | $4A^3+27B^2=0$ . This flag is updated after execution of the command | | 9 | SIGNOTVALID | 0x0 | R | Signature not valid | | | | | | e rejected. This flag is set to 1 when the signature is not valid and is eneration, ECDSA_Verification, DSA_Generation, DSA_Verification, | | 8 | NOTIMPLEMENTED | 0x0 | R | Not implemented | | | set to '1' when the Type | of operation | programmed in | the command register is not supported. | | 7 | PARAMNNOTVALID | 0x0 | R | Param n not valid | | Bit | Name | Reset | Access | Description | |-----|---------------------------------------------|-------------------|------------------|----------------------------------------------------------------------| | | set to 1 when Paramete | er n is not vali | d. This flag is | updated after execution of the command Check_n. | | 6 | COUPLENOTVALID | 0x0 | R | Couple not valid | | | set to 1 when couple x, mand Check_Couple_L | • | (i.e. not small | er than the prime). This flag is updated after execution of the com- | | 5 | ATINFINITY | 0x0 | R | Point Px at infinity | | | set to 1 when Point Px | is at the infinit | ty. This flag is | updated after execution of an ECC operation | | 4 | NOTONCURVE | 0x0 | R | Point Px not on curve | | | set to 1 when Point Px<br>Curve | is not on the o | defined EC. Th | nis flag is updated after execution of the command Check_Point_On- | | 3:0 | FAILADDR | 0x0 | R | Fail Address | | | These bits indicate whi | ch data location | on generated | the error flag. They are not available for all error flags. | ## 11.3.2.5 CRYPTOACC\_VERSION - Version | Offset | Bit Po | sition | | |--------|---------------------------------------------------------------------------------|---------|-------------------------------------------------------------------------| | 0x010 | 33<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>3 | 6 9 9 8 | L 0 0 4 8 0 L 0 | | Reset | | 0×0 | 0×0 | | Access | | α | α_ | | Name | | МН | SW | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 15:8 | HW | 0x0 | R | Hardware version number | | | Version of the hardware | | | | | 7:0 | SW | 0x0 | R | Software version number | | | Version of the micro-cod | е | | | ## 11.3.2.6 CRYPTOACC\_TIMER - Timer | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x014 | 31 | 99 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | • | • | • | • | | • | • | • | • | • | 2 | 2 | • | | • | • | • | | | | • | • | • | • | | • | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|---------------|-----------------|-------------| | 31:0 | TIMER | 0x0 | R | Timer | | | Number of core clock cy | cles used dur | ing previous op | eration | #### 11.4 DMA Interface The CRYPTOACC includes a DMA bus master which allows the block to autonomously fetch data, perform cipher operations and store data across multiple blocks with little CPU intervention. Control and access registers used for fetching and pushing data with the DMA bus master are documented in the following sections. Although the register interface is provided here, it is highly recommended to use the APIs provided by mbed TLS. The register map in this section includes several read-only hardware configuration registers. These are used by mbed TLS software to determine device capabilities. #### 11.4.1 CRYPTOACC Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|--------------------------------|------------|------------------------------------------| | 0x000 | CRYPTOACC_FETCHADDR | RW | Fetcher Address | | 0x008 | CRYPTOACC_FETCHLEN | RW | Fetcher Length | | 0x00C | CRYPTOACC_FETCHTAG | RW | Fetcher Tag | | 0x010 | CRYPTOACC_PUSHADDR | RW | Pusher Address | | 0x018 | CRYPTOACC_PUSHLEN | RW | Pusher Length | | 0x01C | CRYPTOACC_IEN | RWH | Interrupt Enable | | 0x028 | CRYPTOACC_IF | RH INTFLAG | Interrupt Flags | | 0x030 | CRYPTOACC_IF_CLR | WH | Interrupt status clear | | 0x034 | CRYPTOACC_CTRL | RW | Control register | | 0x038 | CRYPTOACC_CMD | W | Command register | | 0x03C | CRYPTOACC_STATUS | RH | Status register | | 0x400 | CRYP-<br>TOACC_INCL_IPS_HW_CFG | RH | General CRYPTOACC Hardware Configuration | | 0x404 | CRYP-<br>TOACC_BA411E_HW_CFG_1 | RH | BA411E Hardware Configuration 1 | | 0x408 | CRYP-<br>TOACC_BA411E_HW_CFG_2 | RH | BA411E Hardware Configuration 2 | | 0x40C | CRYPTOACC_BA413_HW_CFG | RH | BA413 Hardware Configuration | | 0x410 | CRYPTOACC_BA418_HW_CFG | RH | BA418 Hardware Configuration | | 0x414 | CRYPTOACC_BA419_HW_CFG | RH | BA419 Hardware Configuration | ### 11.4.2 CRYPTOACC Register Description ### 11.4.2.1 CRYPTOACC\_FETCHADDR - Fetcher Address | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | 2 | 2 | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | 0 | אחחא | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------------|-------|--------|-----------------------------| | 31:0 | ADDR | 0x0 | RW | Start address of data block | | | Fetch address | | | | ## 11.4.2.2 CRYPTOACC\_FETCHLEN - Fetcher Length | Offset | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|---------|-----------|----|----|----|----|----|----|----|----|----|----|----|-------|------|-------|--------|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | œ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | 000 | 0x0 | | | | | | | | • | | | | | | 2 | Š | | | • | • | | | | • | | | | | | | Access | | | Z. | RW | | | | | | | | | | | | | | 2 | ≥<br>Ľ | | | | | | | | | | | | | | | Name | | | REALIGN | CONSTADDR | | | | | | | | | | | | | | THUNG | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:30 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 29 | REALIGN | 0x0 | RW | Realign length | | | Fetch realign length | | | | | 28 | CONSTADDR | 0x0 | RW | Constant address | | | Fetch constant address | | | | | 27:0 | LENGTH | 0x0 | RW | Length of data block | | | Fetch length | | | | ### 11.4.2.3 CRYPTOACC\_FETCHTAG - Fetcher Tag | Offset | Bit Position | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x00C | 33 34 36 37 38 39 30 30 31 32 33 34 35 36 37 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×0 | | Access | R≷ | | Name | TAG | | Bit | Name | Reset | Access | Description | |------|----------|-------|--------|-------------| | 31:0 | TAG | 0x0 | RW | User tag | | | User tag | | | | ### 11.4.2.4 CRYPTOACC\_PUSHADDR - Pusher Address | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | • | | | • | • | | | | • | • | | | 2 | 2 | | | | | | | | | | | • | | | | | | Access | | | | | | | | | | | | | | | | 2 | Ž | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | 0 | אחחא | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-----------------------|-------|--------|-----------------------------| | 31:0 | ADDR | 0x0 | RW | Start address of data block | | | Push starting address | | | | ### 11.4.2.5 CRYPTOACC\_PUSHLEN - Pusher Length | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|---------|---------|-----------|----|----|----|----|----|----|----|----|----|---|----|------|------|--------|--------|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 0X0 | 000 | 000 | | | | | | | | | | • | | | | | S<br>S | | | | • | | • | | | • | • | | | | | Access | | ¥<br>M | ₩<br>M | R<br>M | | | | | | | | | | | | | | Š | ≩<br>Y | | | | | | | | | | | | | | | Name | | DISCARD | REALIGN | CONSTADDR | | | | | | | | | | | | | | H<br>( | E E | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|------------------------|-----------|-------------------|---------------------------------------------------------------------------| | 31 | Reserved | To ensur | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 30 | DISCARD | 0x0 | RW | Discard data | | | Discard data | | | | | 29 | REALIGN | 0x0 | RW | Realign length | | | Realign length | | | | | 28 | CONSTADDR | 0x0 | RW | Constant address | | | Constant address | | | | | 27:0 | LENGTH | 0x0 | RW | Start address of data block | | | Starting address of da | ita block | | | ### 11.4.2.6 CRYPTOACC\_IEN - Interrupt Enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|-------------|---------------|------------------|--------------|----------------|-------------------| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | ' | | | | • | | • | | ' | | | | | | | | | | | • | | ' | 0×0 | 0x0 | 0×0 | 0x0 | 0×0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | RW | Z<br>M | RW | ₩<br>M | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | PUSHERERROR | PUSHERSTOPPED | PUSHERENDOFBLOCK | FETCHERERROR | FETCHERSTOPPED | FETCHERENDOFBLOCK | | Bit | Name | Reset | Access | Description | |------|----------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure c | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | PUSHERERROR | 0x0 | RW | Error interrupt enable | | | Error interrupt enable | | | | | 4 | PUSHERSTOPPED | 0x0 | RW | Stopped interrupt enable | | | Stopped interrupt enable | | | | | 3 | PUSHERENDOF-<br>BLOCK | 0x0 | RW | End of block interrupt enable | | | End of block interrupt ena | able | | | | 2 | FETCHERERROR | 0x0 | RW | Error interrupt enable | | | Error interrupt enable | | | | | 1 | FETCHERSTOPPED | 0x0 | RW | Stopped interrupt enable | | | Stopped interrupt enable | | | | | 0 | FETCHERENDOF-<br>BLOCK | 0x0 | RW | End of block interrupt enable | | | End of block interrupt ena | able | | | ## 11.4.2.7 CRYPTOACC\_IF - Interrupt Flags | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|----------|---|-------------|---------------|------------------|--------------|----------------|-------------------| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | ' | | | | | | | | | ' | | • | | ' | | | | ' | <u>'</u> | | 0×0 | 0x0 | 000 | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>~</u> | 22 | œ | œ | <u>~</u> | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | PUSHERERROR | PUSHERSTOPPED | PUSHERENDOFBLOCK | FETCHERERROR | FETCHERSTOPPED | FETCHERENDOFBLOCK | | Bit | Name | Reset | Access | Description | |------|---------------------------|-----------------|-------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | PUSHERERROR | 0x0 | R | Error interrupt flag | | | Triggered when an error | response is r | eceived from AX | (I | | 4 | PUSHERSTOPPED | 0x0 | R | Stopped interrupt flag | | | Triggered when reaching | a block with | Stop=1 (or end | of direct transfer) | | 3 | PUSHERENDOF-<br>BLOCK | 0x0 | R | End of block interrupt flag | | | Triggered at the end of e | ach block (if e | enabled in the d | escriptor - scatter-gather only) | | 2 | FETCHERERROR | 0x0 | R | Error interrupt flag | | | Triggered when an error | response is r | eceived from AX | KI | | 1 | FETCHERSTOPPED | 0x0 | R | Stopped interrupt flag | | | Triggered when reaching | a block with | Stop=1 (or end | of direct transfer) | | 0 | FETCHERENDOF-<br>BLOCK | 0x0 | R | End of block interrupt flag | | | Triggered at the end of e | ach block (if e | enabled in the d | escriptor - scatter-gather only) | ## 11.4.2.8 CRYPTOACC\_IF\_CLR - Interrupt status clear | Offset | | | | | | | | | | | | | | | В | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|-------|------|----|----|----|---|----|---|---|---|---|-------------|---------------|------------------|--------------|----------------|-------------------| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | | • | | | | | • | | | | | • | | <u>'</u> | 1 | • | | • | | | | | ' | • | | 000 | 000 | 000 | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | > | > | > | > | > | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | PUSHERERROR | PUSHERSTOPPED | PUSHERENDOFBLOCK | FETCHERERROR | FETCHERSTOPPED | FETCHERENDOFBLOCK | | Bit | Name | Reset | Access | Description | |------|----------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | PUSHERERROR | 0x0 | W | Error interrupt flag clear | | | Error interrupt flag clear | | | | | 4 | PUSHERSTOPPED | 0x0 | W | Stopped interrupt flag clear | | | Stopped interrupt flag cle | ear | | | | 3 | PUSHERENDOF-<br>BLOCK | 0x0 | W | End of block interrupt flag clear | | | End of block interrupt fla | g clear | | | | 2 | FETCHERERROR | 0x0 | W | Error interrupt flag clear | | | Error interrupt flag clear | | | | | 1 | FETCHERSTOPPED | 0x0 | W | Stopped interrupt flag clear | | | Stopped interrupt flag cle | ear | | | | 0 | FETCHERENDOF-<br>BLOCK | 0x0 | W | End of block interrupt flag clear | | | End of block interrupt fla | g clear | | | # 11.4.2.9 CRYPTOACC\_CTRL - Control register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---------|------------|-------------|---------------------|----------------------| | 0x034 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | • | | 000 | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₽ | ₩<br>M | RW | Z. | W. | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | SWRESET | STOPPUSHER | STOPFETCHER | PUSHERSCATTERGATHER | FETCHERSCATTERGATHER | | Bit | Name | Reset | Access | Description | |------|------------------------------------------------------|-----------------|--------------------|-----------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | SWRESET | 0x0 | RW | Software reset | | | When this bit is high, the The AXI bus is not affect | | | odules, the FIFO's and the processing module will be activated. completed). | | 3 | STOPPUSHER | 0x0 | RW | Stop pusher | | | When this bit is high, the | pusher will st | top at the end of | the current block (even if the STOP bit in the descriptor is low). | | 2 | STOPFETCHER | 0x0 | RW | Stop fetcher | | | When this bit is high, the | fetcher will st | top at the end of | the current block (even if the STOP bit in the descriptor is low). | | 1 | PUSHERSCATTER-<br>GATHER | 0x0 | RW | Pusher scatter/gather | | | When this bit is zero, the | pusher runs | in direct mode. \ | When this bit is one, the pusher runs in scatter-gather mode. | | 0 | FETCHERSCATTER-<br>GATHER | 0x0 | RW | Fetcher scatter/gather | | | When this bit is zero, the | fetcher runs | in direct mode. \ | When this bit is one, the fetcher runs in scatter-gather mode. | ### 11.4.2.10 CRYPTOACC\_CMD - Command register | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-------------|--------------| | 0x038 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | | • | • | | | • | | | | | • | | | • | | | | | | | • | • | • | | • | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | STARTPUSHER | STARTFETCHER | | Bit | Name | Reset | Access | Description | |------|------------------------------|---------------|-------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | STARTPUSHER | 0x0 | W | Start push | | | Writing a '1' starts the pu | sher. Writing | a '0' has no effe | ct. | | 0 | STARTFETCHER | 0x0 | W | Start fetch | | | Writing a '1' starts the fet | cher. Writing | a '0' has no effe | ct. | ### 11.4.2.11 CRYPTOACC\_STATUS - Status register | Offset | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----------|-------|------|----|----|-----|------------|---------|----------|---|-----|-----------|------------|---|---|---|---|---| | 0x03C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 0×0 | | | | | | | ' | 1 | | | • | | <u>'</u> | • | | ' | • | 000 | 0X0 | 0X0 | | • | 000 | 0x0 | | | | | | | | Access | | α | | | | | | | | | | | | | | | | | | œ | 22 | 22 | | | œ | 2 | | | | | | | | Name | | FIFODATANUM R | | | | | | | | | | | | | | | | | | | SOFTRSTBSY | WAITING | NOTEMPTY | | | PUSHERBSY | FETCHERBSY | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|----------------|-------------------|------------------------------------------------------------------------| | 31:16 | FIFODATANUM | 0x0 | R | Number of data in output FIFO | | | Number of bytes in outp | ut FIFO (push | ner). | | | 15:7 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 6 | SOFTRSTBSY | 0x0 | R | Software reset busy | | | This bit is high when the | soft reset is | on-going. | | | 5 | WAITING | 0x0 | R | Pusher waiting for FIFO | | | This bit is high when the | pusher if wai | ting for more da | ta in output FIFO. | | 4 | NOTEMPTY | 0x0 | R | Not empty flag from input FIFO (fetcher) | | | Not empty flag from inpu | ut FIFO (fetch | er). | | | 3:2 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | PUSHERBSY | 0x0 | R | Pusher busy | | | This bit is high as long a | s the pusher | is busy. | | | 0 | FETCHERBSY | 0x0 | R | Fetcher busy | | | This bit is high as long a | s the fetcher | is busy. | | ### 11.4.2.12 CRYPTOACC\_INCL\_IPS\_HW\_CFG - General CRYPTOACC Hardware Configuration | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----------------|--------------|--------------|--------------|---------------|---------------------|---------------|--------------|-----------------|-----------------|--------------| | 0x400 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | - | 0 | | Reset | | | | | • | • | | | | | | • | • | | | • | | | | | | 0 <u>x</u> 1 | 0x1 | 0×0 | 0x0 | 0x0 | 0x0 | 0x1 | 0x0 | 0x0 | 0x0 | 0×1 | | Access | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | 22 | 2 | 22 | 2 | 2 | 2 | 2 | R | 2 | | Name | | | | | | | | | | | | | | | | | | | | | | g_IncludeNDRNG | g_IncludePKE | g_IncludeSM4 | g_IncludeZUC | g_IncludeSHA3 | g_IncludeChachaPoly | g_IncludeHASH | g_IncludeDES | g_IncludeAESXTS | g_IncludeAESGCM | g_IncludeAES | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|--------------------|------------------------------------------------------------------------| | 31:11 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 10 | g_IncludeNDRNG | 0x1 | R | Generic g_IncludeNDRNG value | | | BA431 – NDRNG IP inc | luded if set | | | | 9 | g_IncludePKE | 0x1 | R | Generic g_IncludePKE value | | | BA414EP – PKE IP incl | uded if set | | | | 8 | g_IncludeSM4 | 0x0 | R | Generic g_IncludeSM4 value | | | BA419 – SM4 IP include | ed if set | | | | 7 | g_IncludeZUC | 0x0 | R | Generic g_IncludeZUC value | | | BA421 – ZUC IP include | ed if set | | | | 6 | g_IncludeSHA3 | 0x0 | R | Generic g_IncludeSHA3 value | | | BA418 – SHA3 IP includ | led if set | | | | 5 | g_IncludeChachaPoly | 0x0 | R | Generic g_IncludeChachaPoly value | | | BA417 - ChachaPoly IP | included if se | et | | | 4 | g_IncludeHASH | 0x1 | R | Generic g_IncludeHASH value | | | BA413 – HASH IP include | ded if set | | | | 3 | g_IncludeDES | 0x0 | R | Generic g_IncludeDES value | | | BA412 – DES IP include | ed if set | | | | 2 | g_IncludeAESXTS | 0x0 | R | Generic g_IncludeAESXTS value | | | BA416 – AESXTS IP inc | cluded if set | | | | 1 | g_IncludeAESGCM | 0x0 | R | Generic g_IncludeAESGCM value | | | BA415 – AESGCM IP in | cluded if set | | | | 0 | g_IncludeAES | 0x1 | R | Generic g_IncludeAES value | | | BA411E – AES IP includ | ded if set | | | # 11.4.2.13 CRYPTOACC\_BA411E\_HW\_CFG\_1 - BA411E Hardware Configuration 1 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|--------------|------|------|----|----|----|---|----|---|---|---|---|---|--------------|-------------------|---|---|---| | 0x404 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 1 ო | 2 | - | 0 | | Reset | | • | | | | | 0x7 | | | | | • | • | • | 0x0 | 0x0 | | | • | | | | • | | | | • | 0×17E | L<br>X | · | | | | Access | | | | | | | 2 | | | | | | | | 22 | 22 | | | | | | | | | | | | Ω | ۲ | | | | | Name | | | | | | | g_Keysize | | | | | | | | g_UseMasking | g_cs | | | | | | | | | | | | Sac AssModes | g_Aesiviodes Loss | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------|--------------------|--------------------|------------------------------------------------------------------------| | 31:27 | Reserved | To ensure ventions | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 26:24 | g_Keysize | 0x7 | R | Generic g_Keysize value | | | BA411E AES engine co | nfiguration | | | | 23:18 | Reserved | To ensure ventions | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 17 | g_UseMasking | 0x0 | R | Generic g_UseMasking value | | | BA411E AES engine co | nfiguration | | | | 16 | g_CS | 0x0 | R | Generic g_CS value | | | BA411E AES engine co | nfiguration | | | | 15:9 | Reserved | To ensure ventions | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | g_AesModesPoss | 0x17F | R | AES Modes Supported | | | BA411E AES engine co | nfiguration | | | ### 11.4.2.14 CRYPTOACC\_BA411E\_HW\_CFG\_2 - BA411E Hardware Configuration 2 | Offset | Bit Position | | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------| | 0x408 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <t< th=""><th>· 0 r 4 w 7 - 0</th></t<> | · 0 r 4 w 7 - 0 | | Reset | 0880 | | | Access | α α | | | Name | g_CtrSize | | | Bit | Name | Reset | Access | Description | |-------|----------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | g_CtrSize | 0x80 | R | Generic g_CtrSize value | | | BA411E AES engine co | nfiguration | | | # 11.4.2.15 CRYPTOACC\_BA413\_HW\_CFG - BA413 Hardware Configuration | Offset | | Bit Position | | |--------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------| | 0x40C | 15 00 00 00 00 00 00 00 00 00 00 00 00 00 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 0 4 0 7 - 0 | | Reset | | 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 | 0x7F | | Access | | α α α | <b>c</b> | | Name | | g_HashVerifyDigest<br>g_HMAC_enabled<br>g_HashPadding | g_HashMaskFunc | | Bit | Name | Reset | Access | Description | |-------|----------------------|--------------------|------------------|--------------------------------------------------------------------------| | 31:19 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 18 | g_HashVerifyDigest | 0x0 | R | Generic g_HashVerifyDigest value | | | BA413 Hash engine co | nfiguration | | | | 17 | g_HMAC_enabled | 0x1 | R | Generic g_HMAC_enabled value | | | BA413 Hash engine co | nfiguration | | | | 16 | g_HashPadding | 0x1 | R | Generic g_HashPadding value | | | BA413 Hash engine co | nfiguration | | | | 15:7 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 6:0 | g_HashMaskFunc | 0x7F | R | Generic g_HashMaskFunc value | | | BA413 Hash engine co | nfiguration | | | ### 11.4.2.16 CRYPTOACC\_BA418\_HW\_CFG - BA418 Hardware Configuration | Offset | Bit Position | | |--------|-----------------------------------------|--------------| | 0x410 | 7 - 7 - 8 - 8 - 8 - 8 - 8 - 8 - 8 - 8 - | 0 | | Reset | | 0x1 | | Access | | ď | | Name | | g_Sha3CtxtEn | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | g_Sha3CtxtEn | 0x1 | R | Generic g_Sha3CtxtEn value | | | BA418 SHA3 configurati | on | | | # 11.4.2.17 CRYPTOACC\_BA419\_HW\_CFG - BA419 Hardware Configuration | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|----------------|---|---|---| | 0x414 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | | | | | | | | | • | | • | | | | • | • | • | • | • | • | | | | | 0x5F | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | g_SM4ModesPoss | | | | | Bit | Name | Reset | Access | Description | |------|---------------------|--------------------|---------------|-------------------------------------------------------------------------------| | 31:7 | Reserved | To ensure ventions | e compatibili | ity with future devices, always write bits to 0. More information in 1.2 Con- | | 6:0 | g_SM4ModesPoss | 0x5F | R | Generic g_SM4ModesPoss value | | | BA419 SM4 engine co | nfiguration | | | #### 11.5 Random Number Generation The CRYPTOACC provides access to a non-deterministic random number generator based on a full hardware solution. The RNG output passes the NIST 800-22 and AIS31 test suites. The RNG 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$ Control and access registers for the random number generator are described in the following sections. Although the register interface is provided here, it is highly recommended to use the APIs provided by mbed TLS. #### 11.5.1 CRYPTOACC\_RNGCTRL Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|-----------------------|------|--------------------------------| | 0x000 | CRYPTOACC_RNGCTRL | RWH | RNG Control Register | | 0x004 | CRYPTOACC_FIFOLEVEL | RH | FIFO Level Register | | 0x008 | CRYPTOACC_FIFOTHRESH | RH | FIFO Threshold Register | | 0x00C | CRYPTOACC_FIFODEPTH | R | FIFO Depth Register | | 0x010 | CRYPTOACC_KEYx | RW | Key Register | | 0x020 | CRYPTOACC_TESTDATA | W | Test Data Register | | 0x030 | CRYPTOACC_RNGSTATUS | RWH | RNG Status Register | | 0x034 | CRYPTOACC_INITWAITVAL | RW | Initial Wait Counter | | 0x040 | CRYPTOACC_SWOFFTMRVAL | RW | Switch off timer value | | 0x044 | CRYPTOACC_CLKDIV | RW | Sample clock divider | | 0x048 | CRYPTOACC_AIS31CONF0 | RW | AIS31 configuration 0 register | | 0x04C | CRYPTOACC_AIS31CONF1 | RW | AIS31 configuration 1 register | | 0x050 | CRYPTOACC_AIS31CONF2 | RW | AIS31 configuration 2 register | | 0x054 | CRYPTOACC_AIS31STATUS | RWH | AIS31 status register | ### 11.5.2 CRYPTOACC\_RNGCTRL Register Description ## 11.5.2.1 CRYPTOACC\_RNGCTRL - RNG Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|---------|----|----|----------|---------------|----|--------|------------------|--------|--------------|---------------|----------|---------|----------|--------|--------|-----------|---------|------------|----------|-------------|------------|--------|-----|--------| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | • | | | | | | | | • | 0x0 | | 3 | 4X0 | | 0x0 | 0x0 | | | Access | | | | | | | | RW<br>W | | 2 | <u>}</u> | | RW | ₩<br>M | S. | ₩<br>M | S. | ₩<br>M | RW<br>W | ₩<br>M | Z. | ₩<br>M | Z. | RW | ₩<br>M | ₩<br>M | | Z. | | | | | | Name | | | | | | | | | | | | FIFOWRSTARTUP | | | NB IZ8BII BLUCKS | | AIS31TESTSEL | HEALTHTESTSEL | BYPAIS31 | BYPNIST | FORCERUN | ALMIEN | PREIEN | SOFTRESET | FULLIEN | APT4096IEN | APT64IEN | REPCOUNTIEN | CONDBYPASS | TESTEN | | ENABLE | | Bit | Name | Reset | Access | Description | |-------|--------------------------|---------------|--------------------|-------------------------------------------------------------------------------------------| | 31:21 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 20 | FIFOWRSTARTUP | 0x0 | RW | Fifo Write Start Up | | | Fifo Write Start Up | | | | | 19:16 | NB128BITBLOCKS | 0x4 | RW | Number of 128b blocks in AES-CBCMAC | | | Number of 128 bit blocks | s used in AES | S-CBCMAC post | -processing. This value cannot be zero | | 15 | AIS31TESTSEL | 0x0 | RW | AIS31 test input select | | | AIS31 test input select | | | | | | Value | Mode | | Description | | | 0 | BEFORE | | Before conditioning | | | 1 | AFTER | | After conditioning | | 14 | HEALTHTESTSEL | 0x0 | RW | Health test input select | | | Health test input select | | | | | | Value | Mode | | Description | | | 0 | BEFORE | | Before conditioning | | | 1 | AFTER | | After conditioning | | 13 | BYPAIS31 | 0x0 | RW | AIS31 Start-up Test Bypass. | | | Bypass for AIS31 startup | test. | | | | | Value | Mode | | Description | | | 0 | NORMAL | | AIS31 startup test is applied. No data will be written to the FIFO until the test passes. | | | 1 | BYPASS | | AIS31 startup test is bypassed. | | 12 | BYPNIST | 0x0 | RW | NIST Start-up Test Bypass. | | Bit | Name | Reset | Access | Description | |-----|-----------------------|---------------------|--------------------|--------------------------------------------------------------------------------------------------| | | Bypass for NIST-80 | 0-90B startup tes | st. | | | | Value | Mode | | Description | | | 0 | NORMAL | | NIST-800-90B startup test is applied. No data will be written to the FIFO until the test passes. | | | 1 | BYPASS | | NIST-800-90B startup test is bypassed. | | 11 | FORCERUN | 0x0 | RW | Oscillator Force Run | | | Set this bit to force | oscillators to run | even when FIF | O is full. | | | Value | Mode | | Description | | | 0 | NORMAL | | Oscillators will shut down when FIFO is full | | | 1 | RUN | | Oscillators will continue to run even after FIFO is full | | 10 | ALMIEN | 0x0 | RW | IRQ enable for AIS31 noise alarm | | | Enable/disable AIS | 31 noise alarm in | terrupt. | | | 9 | PREIEN | 0x0 | RW | IRQ enable for AIS31 prelim. noise alarm | | | Enable/disable AIS | 31 preliminary no | ise alarm interr | upt. | | 8 | SOFTRESET | 0x0 | RW | Software Reset | | | Set to reset the mod | dule. This bit is n | ot cleared autor | matically. | | | Value | Mode | | Description | | | 0 | NORMAL | | Module not in reset | | | 1 | RESET | | The continuous test, the conditioning function and the FIFO are reset | | 7 | FULLIEN | 0x0 | RW | IRQ enable for FIFO full | | | Enable/Disable FIF | O full interrupt. | | | | 6 | APT4096IEN | 0x0 | RW | IRQ enable for APT4096IF | | | Enable/Disable 409 | 6-sample Adapti | ve Proportion te | est failure interrupt. | | 5 | APT64IEN | 0x0 | RW | IRQ enable for APT64IF | | | Enable/Disable 64-s | sample Adaptive | Proportion test | failure interrupt. | | 4 | REPCOUNTIEN | 0x0 | RW | IRQ enable for Repetition Count Test | | | Enable/Disable Rep | etition Count Te | st failure interru | pt. | | 3 | CONDBYPASS | 0x0 | RW | Conditioning Bypass | | | Enables bypassing | of the conditionir | ng function (to o | bserve entropy source directly). | | | Value | Mode | | Description | | | 0 | NORMAL | | The conditionig function is used | | | 1 | BYPASS | | The conditioning function is bypassed | | 2 | TESTEN | 0x0 | RW | Test Enable | | | Selects the input for | the conditioning | function and a | | | Bit | Name | Reset | Access | Description | |-----|----------------------|--------------------|------------------|-------------------------------------------------------------------------| | | Value | Mode | | Description | | | 0 | NOISE | | Non-determinsitc random number generation | | | 1 | TESTDATA | 4 | Pseudo-random number generation | | 1 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 0 | ENABLE | 0x0 | RW | TRNG Module Enable | | | Enable the TRNG. The | module will ge | enerate random | numbers unless the FIFO is full. | | | Value | Mode | | Description | | | 0 | DISABLED | ) | Module disabled | | | 1 | ENABLED | | Module enabled | | | | | | | ## 11.5.2.2 CRYPTOACC\_FIFOLEVEL - FIFO Level Register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|-------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x004 | 31 | 39 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 0<br>0<br>0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | <u>α</u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | בובטו בייבו | > | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------|--------------------|-------------| | 31:0 | FIFOLEVEL | 0x0 | R | FIFO Level | | | Number of 32-bit words | of random da | ta available in th | ne FIFO. | ### 11.5.2.3 CRYPTOACC\_FIFOTHRESH - FIFO Threshold Register | Offset | Bit Position | | | | | | | | | | | | | | | |--------|------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x008 | 33 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | | | | | | | | | | | | | | | | Reset | 0×3<br>8× | | | | | | | | | | | | | | | | Access | α | | | | | | | | | | | | | | | | Name | FIFOTHRESH | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|----------------|-------------------|-------------------------------------------------------------| | 31:0 | FIFOTHRESH | 0x3F | R | FIFO threshold level | | | FIFO level at which the | ings are resta | arted when in the | e FIFOFull_Off state, expressed in number of 128bit blocks. | ## 11.5.2.4 CRYPTOACC\_FIFODEPTH - FIFO Depth Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|-----------------------------------------|----|----|----|----|----|----|----|----|---|----|----|----|----|-----------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 000000000000000000000000000000000000000 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | Š<br>Ľ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | EIEODEBTH | 0 | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|----------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--|--|--| | 31:0 | FIFODEPTH | 0x40 | R | FIFO Depth. | | | | | | | | | | | Maximum number of 32-bit words that can be stored in the FIFO. | | | | | | | | | | | | ## 11.5.2.5 CRYPTOACC\_KEYx - Key Register | Offset | Bit Position | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x010 | 33 34 37 38 39 30 30 30 31 32 33 34 35 36 37 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×0 | | Access | N | | Name | ΥĒΥ | | Bit | Name | Reset | Access | Description | |------|-----------------------------------|---------------|----------------|-----------------------------------------------------------------| | 31:0 | KEY | 0x0 | RW | Key | | | KEY0, KEY1, KEY2, and is the LSB. | d KEY3 form t | he 128-bit AES | key used in the conditioning function. KEY0 is the MSB and KEY3 | # 11.5.2.6 CRYPTOACC\_TESTDATA - Test Data Register | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |----|-----|--------|---------|----------------------|-------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------|----|------------------------------------------|----|----------|----------------------------------------------------------|----|----------|----|---------------------------------------------------------------------------|----|----------------------------------------------------------|------|-------|---|-----------------------------------------------------------------------------------------|---|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | • | • | • | • | | | | | | | | | | | > | 8 | | | • | | | | | | | | • | | • | • | | | | | | | | | | | | | | | | | > | > | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | ,<br>, | | | | | | | | | | | | | | | | | `` | (S) | 5 30 3 | 78 29 3 | 29<br>29<br>28<br>27 | 29 30 30 50 50 50 50 50 50 50 50 50 50 50 50 50 | 25 26 27 28 29 30 25 26 27 28 29 20 | 25 28 29 30 52 52 54 54 54 54 54 54 54 54 54 54 54 54 54 | 23 24 25 26 27 28 27 28 27 28 29 20 21 22 23 24 25 26 27 28 29 20 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>25 23 24 25 28 23 24 25 25 25 25 25 25 25 25 25 25 25 25 25</th> <th>25 25 25 25 27 28 29 21 25 25 25 25 25 25 25 25 25 25 25 25 25</th> <th>2</th> <th>20 S S S S S S S S S S S S S S S S S S S</th> <th>2</th> <th></th> <th>28 29 30 52 53 53 64 64 64 64 64 64 64 64 64 64 64 64 64</th> <th></th> <th>0X0<br/>M</th> <th>W</th> <th>W 0X0 22 23 23 23 30 30 4 12 13 14 15 15 15 15 15 15 15 15 15 15 15 15 15</th> <th>W</th> <th>W 0X0 16 17 18 19 10 10 10 10 10 10 10 10 10 10 10 10 10</th> <th>W NX</th> <th>W 0X0</th> <th>W</th> <th>W 0X0 16 17 18 19 22 22 22 23 30 17 17 18 19 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10</th> <th>W</th> <th>W 0X0 16 17 17 18 19 10 10 10 10 10 10 10 10 10 10 10 10 10</th> <th>W 0x0 15 12 22 22 22 23 30 15 14 17 11 17 17 18 8 8 7 7 8 8 8 8 8 9 10 11 17 17 17 18 18 18 18 18 18 18 18 18 18 18 18 18</th> <th></th> <th>0x0 12 33 4 5 6 4 5 6 7 12 13 14 15 16 17 17 18 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 <t< th=""></t<></th> | 25 23 24 25 28 23 24 25 25 25 25 25 25 25 25 25 25 25 25 25 | 25 25 25 25 27 28 29 21 25 25 25 25 25 25 25 25 25 25 25 25 25 | 2 | 20 S S S S S S S S S S S S S S S S S S S | 2 | | 28 29 30 52 53 53 64 64 64 64 64 64 64 64 64 64 64 64 64 | | 0X0<br>M | W | W 0X0 22 23 23 23 30 30 4 12 13 14 15 15 15 15 15 15 15 15 15 15 15 15 15 | W | W 0X0 16 17 18 19 10 10 10 10 10 10 10 10 10 10 10 10 10 | W NX | W 0X0 | W | W 0X0 16 17 18 19 22 22 22 23 30 17 17 18 19 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 | W | W 0X0 16 17 17 18 19 10 10 10 10 10 10 10 10 10 10 10 10 10 | W 0x0 15 12 22 22 22 23 30 15 14 17 11 17 17 18 8 8 7 7 8 8 8 8 8 9 10 11 17 17 17 18 18 18 18 18 18 18 18 18 18 18 18 18 | | 0x0 12 33 4 5 6 4 5 6 7 12 13 14 15 16 17 17 18 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 <t< th=""></t<> | | Bit | Name | Reset | Access | Description | |------|----------------------------|-----------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | VALUE | 0x0 | W | Test data input to conditioning tests | | | input data for the selecte | ed test in test<br>s written, and | t mode (CONTF<br>d will clear to 0 | tinuous tests. Each word written to this register represents 32 bits of ROL_TESTEN = 1). TESTDATABUSY in the STATUS register will be when the next data word can be written. Writes to this register are is 0. | ### 11.5.2.7 CRYPTOACC\_RNGSTATUS - RNG Status Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|-------|-------|--------|-----------|---------|------------|---|----------|---|--------------| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | | ' | ' | | | | | | | | | | | | | | | ' | 0x0 | 0×0 | 0x0 | 0×0 | 0×0 | 0x0 | | 000 | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | ~ | W. | œ | ~ | ď | ď | | <u>~</u> | | ~ | | Name | | | | | | | | | | | | | | | | | | | | | | | ALMIF | PREIF | FULLIF | APT4096IF | APT64IF | REPCOUNTIF | | STATE | | TESTDATABUSY | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-----------------|-------------------|--------------------------------------------------------------------------| | 31:10 | Reserved | | | ith future devices, always write bits to 0. More information in 1.2 Con- | | 9 | ALMIF | 0x0 | R | AIS31 Noise Alarm interrupt status | | | Set when a noise aları | m is detected i | n the AIS31 onli | ne test. | | 8 | PREIF | 0x0 | RW | AIS31 Preliminary Noise Alarm IF | | | Set when a preliminary | y noise alarm i | s detected in the | e AIS31 online test. | | 7 | FULLIF | 0x0 | R | FIFO full interrupt status | | | Set when the FIFO is | full. | | | | 6 | APT4096IF | 0x0 | R | 4096-sample window Adaptive Prop. IF | | | Set when an Adaptive | Proportion tes | st (4096-sample | window) failure occurs. | | 5 | APT64IF | 0x0 | R | 64-sample window Adaptive Proportion IF | | | Set when an Adaptive | Proportion tes | st (64-sample wi | ndow) failure occurs. | | 4 | REPCOUNTIF | 0x0 | R | Repetition Count Test interrupt status | | | Set when a Repetition | Count Test fa | ilure occurs. | | | 3:1 | STATE | 0x0 | R | State of the control FSM | | | State of the control FS | SM | | | | | Value | Mode | | Description | | | 0 | RESET | | RESET State | | | 1 | STARTUF | ) | STARTUP State | | | 2 | FIFOFULI | _ON | FIFOFULLON State | | | 3 | FIFOFULI | _OFF | FIFOFULLOFF State | | | 4 | RUNNING | } | RUNNING State | | | 5 | ERROR | | ERROR State | | | 6 | UNUSED | _6 | UNUSED | | | 7 | UNUSED | _7 | UNUSED | | 0 | TESTDATABUSY | 0x0 | R | Test Data Busy | | Bit | Name | Reset | Access | Description | |-----|-------------------|---------------------|----------------|---------------------------------------------------------------| | | Indicates that da | ta written to TESTD | ATA is being p | processed. | | | Value | Mode | | Description | | | 0 | IDLE | | TESTDATA write is finished processing or no test in progress. | | | 1 | BUSY | | TESTDATA write is still being processed. | ## 11.5.2.8 CRYPTOACC\_INITWAITVAL - Initial Wait Counter | Offset | Bit Po | sition | |--------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x034 | 33<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31 | 4 6 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | | Reset | | 0XFFFF | | Access | | R<br>⊗ | | Name | | INITWAITVAL | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|----------------------------------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:16 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 15:0 | INITWAITVAL | 0xFFFF | RW | Wait counter value | | | | | | | | | | | Number of clock cycles to wait before sampling data from the noise source. | | | | | | | | | | | | ### 11.5.2.9 CRYPTOACC\_SWOFFTMRVAL - Switch off timer value | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|--------|-------------|-----|---|---|-----|---|---|---| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | - 9 | 5 | 4 | 1 ო | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | !<br>! | 0xFFFF | · | | | • | • | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | i | <u>×</u> | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | SWOFFTMRVAL | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |-------|----------------------------------------------------------------------------------|-------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:16 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 15:0 | SWOFFTMRVAL | 0xFFFF | RW | Switch Off Timer Value | | | | | | | | | | Number of clock cycles to wait before stopping the rings after the FIFO is full. | | | | | | | | | | | # 11.5.2.10 CRYPTOACC\_CLKDIV - Sample clock divider | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|--------|---|---|---| | 0x044 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | • | | • | | • | • | | | | | | | | | | 0X0 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Σ<br>Š | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | VALUE | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | VALUE | 0x0 | RW | Sample clock divider | | | The frequency at which t | he outputs of | the rings are sa | ampled is given by Fs = Fpclk/(CLKDIV + 1). | ## 11.5.2.11 CRYPTOACC\_AIS31CONF0 - AIS31 configuration 0 register | Offset | | | | | | | | | | | | | | | В | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----------|----|----|----|----|----|----|--------------|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|----|--------------|---|---|---|---|---|---|---| | 0x048 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | - | 0 | | Reset | | | | | | | ' | | 0x4340 | | | | | | • | • | | | 1 | • | | | | • | 0x1040 | • | | • | 1 | | | | | Access | | WA<br>VO | | | | | | | | | | | | | | | | | | | | | | ΑW | | | | | | | | | | Name | | | | | | | | | ONLINETHRESH | | | | | | | | | | | | | | | | STARTUPTHRES | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 30:16 | ONLINETHRESH | 0x4340 | RW | Online Threshold | | | Online Threshold | | | | | 15 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 14:0 | STARTUPTHRES | 0x1040 | RW | Start-up Threshold | | | Start-up Threshold | | | | ### 11.5.2.12 CRYPTOACC\_AIS31CONF1 - AIS31 configuration 1 register | Offset | | | | | | | | | | | | | | | В | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|----------------|---|---|---|---|---|---|---| | 0x04C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | 0x3C0 | | | • | | | • | | | | | • | | | | | 0x680 | | | | • | | • | | | Access | | | | | | | | | R<br>⊗ | | | | | | | | | | | | | | | | X<br>≪ | | | | | | | | | Name | | | | | | | | | ONLINEREPTHRESH | | | | | | | | | | | | | | | | HEXPECTEDVALUE | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------|-------------|-------------------|------------------------------------------------------------------------| | 31 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 30:16 | ONLINEREPTHRESH | 0x3C0 | RW | Online Repeat Threshold | | | Online Rep Threshold | | | | | 15 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 14:0 | HEXPECTEDVALUE | 0x680 | RW | Expected History Value | | | HExpected Value | | | | ## 11.5.2.13 CRYPTOACC\_AIS31CONF2 - AIS31 configuration 2 register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|-----------------------------------------|----|----|----|----|----|----|-------|----|----|----|----|---|----|------|------|----|----|----|---|----|---|------|-------|---|---|---|---|---|---|---| | 0x050 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | ∞ | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | | | | | | | 0x440 | | | • | | • | | • | | | | | | | | • | 0x340 | | | | | | | | | Access | | \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \ | | | | | | | | | | | | | | | | | | | | RW | | | | | | | | | | | | Name | | HMAX RW | | | | | | | | | | | | | | | | | | | | | | NIMH | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------|--------------------|-----------------|---------------------------------------------------------------------------| | 31 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 30:16 | HMAX | 0x440 | RW | Maximum Allowed History Value | | | HMax | | | | | 15 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 14:0 | HMIN | 0x340 | RW | Minimum Allowed History Value | | | HMin | | | | ### 11.5.2.14 CRYPTOACC\_AIS31STATUS - AIS31 status register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---------------------|---------------------|------|----|----|----|---|----|---|---|----------|---|---|---|---|---|---|---| | 0x054 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | 0x0 | 000 | | | | | | | | 2 | 2 | | | | | • | | | | Access | | | | | | | | | | | | | | | RW | Z<br>≪ | | | | | | | | 2 | <u>}</u> | | | | | | | | | Name | | | | | | | | | | | | | | | PRELIMNOISEALARMREP | PRELIMNOISEALARMRNG | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:18 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 17 | PRELIMNOISEALARM-<br>REP | 0x0 | RW | Preliminary noise alarm Rep | | | Last preliminary noise ala | arm occurred | due to consecu | tive high X^2 | | 16 | PRELIMNOISEA-<br>LARMRNG | 0x0 | RW | Preliminary noise alarm RNG | | | Last preliminary noise ala | arm occurred | due to history v | alue out of range | | 15:0 | NUMPRELIMALARMS | 0x0 | RW | Number of preliminary alarms | | | Number of preliminary no | oise alarms si | nce counter wa | s last cleared | #### 12. EMU - Energy Management Unit #### **Quick Facts** #### What? The EMU (Energy Management Unit) handles the different low energy modes in EFR32xG22 #### 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 EFR32xG22. 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 EFR32xG22. 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 287, 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 EFR32xG22 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 288 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,<br>WFE) | Deep Sleep<br>(WFI, WFE) | Deep Sleep<br>(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: Peripherals such as the IADC and radio have the ability to temporarily wake up the part from either EM2 or EM3 to EM1 in order to transfer data. Once completed, the part is automatically placed back into the EM2 or EM3 mode. 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. Table 12.2. Energy Modes | | EM0 / EM1 | EM2 | ЕМ3 | EM4 | |---------------------------------------|------------------|------------------------|------------------------|------------------| | Wake-up time to EM0 / EM1 | - | TBD <sup>1</sup> | TBD <sup>1</sup> | TBD <sup>1</sup> | | Cortex-M33 Core Active | Yes, in EM0 only | - | - | - | | Debug | Available | See Note <sup>2</sup> | See Note <sup>2</sup> | - | | Digital logic and system RAM retained | Yes | Yes | Yes | - | | Flash Memory Access | Available | - | - | - | | LDMA (Linked DMA Controller) | Available | Available <sup>3</sup> | Available <sup>3</sup> | - | | Radio Controller | Available | Available <sup>4</sup> | - | - | | RFSENSE | Available | Available | Available | Available | <sup>1.</sup> Peripheral wake-up from EM2/3 to EM1 and then automatically back to EM2/3 when done. | | EM0 / EM1 | EM2 | EM3 | EM4 | |----------------------------------------------------------------------------------------------------------------|-----------|--------------------------------------|--------------------------------------|-------------------------| | High Frequency Oscillators<br>(HFXO,HFRCODPLL) and<br>Clocks (BUSCLK, HCLK,<br>PCLK, RADIOCLK,<br>EM01GRPACLK) | Available | - | - | - | | Fast Startup RC Oscillator<br>(FSRCO) and ADC Clock<br>(IADCCLK) | Available | Available <sup>5</sup> | Available <sup>5</sup> | - | | Low Frequency Oscillators (LFRCO, LFXO) | Available | Available | - | Available <sup>6</sup> | | Low Energy Clocks<br>(EM23GRPACLK, WDOGCLK,<br>RTCCCLK, PRORTCCLK) | Available | Available | Available <sup>7</sup> | - | | EM4 Clock (EM4GRPACLK) | Available | Available | Available <sup>7</sup> | Available <sup>6</sup> | | ULFRCO (Ultra Low Frequency Oscillator) | On | On | On | Available <sup>6</sup> | | CRYPTOACC (Crypto Accelerator) | Available | - | - | - | | GPCRC ( General Purpose<br>Cyclic Redundancy Check) | Available | - | - | - | | BURTC | Available | Available | Available <sup>7</sup> | Available | | RTCC | Available | Available | Available <sup>7</sup> | - | | RTCC Memory Retained | Yes | Yes | Yes | - | | USART (UART/SPI) | Available | - | - | - | | EUART | Available | Available <sup>11</sup> | - | - | | I <sup>2</sup> C | Available | Available <sup>8</sup> <sup>11</sup> | Available 8 | - | | TIMER (Timer/Counter) | Available | - | - | - | | LETIMER (Low Energy Timer) | Available | Available <sup>11</sup> | Available <sup>7 11</sup> | - | | WDOG (Watchdog) | Available | Available <sup>11</sup> | Available <sup>7 11</sup> | - | | IADC (Analog to Digital Converter) | Available | Available <sup>3</sup> <sup>11</sup> | Available <sup>3</sup> <sup>11</sup> | - | | PDM | Available | - | - | - | | DC-DC | Available | Available | Available | - | | EMU Temperature Change | Available | Available | Available | - | | Brown-Out Detect/Power-on Reset | Available | Available | Available | Available | | Pin Reset | Available | Available | Available | Available | | PRS (Peripheral Reflex System) | Available | Available <sup>11</sup> | Available <sup>11</sup> | - | | GPIO Pin Interrupts | Available | Available | Available | Available 9 | | GPIO Pin State Retention | Yes | Yes | Yes | Available <sup>10</sup> | | EM0 / EM1 | EM2 | ЕМ3 | EM4 | |-----------|-----|-----|-----| |-----------|-----|-----|-----| ### Note: - 1. Approximate time. Additional 32 us / 100 mV required to scale up from a lower VSCALE setting. Refer to the data sheet for specific timing. - 2. 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. - 3. 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. - 4. The RAC can be woken via a PRS interrupt to EM1 to transfer data. Once complete, the system will return to EM2. - 5. Default off, but kept active if used by the IADC. - 6. Default off, but kept active if used by the BURTC - 7. Must be using ULFRCO - 8. I2C0 only. Not supported on all GPIO Ports. Functionality limited to receive address recognition - 9. Pin wake-up in EM4 supported only on GPIO EM4WUx pins. Consult data sheet for complete list of pins. - 10. If enabled in EMU->EM4CTRL.EM4IORETMODE. - 11. Module is in Low Power Domain B (PD0B). The entire PD0B will be kept on in EM2/3 (resulting in higher current draw) if any module in PD0B is enabled on EM2/3 entry. 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 - · Radio and HFXO 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 - RFSENSE available - · High frequency clock tree is inactive - · Low frequency clock tree is active - · The following oscillators are available - · LFRCO, LFXO, ULFRCO, FSRCO (on demand, if used by the IADC) - · The following low frequency peripherals are available - · RTCC, BURTC, WDOG, and LETIMER - The following analog peripherals are available (with potential limitations on functionality) - IADC - Wake-up to EM0 through - Peripheral interrupt, reset pin, power on reset, asynchronous pin interrupt, I2C0 address recognition, EUART0 interrupt, or RFSENSE - · Wake-up to EM1 through - · Radio 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 - · RTCC memory 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.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 - · RFSENSE available - · 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, FSRCO (on demand, if used by the IADC) - · The following low frequency peripherals are available if clocked by the ULFRCO - · RTCC, BURTC, and WDOG - The following analog peripherals are available (with potential limitations on functionality) - IADC - Wake-up to EM0 through - Peripheral interrupt, reset pin, power on reset, asynchronous pin interrupt, I2C0 address recognition, or RFSENSE - · Wake-up to EM1 through - · Radio 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 - · RTCC memory 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 - RFSENSE available - · 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), or RFSENSE - 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 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. 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 the RAC 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 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 | - | | EUART0 | Any enabled interrupt | Yes | - | - | | RFSENSE | Wake condition met | Yes | Yes | Yes | | RTCC | 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 The EFR32xG22 implements 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. 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, etc.) 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:** The number of PD0 power domains varies depending on the device family. All devices support at least the base PD0 power domain (PD0A). Refer to the device data sheet for information on the assignment of peripherals to auxiliary PD0 power domains. 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. ### 12.3.5 Voltage Scaling The EFR32xG22 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: | VSCALE Setting | DECOUPLE Voltage | Operating Conditions | |----------------|------------------|--------------------------------| | VSCALE2 | 1.1 V | EM0/EM1 Operation up to 80 MHz | | | | EM2 and EM3 | | VSCALE1 | 1.0 V | EM0/EM1 Operation up to 40 MHz | | | | EM2 and EM3 | | VSCALE0 | 0.9 V | EM2 and EM3 Only | Table 12.4. Voltage Scaling Options ## 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\_VSCA-LEBUSY 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. The voltage scale level for EM2 and EM3 is set using 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. EMU\_CTRL\_EMU23VSCALE should always be set to a VSCALE level at or lower than the one used in EM0/EM1. For example, if EM0 / EM1 voltage scaling is set to VSCALE1, then EM2 / EM3 voltage scaling can be set to VSCALE1 or VSCALE0. If the voltage scaling level for EM0 / EM1 is lower than the level set for EM2 / EM3, additional time is needed to wake up from the low powered state (see the device data sheet for specific timing). The lowest sleep current will be obtained by setting EMU23VSCALE to VSCALE0, and the fastest wake times will be obtained when EMU23VSCALE is set to 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\_PD1PAR-ETCTRL\_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 reconfigure any peripherals as necessary when the device wakes to EMO. #### 12.3.7 Power Configurations In order to provide the lowest power solutions, the EFR32xG22 comes with a DC-DC module to power internal circuits. The EFR32xG22 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 EFR32xG22 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 (DECOUPLE). Additional detail for each configuration and option is given in the following sections. Due to on-chip circuitry (e.g., diodes), some EFR32 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 >= DVDD Note: In systems not using the DC-DC converter, VREGVDD must be shorted to DVDD external to the device. - PAVDD >= RFVDD - DVDD >= DECOUPLE - AVDD, IOVDD: No dependency with other supply pins. 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. IOVDD, AVDD, RFVDD and PAVDD 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<sub>DCDC</sub>) 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 298, 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.8 DC-to-DC Interface The EFR32xG22 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, delivering up to 60 mA of current. 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 Bypass Mode and VREGVDD Comparator In bypass mode, the VREGVDD input voltage is directly shorted 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 EFR32xG22 includes a supply comparator circuit to help software determine when the VREGVDD supply is high enough to enable DC-DC regulation 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 DVDDBOD | EMU RMURSTCAUSE DVDDLEBOD) If true, the part should remain in bypass mode with the DCDC disabled. #### 12.3.8.2 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 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.5 DRVSPEED, IPKVAL, and IPKMAXCTRL Recommended Settings on page 300. Table 12.5. DRVSPEED, IPKVAL, and IPKMAXCTRL Recommended Settings | Bit Field | Recommended Setting | |-----------------------|---------------------| | EM01CTRL0_IPKVAL | 9 (LOAD60MA) | | EM01CTRL0_DRVSPEED | 1 (DEFAULT_SETTING) | | EM23CTRL0_IPKVAL | 3 (LOAD5MA) | | EM23CTRL0_DRVSPEED | 3 (BEST_EFFICIENCY) | | DCDC_CTRL_IPKTMAXCTRL | 4 (TMAX_1P19US) | The DCDC\_CTRL\_DCMONLYEN field can be used to select between DCM and CCM mode. The default setting (1) is to use DCM mode, and should not be changed for most applications. #### 12.3.8.4 EM4 Entry The 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 EFP Communication EFR32xG22 has built-in hardware support for the EFP01 Energy Friendly PMICs. The EFP01's dual-DCDC converter outputs can, for example, provide power to both the 1.8V (e.g., DVDD/AVDD/IOVDD) supplies as well as the 1.1V (DECOUPLE) for improved efficiency. Consult EFP01 Datasheet for detailed information. EFR32xG22 communicates with EFP01 via I2C. EFP01 also has a unidirectional, open-drain IRQ# output to EFR32xG22 to indicate status flag changes. EFR32xG22'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 EFR32xG22's DECOUPLE supply. Once set, EFR32xG22's internal LDOs will be disabled, and the EMU will control EFP01 for voltage-scaling (if enabled). In addition, (if connected as described below) any interrupts received by EFP01's IRQ will set the EFPIF flag in the EMU\_EFPIF register. Note that because this bit disables in 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 EFR32xG22's DVDD supply (or DVDD along with other 1.8V supply inputs). This mode assumes that EFR32xG22's internal DCDC is not being used, so the VREGVDD and PAVDD pins should be shorted together on the PCB. In addition, (if connected as described above) any interrupts received by EFP01's IRQ will set the EFPIF flag in the EMU\_EFPIF register. EFR32xG22 provides a dedicated hardware IRQ vector for the EFP01's IRQ output. To use the EFR32xG22's hardware support for EFP01's IRQ output: - 1. The PC5 pin should be configured as an input 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. For EM4 operation, PC5 would need to be configured as a EM4Wakeup. - 2. EFP Hardware support must be enabled by setting either the EFPDRVDECOUPLE or the EFPDRVDVDD bits as described above. Once enabled, the EFP interupt flag in the EMU\_EFPIF register will be set whenever the EFP01 IRQ line goes low. A processor interupt can be generated by setting the EFPIEN bit in the EMU\_EFPIEN register. EFR32xG22 supports EFP01's optional Direct Mode interface to allow fast-energy mode transitions into and out of all energy modes (EM0/1, EM2/3, EM4). Ordinarilly, I2C transactions are used to toggle EFP01's energy mode state - however, a single I2C transaction can take over 100usec. In Direct Mode, the EFR32xG22 retasks the I2C pins as push-pull outputs with pull-ups disabled to control the EFP01's energy mode state directly, allowing much faster energy mode transistions. State definitions are defined in Table 12.6 Direct Mode Energy Mode States on page 301. Because the Direct Mode feature is non-I2C compliant, it should be enabled only during periods when no communication between EFR32xG22 and EFP01 is required. It is recommended for firmware to wait for the I2C STOP interrupt ensure no I2C transaction is in progress before switching to Direct Mode. | Direct Mode State | I2C SCL Level | I2C SDA Level | Allowed State Transitions | |----------------------------------|---------------|---------------|------------------------------------| | EM0 | 1 | 1 | • EM2 | | | | | • I <sup>2</sup> C Start Condition | | EM2 | 0 | 1 | • EM0 | | | | | • EM4 | | EM4 | 0 | 0 | • EM2 <sup>2</sup> | | I <sup>2</sup> C Start Condition | 1 | 0 | | Table 12.6. Direct Mode Energy Mode States - 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 EFPDIRECTMODEN bit in the EMU\_CTRL register. The EMU will automatically disable the I2C1 internal pull-ups when in Direct Mode - 5. EFP 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 EFR32xG22. Once triggered, a BOD will generate a system reset. Each BOD raw output is visible via the EMU\_ANASTATUS register and can also be routed to a GPIO via PRS for observability (see EMU PRS section for more details). In addition the xxxxMASKONCFGCHG status bits (also in the EMU\_ANASTATUS register) indicate when a particular BOD is being masked by HW following a configuration change (enable/disable or trim change). 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 BOD can be individually enabled and masked. EMU\_TESTCTRL\_BODMASK can be used to mask all BOD's at once. #### Table 12.7. EFR32xG22 BODs | BOD | Control Register | Supported Energy Modes | Function | |-----------|------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DVDDBOD | EMU_DVDDBOD | 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 | EMU_DVDDLEBOD | 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 | | DECBOD | EMU_DECBOD | EM0/1/2/3 | Monitors the DECOUPLE supply. DECBOD is automatically masked by hardware for ~20us after it is enabled to allow it to settle. | | DECOVMBOD | EMU_DECBOD | 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. | | AVDDBOD | 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. | | IOVDDBOD | 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 EFR32xG22. After reset, the M33 loads the stack pointer and program entry point from memory and start execution. Figure 12.5. Reset Tree There are two types of reset: - HARD resets. Resets the entire chip. After a hard reset, the EFR32xG22 goes through its power up sequence. The time to return to EM0 mode can be a few hundred usec. - 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). The time to return to EM0 mode is on the order of a few usec. #### EFR32xG22 Reset sources - · Power-on Reset (POR) - The POR ensures that EFR32xG22 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, EFR32xG22 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 EFR32xG22. - · 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) - EFR32xG22 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. - Debug Challenge Interface (DCI) Whether a reset source trigger event lead to a system reset can be controlled via EMU\_RMUCTRL register. EMU\_RMURSTCAUSE register User can determine the cause of the last reset by querying the EMU\_RMURSTCAUSE register. Once read, EMU\_RMURSTCAUSE should be cleared via EMU\_CMD\_RCCLR. **Table 12.8. Reset Sources Summary** | RSTCAU<br>SE Bit | Name | Туре | 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 | DVDDBOD | Hard | No | DVDD BOD | | 8 | DVDDLEBOD | Hard | No | DVDD LEBOD | | 9 | DECBOD | Hard | Yes | DECOUPLE BOD | | 10 | AVDDBOD | Soft | Yes | AVDD BOD | | 11 | VDDIO0BOD | Soft | Yes | IOVDD 0 BOD | | 16 | DCI | Soft | Yes | Debug Challenge Interface | #### 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 ½ 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 ½ 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<sub>Celsius</sub> = T<sub>Kelvin</sub> - 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. Polynomial coefficients for both cases are shown in Table 12.9 Polynomial Coefficients on page 305. Note that the polynomial coefficients provided assume the raw output (in Kelvin) has been converted to Celsius prior to linearization. Polynomial Order x³ Term x² Term x¹ Term xº Term Third Order -8.186E-7 -3.005E-5 1.015 -2.860 Second Order n/a -1.570E-4 1.017 -2.733 **Table 12.9. Polynomial Coefficients** Additional accuracy may be achieved by performing in-system calibration at known temperatures and operating conditions. ## 12.3.13 Register Resets Each EMU register requires retaining state in various energy modes and power transitions and will consequently need to be reset with a different condition. The following reset conditions will apply to the appropriate set of registers as marked in the Register Description table. - · Reset with POR or Hard Pin Reset - · Reset with POR, Hard Pin Reset, or any BOD reset - Reset with SYSEXTENDEDRESETn - Reset with FULLRESETn (default) If a register field is not marked with a specific reset condition then it is assumed to be reset with FULLRESETn. ## 12.3.14 Register Locks EMU EMU\_LOCK (for user accessible registers) can be used to control access to the EMU\_RMUCTRL, EMU\_CTRL, and EMU\_DECBOD 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 | Туре | Description | |--------|-------------------------|-------------|-------------------------------------------| | 0x010 | EMU_DECBOD | RW | DECOUPLE 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 | | 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 SYNC | EMU Temperature thresholds | | 0x084 | EMU_STATUS | RH | EMU Status register | | 0x088 | EMU_TEMP | RH SYNC | Temperature | | 0x090 | EMU_RSTCTRL | RW | Reset Management Control register | | 0x094 | EMU_RSTCAUSE | RH | 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 | DECOUPLE LVBOD Control register | | 0x1020 | EMU_BOD3SENSE_SET | RW | BOD3SENSE Control register | | 0x103C | EMU_VREGVDDCMPCTRL_SE T | RW | DC-DC VREGVDD Comparator Control Register | | 0x1040 | EMU_PD1PARETCTRL_SET | RW | PD1 Partial Retention Control | | 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 SYNC | EMU Temperature thresholds | | 0x1084 | EMU_STATUS_SET | RH | EMU Status register | | 0x1088 | EMU_TEMP_SET | RH SYNC | Temperature | | 0x1090 | EMU_RSTCTRL_SET | RW | Reset Management Control register | | 0x1094 | EMU_RSTCAUSE_SET | RH | Reset cause | | Offset | Name | Туре | Description | |--------|-------------------------|-------------|-------------------------------------------| | 0x10A0 | EMU_DGIF_SET | RWH INTFLAG | Interrupt Flags Debug | | 0x10A4 | EMU_DGIEN_SET | RW | Interrupt Enables Debug | | 0x1100 | EMU_EFPIF_SET | RWH INTFLAG | EFP Interrupt Register | | 0x1104 | EMU_EFPIEN_SET | RW | EFP Interrupt Enable Register | | 0x2010 | EMU_DECBOD_CLR | RW | DECOUPLE LVBOD Control register | | 0x2020 | EMU_BOD3SENSE_CLR | RW | BOD3SENSE Control register | | 0x203C | EMU_VREGVDDCMPCTRL_CL R | RW | DC-DC VREGVDD Comparator Control Register | | 0x2040 | EMU_PD1PARETCTRL_CLR | RW | PD1 Partial Retention Control | | 0x2060 | EMU_LOCK_CLR | W | EMU Configuration lock register | | 0x2064 | EMU_IF_CLR | RWH INTFLAG | Interrupt Flags | | 0x2068 | EMU_IEN_CLR | RW | Interrupt Enables | | 0x206C | EMU_EM4CTRL_CLR | RW | EM4 Control | | 0x2070 | EMU_CMD_CLR | W | EMU Command register | | 0x2074 | EMU_CTRL_CLR | RW | EMU Control register | | 0x2078 | EMU_TEMPLIMITS_CLR | RW SYNC | EMU Temperature thresholds | | 0x2084 | EMU_STATUS_CLR | RH | EMU Status register | | 0x2088 | EMU_TEMP_CLR | RH SYNC | Temperature | | 0x2090 | EMU_RSTCTRL_CLR | RW | Reset Management Control register | | 0x2094 | EMU_RSTCAUSE_CLR | RH | Reset cause | | 0x20A0 | EMU_DGIF_CLR | RWH INTFLAG | Interrupt Flags Debug | | 0x20A4 | EMU_DGIEN_CLR | RW | Interrupt Enables Debug | | 0x2100 | EMU_EFPIF_CLR | RWH INTFLAG | EFP Interrupt Register | | 0x2104 | EMU_EFPIEN_CLR | RW | EFP Interrupt Enable Register | | 0x3010 | EMU_DECBOD_TGL | RW | DECOUPLE LVBOD Control register | | 0x3020 | EMU_BOD3SENSE_TGL | RW | BOD3SENSE Control register | | 0x303C | EMU_VREGVDDCMPCTRL_TG L | RW | DC-DC VREGVDD Comparator Control Register | | 0x3040 | EMU_PD1PARETCTRL_TGL | RW | PD1 Partial Retention Control | | 0x3060 | EMU_LOCK_TGL | W | EMU Configuration lock register | | 0x3064 | EMU_IF_TGL | RWH INTFLAG | Interrupt Flags | | 0x3068 | EMU_IEN_TGL | RW | Interrupt Enables | | 0x306C | EMU_EM4CTRL_TGL | RW | EM4 Control | | 0x3070 | EMU_CMD_TGL | W | EMU Command register | | 0x3074 | EMU_CTRL_TGL | RW | EMU Control register | | 0x3078 | EMU_TEMPLIMITS_TGL | RW SYNC | EMU Temperature thresholds | | 0x3084 | EMU_STATUS_TGL | RH | EMU Status register | | 0x3088 | EMU_TEMP_TGL | RH SYNC | Temperature | | Offset | Name | Туре | Description | |--------|------------------|-------------|-----------------------------------| | 0x3090 | EMU_RSTCTRL_TGL | RW | Reset Management Control register | | 0x3094 | EMU_RSTCAUSE_TGL | RH | Reset cause | | 0x30A0 | EMU_DGIF_TGL | RWH INTFLAG | Interrupt Flags Debug | | 0x30A4 | EMU_DGIEN_TGL | RW | Interrupt Enables Debug | | 0x3100 | EMU_EFPIF_TGL | RWH INTFLAG | EFP Interrupt Register | | 0x3104 | EMU_EFPIEN_TGL | RW | EFP Interrupt Enable Register | # 12.5 EMU Register Description # 12.5.1 EMU\_DECBOD - DECOUPLE LVBOD Control register | Offset | Bit Position | | | | | |--------|------------------------------------------|------------|--|--|--| | 0x010 | 33 31 31 31 31 31 31 31 31 31 31 31 31 3 | 0 7 7 0 | | | | | Reset | 0×0<br>0×0 | 0x0 | | | | | Access | X XW | RW WW | | | | | Name | DECOVMBODMASK<br>DECOVMBODEN | DECBODMASK | | | | | Bit | Name | Reset | Access | Description | |------|---------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | DECOVMBODMASK | 0x1 | RW | Over Voltage Monitor Mask | | | DECOUPLE BOD Over | Voltage Monit | or Mask | | | 4 | DECOVMBODEN | 0x0 | RW | Over Voltage Monitor enable | | | DECOUPLE BOD Over | Voltage Monit | or enable. Enab | les LVBOD below vref high. BOD is masked for 20us after enable | | 3:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | DECBODMASK | 0x1 | RW | DECBOD Mask | | | DECOUPLE BOD Mask | | | | | 0 | DECBODEN | 0x0 | RW | DECBOD enable | | | DECOUPLE BOD enable | e. Enables LV | BOD above vre | f low. BOD is masked for 20us after enable | # 12.5.2 EMU\_BOD3SENSE - BOD3SENSE Control register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|-------------|-------------|-----------| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | | | ' | | ' | | | | ' | | ' | | ' | | | | • | | | ' | • | ' | | ' | ' | | | 0x0 | 0×0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | W<br>M | W. | SX<br>SX | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | VDDIO1BODEN | VDDIO0BODEN | AVDDBODEN | | Bit | Name | Reset | Access | Description | |------|-------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:3 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 2 | VDDIO1BODEN | 0x0 | RW | VDDIO1 BOD enable | | | BOD output is automatic | ally masked f | or 100us by HW | after enable is set | | 1 | VDDIO0BODEN | 0x0 | RW | VDDIO0 BOD enable | | | BOD output is automatic | ally masked f | or 100us by HW | after enable is set | | 0 | AVDDBODEN | 0x0 | RW | AVDD BOD enable | | | BOD output is automatic | ally masked f | or 100us by HW | after enable is set | # 12.5.3 EMU\_VREGVDDCMPCTRL - DC-DC VREGVDD Comparator Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|----------|-------------| | 0x03C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 5 | 3 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | IDOCUL | I INEGGE | VREGINCMPEN | | Bit | Name | Reset | Access | Description | |------|----------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:3 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 2:1 | THRESSEL | 0x3 | RW | VREGVDD comparator threshold programming | | | VREGVDD comparator t | hreshold prog | ramming: 2.0-> | 2.3V, 0.1V/step | | 0 | VREGINCMPEN | 0x0 | RW | VREGVDD comparator enable | | | VREGVDD comparator 6 | enable. Outpu | t is masked for | 5us after enabled. Automatically disabled in EM2. | # 12.5.4 EMU\_PD1PARETCTRL - PD1 Partial Retention Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|-----------|---|---|---|---|---|---|---| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | ' | | | | ' | | | | | | ' | | | | | | | | | | | 2 | e<br>X | | • | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | 2 | }<br>Ƴ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | F | <br>เกา | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | ć | TAKT<br>T | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 7 | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------|----------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------| | 31:16 | Reserved | To ensur<br>ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | PD1PARETDIS | 0x0 | RW | Disable PD1 Partial Retention | | | | 0]: Disables PD | | n EM2/EM3. Each bit controls a register group. MCU core group is MCU Peripherals group. Bit[1]: Disables PD1 retention for RADIO | | | Value | Mode | | Description | | | 0 | RETAIN | | Retain associated registers when in EM2/3 | | | 1 | NORETA | ΔIN | Do not retain associcated registers when in EM2/3 | # 12.5.5 EMU\_LOCK - EMU Configuration lock register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|---|---|----------------------------------------|-------|---|---|---|---|---|---|---| | 0x060 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | OXADE8 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | 3 | > | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | \ \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | LOCKA | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0xADE8 | W | Lock Key | | | Write any other value th | an the unlock | code to lock | | | | Value | Mode | | Description | | | 44520 | UNLOCK | | Unlock EMU register | | | | | | | # 12.5.6 EMU\_IF - Interrupt Flags | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----------|---------|------|----|---------|----|------------|------------|----|----|----|----|----|----|-----------|---------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | 0x0 | 000 | 000 | | 0×0 | | 000 | 0x0 | | • | • | | • | • | 0X0 | 0x0 | | • | • | | | | | • | • | | • | • | | | | | | Access | Z<br>M | Z. | Z. | | Z. | | W. | RW | | | | | | | Z. | W. | | | | | | | | | | | | | | | | | | Name | TEMPHIGH | TEMPLOW | TEMP | | TEMPAVG | | VSCALEDONE | EM23WAKEUP | | | | | | | IOVDD0BOD | AVDDBOD | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|---------------|-------------------|----------------------------------------------------------------------| | 31 | TEMPHIGH | 0x0 | RW | Temperature high Interrupt flag | | | Measured temperature a | bove threshol | d | | | 30 | TEMPLOW | 0x0 | RW | Temperature low Interrupt flag | | | Measured temperature b | elow threshol | d | | | 29 | TEMP | 0x0 | RW | Temperature Interrupt flag | | | Temperature Update | | | | | 28 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 27 | TEMPAVG | 0x0 | RW | Temperature Average Interrupt flag | | | Averaged Temperature l | Jpdate | | | | 26 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 25 | VSCALEDONE | 0x0 | RW | Vscale done Interrupt flag | | | Voltage scaling complete | ed. EM0 only. | | | | 24 | EM23WAKEUP | 0x0 | RW | EM23 Wake up Interrupt flag | | | EM23 wake up | | | | | 23:18 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 17 | IOVDD0BOD | 0x0 | RW | VDDIO0 BOD Interrupt flag | | | IOVDD0 BOD triggered | | | | | 16 | AVDDBOD | 0x0 | RW | AVDD BOD Interrupt flag | | | AVDD BOD triggered | | | | | 15:0 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | # 12.5.7 EMU\_IEN - Interrupt Enables | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----------|---------|------|----|---------|----|------------|------------|----|----|----|----|----|----|-----------|-------------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x068 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | 000 | 000 | | 000 | | 000 | 0x0 | | | | | • | • | 0X0 | 0x0 | | | | | | | | • | • | • | • | • | • | | | | | Access | ₩ | Z. | Z. | | Z. | | ₩<br>M | RW | | | | | | | ₩<br>M | R<br>M<br>M | | | | | | | | | | | | | | | | | | Name | TEMPHIGH | TEMPLOW | TEMP | | TEMPAVG | | VSCALEDONE | EM23WAKEUP | | | | | | | IOVDD0BOD | AVDDBOD | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-----------------|--------------------|----------------------------------------------------------------------| | 31 | TEMPHIGH | 0x0 | RW | Temperature high Interrupt enable | | | Measured temperature a | bove thresho | ld Interrupt enab | le | | 30 | TEMPLOW | 0x0 | RW | Temperature low Interrupt enable | | | Measured temperature b | elow threshol | d Interrupt enabl | le | | 29 | TEMP | 0x0 | RW | Temperature Interrupt enable | | | Temperature Update Inte | errupt enable | | | | 28 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 27 | TEMPAVG | 0x0 | RW | Temperature Interrupt enable | | | Averaged Temperature I | nterrupt enab | le | | | 26 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 25 | VSCALEDONE | 0x0 | RW | Vscale done Interrupt enable | | | Voltage scaling complete | ed Interrupt er | nable. EM0 only. | | | 24 | EM23WAKEUP | 0x0 | RW | EM23 Wake up Interrupt enable | | | EM23 wake up Interrupt | enable | | | | 23:18 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 17 | IOVDD0BOD | 0x0 | RW | VDDIO0 BOD Interrupt enable | | | IOVDD0 BOD Interrupt 6 | enable | | | | 16 | AVDDBOD | 0x0 | RW | AVDD BOD Interrupt enable | | | AVDD BOD Interrupt ena | able | | | | 15:0 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | # 12.5.8 EMU\_EM4CTRL - EM4 Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------------|---|---|--------------|---|---|---|----------| | 0x06C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 7 | - 0 | | Reset | | | • | • | | | • | | | | | • | • | | | • | • | • | | | | • | | 0X0 | | | 0XO | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>W | | | X<br>N | | | | R<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | BOD3SENSEEM4WU | | | EM4IORETMODE | | | | EM4ENTRY | | Bit | Name | Reset | Access | Description | |------|---------------------------------------------|---------------------|--------------------|----------------------------------------------------------------------------------------| | 31:9 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 8 | BOD3SENSEEM4WU | 0x0 | RW | Set BOD3SENSE as EM4 wakeup | | | Enable BOD3SENSE as | s EM4 wakeı | up source | | | 7:6 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | EM4IORETMODE | 0x0 | RW | EM4 IO retention mode | | | Determine when IO rete | ntion will be | applied and remo | ved | | | 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 | SWUNLA <sup>-</sup> | ТСН | Retention through EM4 and Wakeup: software writes UNLATCH register to remove retention | | 3:2 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | EM4ENTRY | 0x0 | RW | EM4 entry request | | | This field is used to ente<br>Energy Mode 4 | er the Energy | / Mode 4 sequenc | e. Writing the sequence 2,3,2,3,2,3,2,3,2 will enter the part into | # 12.5.9 EMU\_CMD - EMU Command register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|------|------|----|----|----|-------------|-------------|---|---|---|---|---|------------|---|---|------------|---| | 0x070 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | • | • | • | • | • | • | | | | | | | | 0×0 | | • | | | | 0x0 | 0x0 | | | | • | • | 0x0 | | • | 0x0 | | | Access | | | | | | | | | | | | | | | ≥ | | | | | | > | > | | | | | | > | | | W | | | Name | | | | | | | | | | | | | | | RSTCAUSECLR | | | | | | EM01VSCALE2 | EM01VSCALE1 | | | | | | TEMPAVGREQ | | | EM4UNLATCH | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|--------------|--------------------|----------------------------------------------------------------------| | 31:18 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 17 | RSTCAUSECLR | 0x0 | W | Reset Cause Clear | | | Set this bit to clear the R | MURSTCAUS | SE register | | | 16:12 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 11 | EM01VSCALE2 | 0x0 | W | Scale voltage to Vscale2 | | | EM01 Voltage Scale Cor | nmand to sca | le to Voltage Sc | ale Level 2 | | 10 | EM01VSCALE1 | 0x0 | W | Scale voltage to Vscale1 | | | EM01 Voltage Scale Cor | nmand to sca | le to Voltage Sc | ale Level 1 | | 9:5 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | TEMPAVGREQ | 0x0 | W | Temperature Average Request | | | Request for Averaged Te | emperature M | easurement | | | 3:2 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 1 | EM4UNLATCH | 0x0 | W | EM4 unlatch | | | GPIO unlatch request af | ter EM4 wake | up. Only valid w | hen EM4IORETMODE== SWUNLATCH | | 0 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | # 12.5.10 EMU\_CTRL - EMU Control register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|------------|----------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|-------|----|----|----|----|----|---|----------|---|---|---|---|------------|---|---|----------| | 0x074 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | 3 | 7 | _ | 0 | | Reset | 0x0 | 000 | 000 | | ' | ' | | | • | | | | | • | ' | 0x0 | | | • | | | | ç | Z | ' | | | | 0x0 | | | 0x0 | | Access | R | ₩<br>W | ₩<br>M | | | | | | | | | | | | | RW | | | | | | | Š | <u>}</u> | | | | | RW | | | ₩<br>N | | Name | EFPDRVDVDD | EFPDRVDECOUPLE | EFPDIRECTMODEEN | | | | | | | | | | | | | FLASHPWRUPONDEMAND | | | | | | | ( | ۲<br>ک | | | | | TEMPAVGNUM | | | EM2DBGEN | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31 | EFPDRVDVDD | 0x0 | RW | EFP drives DVDD | | | EFP Drives DVDD | | | | | 30 | EFPDRVDECOUPLE | 0x0 | RW | EFP drives DECOUPLE | | | EFP Drives DECOUPLE | E. EMU volta | age scaling is do | one through EFP | | 29 | EFPDIRECTMODEEN | 0x0 | RW | EFP Direct Mode Enable | | | EFP Direct mode enable | e. EMU drive | es I2C SDA/SCI | L lines to transition EFP between energy modes | | 28:17 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 16 | FLASHPWRUPONDE-<br>MAND | 0x0 | RW | Enable flash on demand wakeup | | | When set, during wake issue powerup comman | | | own mode until either incoming Flash data fetch or when software gister | | 15:10 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | EM23VSCALE | 0x2 | RW | EM2/EM3 Vscale | | | Set VSCALE value for E | EM2/EM3 mo | ode | | | | Value | Mode | | Description | | | 0 | VSCALE | ) | VSCALE0. 0.9v | | | 1 | VSCALE? | 1 | VSCALE1. 1.0v | | | 2 | VSCALE | 2 | VSCALE2. 1.1v | | 7:4 | Reserved | To ensure | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 3 | TEMPAVGNUM | 0x0 | RW | Averaged Temperature samples num | | | Number of samples take | en for Avera | ged Temperatu | re Measurement | | | Value | Mode | | Description | | | | | | | | Bit | Name | Reset | Access | Description | |-----|--------------------|-------------------|-----------------|---------------------------------------------------------------------------| | | 0 | N16 | | 16 measurements | | | 1 | N64 | | 64 measurements | | 2:1 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EM2DBGEN | 0x0 | RW | Enable debugging in EM2 | | | Force PD0B to stay | on on EM2 entr | y. This allows | debugger to remain connected in EM2. | # 12.5.11 EMU\_TEMPLIMITS - EMU Temperature thresholds | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|----------|-----|---|---|---| | 0x078 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | t m | 2 | _ | 0 | | Reset | | | • | | • | • | | | | | | 0x1FF | • | | • | | | • | | • | • | | | | | • | | OXO | 2 | | | | | Access | | | | | | | | | | | | Ŋ. | | | | | | | | | | | | | | | | 8 | 2 | | | | | Name | | | | | | | | | | | | TEMPHIGH | | | | | | | | | | | | | | | | TEMPI OW | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------------------------|--------------------|---------------|---------------------------------------------------------------------------| | 31:25 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 24:16 | TEMPHIGH | 0x1FF | RW | Temp High limit | | | Temp threshold in d equal to or higher th | | e TEMPHIGH | I interrupt flag is set when a periodic temperature measurement is | | 15:9 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | TEMPLOW | 0x0 | RW | Temp Low limit | | | Temp threshold in d to or lower than this | | e TEMPLOW | interrupt flag is set when a periodic temperature measurement is equal | # 12.5.12 EMU\_STATUS - EMU Status register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------------|----|----------|---|-----------|---|---|---|----------|--------------|------------|---------------|------------|---------------|------| | 0x084 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | . 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | | | • | | | | • | • | | | • | | 000 | | 0X0 | | 0×0 | | | | 0x2 | 000 | 0x0 | 0x0 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | œ | | 2 | | 22 | | | | <u>~</u> | œ | <u>~</u> | 22 | 22 | œ | 2 | | Name | | | | | | | | | | | | | | | | | | EM2ENTERED | | EM4IORET | | RACACTIVE | | | | VSCALE | VSCALEFAILED | VSCALEBUSY | TEMPAVGACTIVE | TEMPACTIVE | FIRSTTEMPDONE | LOCK | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------------|--------------------|--------------------|-------------------------------------------------------------------------| | 31:15 | Reserved | To ensure ventions | e compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 14 | EM2ENTERED | 0x0 | R | EM2 entered | | | Confirm chip entered E | M2 state. EN | 12 Entry request | can be delayed or denied by peripherals. | | 13 | Reserved | To ensure ventions | e compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 12 | EM4IORET | 0x0 | R | EM4 IO retention status | | | The status of IO retentiting EM4UNLATCH in | | et upon EM4 entr | y based on EM4IORETMODE in EMU_EM4CTRL. Cleared by set- | | 11 | Reserved | To ensure ventions | e compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 10 | RACACTIVE | 0x0 | R | RAC active | | | This bit indicates the st | atus of the R | AC state machine | e. System can not enter EM2 or lower if set. | | 9:8 | Reserved | To ensure ventions | e compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 7:6 | VSCALE | 0x2 | R | Vscale status | | | Current Voltage Scale | Value | | | | | Value | Mode | | Description | | | 0 | VSCALE | ) | Voltage scaling set to 0.9v | | | 1 | VSCALE1 | | Voltage scaling set to 1.0v | | | 2 | VSCALE2 | 2 | Voltage scaling set to 1.1v | | 5 | VSCALEFAILED | 0x0 | R | Vscale failed | | | Voltage scaling failed. | (Time out) | | | | 4 | VSCALEBUSY | 0x0 | R | Vscale busy | | | Voltage Scaling busy | | | | | 3 | TEMPAVGACTIVE | 0x0 | R | Temp Average active | | | Average Temperature | Measuremen | t active | | | 2 | TEMPACTIVE | 0x0 | R | Temp active | | | | | | | | Bit | Name | Reset | Access | Description | |-----|--------------------------|---------------|--------|------------------------------------------| | | Temperature Measure | ment active | | | | 1 | FIRSTTEMPDONE | 0x0 | R | First Temp done | | | First Temperatue mesa | aurement com | pleted | | | 0 | LOCK | 0x0 | R | Lock status | | | Indicates the current st | atus of EMU I | _ock | | | | Value | Mode | | Description | | | 0 | UNLOCKE | ΞD | All EMU lockable registers are unlocked. | | | 1 | LOCKED | | All EMU lockable registers are locked. | # 12.5.13 EMU\_TEMP - Temperature | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|---------|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|------|-----|---|---|---|---------|-----| | 0x088 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | 000 | | | | | | | | | | | | | | | | • | | • | • | | | • | • | 0X0 | | | | | 0x0 | | Access | | α | | | | | | | | | | | | | | | | | | | | | | | 22 | | | | | 22 | | | Name | | TEMPAVG | | | | | | | | | | | | | | | | | | | | | | | TEMP | | | | | TEMPLSB | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:27 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 26:16 | TEMPAVG | 0x0 | R | Averaged Temperature | | | Averaged Temperature I | Measurement | . Temperature in | n Kelvin. 9 integer bits and 2 decimal bits (0.25 Degree resolution) | | 15:11 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 10:2 | TEMP | 0x0 | R | Temperature measured | | | Temperature in Kelvin. V | alue of last p | eriodic tempera | ture measurement. Value is asynchronously updated. | | 1:0 | TEMPLSB | 0x0 | R | Temperature measured decimal part | | | Temperature decimal pa | rt | | | # 12.5.14 EMU\_RSTCTRL - Reset Management Control register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|------|----|----|----|---|-------------|---|---|----------------|--------------|---|---|-------------|----------|---|------------| | 0x090 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | • | • | | | | | | | | 0 <u>X</u> 1 | | | • | • | • | 0X | | • | 0X0 | 000 | | • | 0X0 | 0X1 | | 0×1 | | Access | | | | | | | | | | | | | | | | Z. | | | | | | ₩ | | | ₩ | Z. | | | Z<br>M | RW | | RW<br>W | | Name | | | | | | | | | | | | | | | | DCIRMODE | | | | | | DECBODRMODE | | | IOVDD0B0DRM0DE | AVDDBODRMODE | | | LOCKUPRMODE | SYSRMODE | | WDOGORMODE | | Bit | Name | Reset | Access | Description | |-------|------------------------|-----------------------|--------------------|------------------------------------------------------------------------| | 31:17 | Reserved | To ensure<br>ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 16 | DCIRMODE | 0x1 | RW | DCI System reset | | | DCI sysreset Reset Mod | de | | | | | Value | Mode | | Description | | | 0 | DISABLED | ) | Reset request blocked | | | 1 | ENABLED | | The entire device is reset except some EMU registers | | 15:11 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 10 | DECBODRMODE | 0x1 | RW | Enable DECBOD reset | | | LVBOD Reset Mode. D | ECOUPLE m | onitoring. BOD m | nust be trimmed before it is used as a reset source. | | | Value | Mode | | Description | | | 0 | DISABLED | ) | Reset request is blocked | | | 1 | ENABLED | | The entire device is reset | | 9:8 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7 | IOVDD0B0DRM0DE | 0x0 | RW | Enable VDDIO0 BOD reset | | | LEBOD2 Reset Mode. I | OVDD0 moni | toring. BOD mus | t be trimmed before it is used as a reset source. | | | Value | Mode | | Description | | | 0 | DISABLED | ) | Reset request is blocked | | | 1 | ENABLED | | The entire device is reset except some EMU registers | | 6 | AVDDBODRMODE | 0x0 | RW | Enable AVDD BOD reset | | | LEBOD1 Reset Mode. | AVDD monito | ring. BOD must b | be trimmed before it is used as a reset source. | | | Value | Mode | | Description | | | 0 | DISABLED | ) | Reset Request is block | | | | | ) | <u> </u> | | Bit | Name | Reset | Access | Description | |-----|-----------------------|-------------|--------------------|----------------------------------------------------------------------| | | 1 | ENABLED | | The entire device is reset except some EMU registers | | 5:4 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 3 | LOCKUPRMODE | 0x0 | RW | Enable M33 Lockup reset | | | Core LOCKUP Reset M | lode | | | | | Value | Mode | | Description | | | 0 | DISABLED | | Reset Request is Block | | | 1 | ENABLED | | The entire device is reset except some EMU registers | | 2 | SYSRMODE | 0x1 | RW | Enable M33 System reset | | | Core Sysreset Reset M | ode | | | | | Value | Mode | | Description | | | 0 | DISABLED | | Reset request is blocked | | | 1 | ENABLED | | Device is reset except some EMU registers | | 1 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 0 | WDOG0RMODE | 0x1 | RW | Enable WDOG0 reset | | | 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.15 EMU\_RSTCAUSE - Reset cause | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|-----------|---------|----------|-----------|---------|--------|--------|---|-------|----------|-----|-----| | 0x094 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | 000 | | | • | ' | | | | | | ' | | ' | ' | | 000 | | | | | 0x0 | 000 | 000 | 000 | 0X0 | 000 | 0×0 | | 000 | 0x0 | 000 | 0x0 | | Access | 2 | | | | | | | | | | | | | | | 22 | | | | | 22 | œ | <u>~</u> | œ | 2 | 22 | 22 | | 22 | <u>~</u> | 22 | ~ | | Name | VREGIN | | | | | | | | | | | | | | | DCI | | | | | IOVDD0BOD | AVDDBOD | DECBOD | DVDDLEBOD | DVDDBOD | SYSREQ | LOCKUP | | WDOG0 | EM4 | NIG | POR | | Sit Name Reset Access Description | | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------------------|----------------|-------------------|-------------------------------------------------------------------------| | DCDC VREGIN comparator below threshold. For Information only, not a direct source for reset. Should be used to de mine whether the previous reset was caused by DCDC input being too low to support current load. In this case it is at vised to keep the chip in BYPASS mode and check battery level before re-enabling integrated DCDC 30:17 Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 of ventions 16 DCI 0x0 R DCI reset Debug Challenge Interface 15:12 Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 of ventions 11 IOVDD0BOD 0x0 R LEBOD2 Reset Brown Out Detector monitoring IOVDD0 10 AVDDBOD 0x0 R LEBOD1 Reset Brown Out Detector monitoring AVDD 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | Bit | Name | Reset | Access | Description | | mine whether the previous reset was caused by DCDC input being too low to support current load. In this case it is ac vised to keep the chip in BYPASS mode and check battery level before re-enabling integrated DCDC 30:17 Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 of ventions 16 DCI 0x0 R DCI reset Debug Challenge Interface 15:12 Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 of ventions 11 IOVDD0BOD 0x0 R LEBOD2 Reset Brown Out Detector monitoring IOVDD0 10 AVDDBOD 0x0 R LEBOD1 Reset Brown Out Detector monitoring AVDD 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 31 | VREGIN | 0x0 | R | DCDC VREGIN comparator | | Section | | mine whether the previ | ous reset was | caused by DCD | OC input being too low to support current load. In this case it is ad- | | Debug Challenge Interface 15:12 Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Coventions | 30:17 | Reserved | | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 15:12 Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Contents 11 IOVDD0BOD 0x0 R LEBOD2 Reset Brown Out Detector monitoring IOVDD0 10 AVDDBOD 0x0 R LEBOD1 Reset Brown Out Detector monitoring AVDD 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 16 | DCI | 0x0 | R | DCI reset | | 11 IOVDD0BOD 0x0 R LEBOD2 Reset Brown Out Detector monitoring IOVDD0 10 AVDDBOD 0x0 R LEBOD1 Reset Brown Out Detector monitoring AVDD 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | | Debug Challenge Interf | ace | | | | Brown Out Detector monitoring IOVDD0 10 AVDDBOD 0x0 R LEBOD1 Reset Brown Out Detector monitoring AVDD 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 15:12 | Reserved | | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 10 AVDDBOD 0x0 R LEBOD1 Reset Brown Out Detector monitoring AVDD 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 11 | IOVDD0BOD | 0x0 | R | LEBOD2 Reset | | Brown Out Detector monitoring AVDD 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | | Brown Out Detector mo | onitoring IOVD | D0 | | | 9 DECBOD 0x0 R LVBOD Reset Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 10 | AVDDBOD | 0x0 | R | LEBOD1 Reset | | Brown Out Detector monitoring DECOUPLE 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | | Brown Out Detector mo | onitoring AVDI | ) | | | 8 DVDDLEBOD 0x0 R LEBOD Reset Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 9 | DECBOD | 0x0 | R | LVBOD Reset | | Brown Out Detector monitoring DVDD in EM2/3 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | | Brown Out Detector mo | onitoring DEC | OUPLE | | | 7 DVDDBOD 0x0 R HVBOD Reset Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 8 | DVDDLEBOD | 0x0 | R | LEBOD Reset | | Brown Out Detector monitoring DVDD in EM0/1 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | | Brown Out Detector mo | onitoring DVDI | O in EM2/3 | | | 6 SYSREQ 0x0 R M33 Core Sys Reset Last Reset was as M33 Core System reset | 7 | DVDDBOD | 0x0 | R | HVBOD Reset | | Last Reset was as M33 Core System reset | | Brown Out Detector mo | onitoring DVDI | O in EM0/1 | | | | 6 | SYSREQ | 0x0 | R | M33 Core Sys Reset | | 5 LOCKUP 0x0 R M33 Core Lockup Reset | | Last Reset was as M33 | Core System | reset | | | | 5 | LOCKUP | 0x0 | R | M33 Core Lockup Reset | | Last Reset was as M33 Core Lockup reset | | Last Reset was as M33 | Core Lockup | reset | | | 4 Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Content ventions | 4 | Reserved | | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3 WDOG0 0x0 R Watchdog 0 Reset | 3 | WDOG0 | 0x0 | R | Watchdog 0 Reset | | Last reset was a Watchdog 0 reset | | Last reset was a Watch | ndog 0 reset | | | | 2 EM4 0x0 R EM4 Wakeup Reset | 2 | EM4 | 0x0 | R | EM4 Wakeup Reset | | Last reset was a EM4 Wakeup | | Last reset was a EM4 \ | Vakeup | | | | Bit | Name | Reset | Access | Description | |-----|--------------------|----------------|--------|----------------| | 1 | PIN | 0x0 | R | Pin Reset | | | Last reset was a F | Pin reset | | | | 0 | POR | 0x0 | R | Power On Reset | | | Last reset was a F | Power On Reset | | | # 12.5.16 EMU\_DGIF - Interrupt Flags Debug | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|--------------|-------------|----------|----|----|----|----|----------------|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----|---|---|---|---|---|---|-----|--------| | 0x0A0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 80 | 7 | 9 | 2 | 4 | 3 | 2 | - c | _<br>> | | Reset | 0x0 | 0x0 | 0x0 | | • | • | • | 0x0 | | | • | | • | ' | • | • | • | • | • | | • | | • | ' | • | • | | | | | | | | Access | R<br>W | ₩<br>M | W<br>M | | | | | ZW<br>W | | | | | | | | | | | | | | | | | | | | | | | | | | Name | TEMPHIGHDGIF | TEMPLOWDGIF | TEMPDGIF | | | | | EM23WAKEUPDGIF | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|---------------|--------------------|----------------------------------------------------------------------| | 31 | TEMPHIGHDGIF | 0x0 | RW | Temperature high Interrupt flag | | | Measured temperature a | bove threshol | ld | | | 30 | TEMPLOWDGIF | 0x0 | RW | Temperature low Interrupt flag | | | Measured temperature b | elow threshol | d | | | 29 | TEMPDGIF | 0x0 | RW | Temperature Interrupt flag | | | Temperature Update | | | | | 28:25 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 24 | EM23WAKEUPDGIF | 0x0 | RW | EM23 Wake up Interrupt flag | | | EM23 wake up | | | | | 23:0 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | # 12.5.17 EMU\_DGIEN - Interrupt Enables Debug | Offset | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|---------------|--------------|-----------|----|----|----|----|-----------------|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|----|---|---|---|---|---|---|---|---| | 0x0A4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | 000 | 000 | 0×0 | | • | 1 | ' | 0x0 | | | | | ' | | ' | ' | | ' | | ' | | ' | | ' | | ' | | | | | | | | Access | R<br>W | ₩<br>M | W<br>M | | | | | RW | | | | | | | | | | | | | | | | | | | | | | | | | | Name | TEMPHIGHDGIEN | TEMPLOWDGIEN | TEMPDGIEN | | | | | EM23WAKEUPDGIEN | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|------------------------|---------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31 | TEMPHIGHDGIEN | 0x0 | RW | Temperature high Interrupt enable | | | | | | | | | | | Measured temperature a | bove thresho | ld | | | | | | | | | | | 30 | TEMPLOWDGIEN | 0x0 | RW | Temperature low Interrupt enable | | | | | | | | | | | Measured temperature b | elow threshol | ld | | | | | | | | | | | 29 | TEMPDGIEN | 0x0 | RW | Temperature Interrupt enable | | | | | | | | | | | Temperature Update | | | | | | | | | | | | | 28:25 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 24 | EM23WAKEUPDGIEN | 0x0 | RW | EM23 Wake up Interrupt enable | | | | | | | | | | | EM23 wake up | | | | | | | | | | | | | 23:0 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | # 12.5.18 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 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | • | | | | | | | | • | | | • | | • | | | | | | | | | | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | EFPIF | | Bit | Name | Reset | Access | Description | | | | | | | |------|---------------|--------------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--|--| | 31:1 | Reserved | To ensure ventions | e compatibility v | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 0 | EFPIF | 0x0 | RW | EFP Interrupt Flag | | | | | | | | | EFP Interrupt | | | | | | | | | | | | | | | | | | | | | | # 12.5.19 EMU\_EFPIEN - EFP Interrupt Enable Register | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----|---|---|---|---|---|---|---|---|---|--------| | 0x104 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | • | | | | | | | | • | | | • | | | | | | | | | • | • | | • | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | S. | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | EFPIEN | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:1 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EFPIEN | 0x0 | RW | EFP Interrupt enable | | | Enable EFP Interrupt | | | | # 12.6 DCDC Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|---------------------|-------------|----------------------| | 0x000 | DCDC_IPVERSION | R | IPVERSION | | 0x004 | DCDC_EN | RW ENABLE | Enable | | 0x008 | DCDC_CTRL | RW SYNC | Control | | 0x010 | DCDC_EM01CTRL0 | RW SYNC | EM01 Control | | 0x014 | DCDC_EM23CTRL0 | RW SYNC | EM23 Control | | 0x024 | DCDC_IF | RWH INTFLAG | Interrupt Flags | | 0x028 | DCDC_IEN | RW | Interrupt Enable | | 0x02C | DCDC_STATUS | RH | Status Register | | 0x040 | DCDC_LOCK | W | Lock Register | | 0x044 | DCDC_LOCKSTATUS | RH | Lock Status Register | | 0x1000 | DCDC_IPVERSION_SET | R | IPVERSION | | 0x1004 | DCDC_EN_SET | RW ENABLE | Enable | | 0x1008 | DCDC_CTRL_SET | RW SYNC | Control | | 0x1010 | DCDC_EM01CTRL0_SET | RW SYNC | EM01 Control | | 0x1014 | DCDC_EM23CTRL0_SET | RW SYNC | EM23 Control | | 0x1024 | DCDC_IF_SET | RWH INTFLAG | Interrupt Flags | | 0x1028 | DCDC_IEN_SET | RW | Interrupt Enable | | 0x102C | DCDC_STATUS_SET | RH | 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_EN_CLR | RW ENABLE | Enable | | 0x2008 | DCDC_CTRL_CLR | RW SYNC | Control | | 0x2010 | DCDC_EM01CTRL0_CLR | RW SYNC | EM01 Control | | 0x2014 | DCDC_EM23CTRL0_CLR | RW SYNC | EM23 Control | | 0x2024 | DCDC_IF_CLR | RWH INTFLAG | Interrupt Flags | | 0x2028 | DCDC_IEN_CLR | RW | Interrupt Enable | | 0x202C | DCDC_STATUS_CLR | RH | 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_EN_TGL | RW ENABLE | Enable | | 0x3008 | DCDC_CTRL_TGL | RW SYNC | Control | | 0x3010 | DCDC_EM01CTRL0_TGL | RW SYNC | EM01 Control | | 0x3014 | DCDC_EM23CTRL0_TGL | RW SYNC | EM23 Control | | Offset | Name | Туре | Description | |--------|---------------------|-------------|----------------------| | 0x3024 | DCDC_IF_TGL | RWH INTFLAG | Interrupt Flags | | 0x3028 | DCDC_IEN_TGL | RW | Interrupt Enable | | 0x302C | DCDC_STATUS_TGL | RH | 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<br>30<br>30<br>29<br>29<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27<br>27 | | | | | | | | | | | | | | | Reset | 0<br>X | | | | | | | | | | | | | | | Access | α- | | | | | | | | | | | | | | | Name | IPVERSION | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--|--|--| | 31:0 | IPVERSION | 0x0 | 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. | | | | | | | | | | | | ## 12.7.2 DCDC\_EN - Enable | Offset | Bit Position | Bit Position | | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x004 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>13 3 3 4 6 6 7 8 8 8 7 9 9 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</th> | 13 3 3 4 6 6 7 8 8 8 7 9 9 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | | | | | Reset | | 0X0 | | | | | | | | | | | | | Access | | NX N | | | | | | | | | | | | | Name | | Z | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | |------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------|-------------|--|--|--|--|--|--| | 31:1 | Reserved | To ensure o | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 0 | EN | 0x0 | Enable | | | | | | | | | | The ENABLE bit enables the module. Software should write to CONFIG type registers before setting Software should write to SYNC type registers only after setting the ENABLE bit. | | | | | | | | | | | Value | Mode | Description | |-------|---------|-------------| | 0 | DISABLE | Disable | | 1 | ENABLE | Enable | # 12.7.3 DCDC\_CTRL - Control | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|---|----|----|----------|----|---|---|---|---|-------------|---|---|-----------|---|---------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | | | ' | | | | | | | • | | <u>'</u> | | | ' | | <u>'</u> | | | ' | | | 0x4 | | | 0X1 | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | R<br>M | | | ₩<br>M | | RW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | IPKTMAXCTRL | | | DCMONLYEN | | MODE | | Bit | Name | Reset | Access | Description | | | | | | | | |------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:7 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Cor | | | | | | | | | 6:4 | IPKTMAXCTRL | 0x4 | RW | Peak Current Timeout Control | | | | | | | | | | | | | nit programmed peak current. Ton_max = (ipk_tmax_ctrl*4 + e timeout was hit before reaching peak current. | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 0 | OFF | | Ton_max disabled | | | | | | | | | | 1 | TMAX_0F | P35US | 0.35us | | | | | | | | | | 2 | TMAX_0F | P63US | 0.63us | | | | | | | | | | 3 | TMAX_0F | P91US | 0.91us | | | | | | | | | | 4 | TMAX_1F | P19US | 1.19us | | | | | | | | | | 5 | TMAX_1F | P47US | 1.47us | | | | | | | | | | 6 | TMAX_1F | P75US | 1.75us | | | | | | | | | | 7 | TMAX_2F | P03US | 2.03us | | | | | | | | | 3 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Co. | | | | | | | | | 2 | DCMONLYEN | 0x1 | RW | DCDC DCM Only Enable | | | | | | | | | | DCDC DCM Only Er | nable | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 0 | DUALMO | DE | Support higher load current at lower battery voltage by working in CCM mode | | | | | | | | | | 1 | DCMONL | YEN | DCM only mode for normal operation, this is the default setting | | | | | | | | | 1 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Cor | | | | | | | | | ) | MODE | 0x0 | RW | DCDC/Bypass Mode Control | | | | | | | | | | Used to switch between bypass and dcdc regulation, this triggers a sequence of controls. IF/STATUS registers can be used to check the true status of DCDC regulator/bypass switch | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | Bit | Name | Reset Access | Description | |-----|------|----------------|-------------------------------------------------| | | 0 | BYPASS | DCDC is OFF, bypass switch is enabled | | | 1 | DCDCREGULATION | Request DCDC regulation, bypass switch disabled | # 12.7.4 DCDC\_EM01CTRL0 - EM01 Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|---|---|----------|---|---|---|---|---|----------|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | • | | | | | | | 3 | Š | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | Š | ≥<br>Y | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | L | DRVSPEED | | | | | | IDKVAI | 7 | | | Bit | Name | Reset | Access | Description | |-------|----------------------|---------------------|--------------------|----------------------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | e compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | DRVSPEED | 0x1 | RW | EM01 Drive Speed Setting | | | Used to configure of | drive speed for tra | adeoff between E | EMI and Efficiency | | | Value | Mode | | Description | | | 0 | BEST_EN | ЛΙ | Lowest Efficiency, Lowest EMI Small decrease in efficiency from default setting | | | 1 | DEFAULT | Γ_SETTING | Default Efficiency, Acceptable EMI level | | | 2 | INTERME | DIATE | Small increase in efficiency from the default setting | | | 3 | BEST_EF | FFICIENCY | Highest Efficiency, Highest EMI Small increase in efficiency from INTERMEDIATE setting | | 7:4 | Reserved | To ensure ventions | e compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | IPKVAL | 0x9 | RW | EM01 Peak Current Setting | | | Used to configure f | or required peak/ | load current in E | M0 and EM1 | | | Value | Mode | | Description | | | 3 | LOAD36N | ЛΑ | Ipeak = 90mA, IL = 36mA | | | 4 | LOAD40N | ЛΑ | Ipeak = 100mA, IL = 40mA | | | 5 | LOAD44N | ЛΑ | Ipeak = 110mA, IL = 44mA | | | 6 | LOAD48N | ЛΑ | Ipeak = 120mA, IL = 48mA | | | 7 | LOAD52N | ИΑ | Ipeak = 130mA, IL = 52mA | | | 8 | LOAD56N | ИΑ | Ipeak = 140mA, IL = 56mA | | | | | | | # 12.7.5 DCDC\_EM23CTRL0 - EM23 Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|---|--------|---|---| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | | | | | | | | | | | | | | | | | | | 3 | Š | | • | | | | 0x3 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | X<br>N | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | URVSPEEU | | | | | | IPKVAI | j | | | Bit | Name | Reset | Access | Description | |-------|---------------------|---------------------|-----------------|----------------------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | DRVSPEED | 0x1 | RW | EM23 Drive Speed Setting | | | Used to configure | drive speed for tra | deoff between | EMI and Efficiency | | | Value | Mode | | Description | | | 0 | BEST_EM | 11 | Lowest Efficiency, Lowest EMI Small decrease in efficiency from default setting | | | 1 | DEFAULT | _SETTING | Default Efficiency, Acceptable EMI level | | | 2 | INTERME | DIATE | Small increase in efficiency from the default setting | | | 3 | BEST_EF | FICIENCY | Highest Efficiency, Highest EMI Small increase in efficiency from INTERMEDIATE setting | | 7:4 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | IPKVAL | 0x3 | RW | EM23 Peak Current Setting | | | Used to configure t | or required peak/ | load current in | EM2 and EM3 | | | Value | Mode | | Description | | | 3 | LOAD5MA | 4 | Ipeak = 90mA, IL = 5 mA | | | 9 | LOAD10N | 1A | Ipeak = 150mA, IL = 10 mA | | | | | | | ## 12.7.6 DCDC\_IF - Interrupt Flags | Offset | Bit Position | | | | | | | | | |--------|----------------------------------------------------------------------------|--------|------|------------|------------|-----------|---------|------|-------| | 0x024 | 33 31 32 32 32 33 33 34 34 35 35 35 36 36 36 36 36 36 36 36 36 36 36 36 36 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 000 | 000 | 0x0 | 000 | 0x0 | 0x0 | 0x0 | 0x0 | | Access | | Ş. | Z. | %<br>≷ | %<br>⊗ | ₹ | RW | ₽ | W. | | Name | | EM4ERR | TMAX | REGULATION | VREGINHIGH | VREGINLOW | RUNNING | WARM | BYPSW | | Bit | Name | Reset | Access | Description | |------|---------------------------------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7 | EM4ERR | 0x0 | RW | EM4 Entry Request Error | | | EM4 entry error - softwa | re requesting | EM4 entry wher | n bypass switch is disabled | | 6 | TMAX | 0x0 | RW | Ton_max Timeout Reached | | | Ton_max timeout was re | ached before | peak current co | ould be achieved | | 5 | REGULATION | 0x0 | RW | DCDC in regulation | | | DC-DC in regulation, out | put voltage is | in range of targ | et voltage | | 4 | VREGINHIGH | 0x0 | RW | VREGVDD above threshold | | | VREGVDD above thresh | old | | | | 3 | VREGINLOW | 0x0 | RW | VREGVDD below threshold | | | VREGVDD below thresh | old | | | | 2 | RUNNING | 0x0 | RW | DCDC Running | | | Bypass switch has turne not be in range of target | | DC is active. No | te that DC-DC might not be in regulation yet. ie output voltage may | | 1 | WARM | 0x0 | RW | DCDC Warmup Time Done | | | 100us DCDC warmup tir | ne complete | | | | 0 | BYPSW | 0x0 | RW | Bypass Switch Enabled | | | Bypass Switch Enabled | | | | | | | | | | ## 12.7.7 DCDC\_IEN - Interrupt Enable | Offset | Bit Position | | | | | | | | | |--------|----------------------------------------------------------------------------|--------|--------|------------|------------|-----------|---------|------|-------| | 0x028 | 33 31 32 32 32 33 33 34 34 35 35 35 36 36 36 36 36 36 36 36 36 36 36 36 36 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 000 | 000 | 000 | 0x0 | 000 | 0x0 | 0x0 | 0x0 | | Access | | ₩<br>M | %<br>≷ | ¥<br>M | RW | ₹ | RW | ₽ | W. | | Name | | EM4ERR | TMAX | REGULATION | VREGINHIGH | VREGINLOW | RUNNING | WARM | BYPSW | | Bit | Name | Reset | Access | Description | |------|-------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7 | EM4ERR | 0x0 | RW | EM4 Entry Req Interrupt Enable | | | EM4 Entry Request Erro | r Interrupt En | able | | | 6 | TMAX | 0x0 | RW | Ton_max Timeout Interrupt Enable | | | Ton_max Timeout Interr | upt Enable | | | | 5 | REGULATION | 0x0 | RW | DCDC in Regulation Interrupt Enable | | | DCDC in Regulation Inte | errupt Enable | | | | 4 | VREGINHIGH | 0x0 | RW | VREGVDD above threshold Interrupt Enable | | | VREGVDD above thresh | old Interrupt | Enable | | | 3 | VREGINLOW | 0x0 | RW | VREGVDD below threshold Interrupt Enable | | | VREGVDD below thresh | old Interrupt I | Enable | | | 2 | RUNNING | 0x0 | RW | DCDC Running Interrupt Enable | | | DCDC Running Interrupt | Enable | | | | 1 | WARM | 0x0 | RW | DCDC Warmup Time Done Interrupt Enable | | | DCDC Warmup Time Do | one Interrupt E | Enable | | | 0 | BYPSW | 0x0 | RW | Bypass Switch Enabled Interrupt Enable | | | Bypass Switch Enabled | Interrupt Enal | ole | | ## 12.7.8 DCDC\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|-----------|--------|----------|------|----------| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | • | | ' | | | | | | | | | • | ' | | | | | ' | | ' | | | | ' | • | 000 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | 22 | 22 | <b>~</b> | 22 | <u>~</u> | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | BYPCMPOUT | VREGIN | RUNNING | WARM | BYPSW | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 4 | BYPCMPOUT | 0x0 | R | Bypass Comparator Output | | | Bypass Comparator Ou | tput | | | | 3 | VREGIN | 0x0 | R | VREGVDD comparator status | | | VREGVDD above thres | hold | | | | 2 | RUNNING | 0x0 | R | DCDC is running | | | DCDC is running | | | | | 1 | WARM | 0x0 | R | DCDC Warmup Done | | | 100us DCDC warmup to | me complete | | | | 0 | BYPSW | 0x0 | R | Bypass Switch is currently enabled | | | Bypass switch is curren | tly enabled | | | ## 12.7.9 DCDC\_LOCK - Lock Register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|-------|--------|---|---|---|---|---|---|---| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | Reset | | | • | | • | • | | | | • | | • | | | | • | | | • | | • | | | ć | e<br>X | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | Ž | > | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | 71.70 | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - | 2 | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|---------------|-------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0x0 | W | Configuration Lock Key | | | Write any other value th | an the unlock | code to lock all | DCDC registers | | | Value | Mode | | Description | | | 43981 | UNLOCKK | EY | Value to write to unlock | # 12.7.10 DCDC\_LOCKSTATUS - Lock Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|------| | 0x044 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | • | | • | | | | | | • | | | | • | | | | | | | | | • | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ď | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LOCK | | to 0. More information in 1.2 Con- | |------------------------------------| | | | | | | | | | | | | ### 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 12 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 12 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 336. 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 and IADC modules. Similarly on the consumer side, all the peripherals can listen to asynchronous channels while only the TIMER and IADC 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 | В | 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 337). 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 | В | 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 337. 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 | В | | 0xB | A OR (NOT B) | | 0xC | A | | 0xD | (NOT A) OR 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\_ASYNCHx\_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 25.3.10.1 Edge 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": - 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 asynchornous 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 | 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 | | RTCC | RTCC (0x03) | CCV0 | 0x0 | | | | CCV1 | 0x1 | | | | CCV2 | 0x2 | | BURTC | BURTC (0x04) | COMP | 0x0 | | | | OVERFLOW | 0x1 | | GPIO | GPIO (0x05) | PIN0 | 0x0 | | | | PIN1 | 0x1 | | | | PIN2 | 0x2 | | | | PIN3 | 0x3 | | | | PIN4 | 0x4 | | | | PIN5 | 0x5 | | | | PIN6 | 0x6 | | | | PIN7 | 0x7 | | СМИ | CMUL (0x06) | CLKOUT0 | 0x0 | | | | CLKOUT1 | 0x1 | | | | CLKOUT2 | 0x2 | | PRS | PRSL (0x0A) | ASYNCH0 | 0x0 | | | | ASYNCH1 | 0x1 | | | | ASYNCH2 | 0x2 | | | | ASYNCH3 | 0x3 | | | | ASYNCH4 | 0x4 | | | | ASYNCH5 | 0x5 | | | | ASYNCH6 | 0x6 | | | | ASYNCH7 | 0x7 | | | PRS (0x0B) | ASYNCH8 | 0x0 | | | | ASYNCH9 | 0x1 | | | | ASYNCH10 | 0x2 | | | | ASYNCH11 | 0x3 | | Peripheral | SOURCESEL | Signal | SIGSEL | | | | |------------|------------------|--------|--------|--|--|--| | EUART0 | EUART0 (0x0C) | IRDATX | 0x0 | | | | | | | RTS | 0x1 | | | | | | | TX | 0x2 | | | | | | | TXC | 0x3 | | | | | | | RXFL | 0x4 | | | | | USART0 | USART0 (0x20) CS | | | | | | | | | IRTX | 0x1 | | | | | | | RTS | 0x2 | | | | | | | RXDATA | 0x3 | | | | | | | TX | 0x4 | | | | | | | TXC | 0x5 | | | | | USART1 | USART1 (0x21) | cs | 0x0 | | | | | | | IRTX | 0x1 | | | | | | RTS | | 0x2 | | | | | | | RXDATA | 0x3 | | | | | | | TX | 0x4 | | | | | | | TXC | 0x5 | | | | | TIMER0 | TIMER0 (0x22) | UF | 0x0 | | | | | | | OF | 0x1 | | | | | | | CC0 | 0x2 | | | | | | | CC1 | 0x3 | | | | | | | CC2 | 0x4 | | | | | TIMER1 | TIMER1 (0x23) | UF | 0x0 | | | | | | | OF | 0x1 | | | | | | | CC0 | 0x2 | | | | | | | CC1 | 0x3 | | | | | | | CC2 | 0x4 | | | | | TIMER2 | TIMER2 (0x24) | UF | 0x0 | | | | | | | OF | 0x1 | | | | | | | CC0 | 0x2 | | | | | | | CC1 | 0x3 | | | | | | | CC2 | 0x4 | | | | | TIMER3 | TIMER3 (0x25) | UF | 0x0 | | | | | | | OF | 0x1 | | | | | | | CC0 | 0x2 | | | | | | | CC1 | 0x3 | | | | | | | CC2 | 0x4 | | | | | Peripheral | SOURCESEL | Signal | SIGSEL | |------------|------------------|-------------|--------| | CORE | CORE (0x26) | CTIOUT0 | 0x0 | | | | CTIOUT1 | 0x1 | | | | CTIOUT2 | 0x2 | | | | CTIOUT3 | 0x3 | | AGC | AGCL (0x27) | CCA | 0x0 | | | | CCAREQ | 0x1 | | | AGC (0x28) | RSSIDONE | 0x2 | | MODEM | MODEML (0x2A) | ADVANCE | 0x0 | | | | ANT0 | 0x1 | | | | ANT1 | 0x2 | | | | COHDSADET | 0x3 | | | | COHDSALIVE | 0x4 | | | | DCLK | 0x5 | | | | DOUT | 0x6 | | | | FRAMEDET | 0x7 | | | MODEM (0x2B) | FRAMESENT | 0x0 | | | | LOWCORR | 0x1 | | | | LRDSADET | 0x2 | | | | LRDSALIVE | 0x3 | | | | NEWSYMBOL | 0x4 | | | | NEWWND | 0x5 | | | | POSTPONE | 0x6 | | | | PREDET | 0x7 | | | MODEMH (0x2C) | PRESENT | 0x0 | | | | RSSIJUMP | 0x1 | | | | SYNCSENT | 0x2 | | | | TIMDET | 0x3 | | | | WEAK | 0x4 | | | | EOF | 0x5 | | FRC | FRC (0x2D) | DCLK | 0x0 | | | | DOUT | 0x1 | | PROTIMER | PROTIMERL (0x2E) | LBTF | 0x6 | | | | LBTR | 0x7 | | | PROTIMER (0x2F) | LBTS | 0x0 | | PDM | PDML (0x31) | PDMDSRPULSE | 0x0 | | Peripheral | SOURCESEL | Signal | SIGSEL | | | |------------|---------------|---------|--------|--|--| | RAC | RACL (0x33) | ACTIVE | 0x0 | | | | | | LNAEN | 0x1 | | | | | | PAEN | 0x2 | | | | | | RX | 0x3 | | | | | | TX | 0x4 | | | | | | CTIOUT0 | | | | | | | CTIOUT1 | 0x6 | | | | | | CTIOUT2 | 0x7 | | | | | RAC (0x34) | стюштз | 0x0 | | | | TIMER4 | TIMER4 (0x35) | UF | 0x0 | | | | | | OF | 0x1 | | | | | | CC0 | 0x2 | | | | | | CC1 | 0x3 | | | | | | CC2 | 0x4 | | | | LFRCO | LFRCO (0x38) | CALMEAS | 0x0 | | | | | | SDM | 0x1 | | | | | | TCMEAS | | | | ### 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\_cperipheral\_name>\_<signal\_name>. For example, the PRS\_CONSUMER\_TIMERO\_CCO register is used to select which PRS channel output is sent to the TIMERO peripheral's CCO 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 | Туре | Description | |--------|-------------------------------------|------|----------------------------------------| | 0x000 | PRS_IPVERSION | R | IP version ID | | 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 | | 0x048 | PRS_SYNC_CHx_CTRL | RW | Sync Channel Control Register | | 0x058 | PRS_CONSUM-<br>ER_CMU_CALDN | RW | CMU CALDN Consumer Selection | | 0x05C | PRS_CONSUMER_CMU_CAL-<br>UP | RW | CMU CALUP Consumer Selection | | 0x064 | PRS_CONSUM-<br>ER_IADC0_SCANTRIGGER | RW | IADC0 SCANTRIGGER Consumer Selection | | 0x068 | PRS_CONSUMER_IADC0_SIN-GLETRIGGER | RW | IADC0 SINGLETRIGGER Consumer Selection | | 0x06C | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ0 | RW | DMAREQ0 Consumer Selection | | 0x070 | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ1 | RW | DMAREQ1 Consumer Selection | | 0x074 | PRS_CONSUMER_LETIM-<br>ER0_CLEAR | RW | LETIMER CLEAR Consumer Selection | | 0x078 | PRS_CONSUMER_LETIM-<br>ER0_START | RW | LETIMER START Consumer Selection | | 0x07C | PRS_CONSUMER_LETIM-<br>ER0_STOP | RW | LETIMER STOP Consumer Selection | | 0x080 | PRS_CONSUMER_EUART0_RX | RW | EUART0 RX consumer register | | 0x084 | PRS_CONSUMER_EU-<br>ART0_TRIGGER | RW | EUART0 TRIGGER Consumer register | | 0x088 | PRS_CONSUMER_MO-<br>DEM_DIN | RW | MODEM DIN Consumer Selection | | 0x0C0 | PRS_CONSUMER_RAC_CLR | RW | RAC CLR Consumer Selection | | 0x0C4 | PRS_CONSUMER_RAC_CTIIN0 | RW | RAC CTIIN0 Consumer Selection | | 0x0C8 | PRS_CONSUMER_RAC_CTIIN1 | RW | RAC CTIIN1 Consumer Selection | | 0x0CC | PRS_CONSUMER_RAC_CTIIN2 | RW | RAC CTIIN2 Consumer Selection | | 0x0D0 | PRS_CONSUMER_RAC_CTIIN3 | RW | RAC CTIIN3 Consumer Selection | | 0x0D4 | PRS_CONSUM-<br>ER_RAC_FORCETX | RW | RAC FORCETX Consumer Selection | | 0x0D8 | PRS_CONSUMER_RAC_RXDIS | RW | RAC RXDIS Consumer Selection | | 0x0DC | PRS_CONSUMER_RAC_RXEN | RW | RAC RXEN Consumer Selection | | 0x0E0 | PRS_CONSUMER_RAC_SEQ | RW | RAC SEQ Consumer Selection | | Offset | Name | Туре | Description | |--------|---------------------------------|------|----------------------------------| | 0x0E4 | PRS_CONSUMER_RAC_TXEN | RW | RAC TXEN Consumer Selection | | 0x0E8 | PRS_CONSUMER_RTCC_CC0 | RW | RTCC CC0 Consumer Selection | | 0x0EC | PRS_CONSUMER_RTCC_CC1 | RW | RTCC CC1 Consumer Selection | | 0x0F0 | PRS_CONSUMER_RTCC_CC2 | RW | RTCC CC2 Consumer Selection | | 0x0F8 | PRS_CONSUM-<br>ER_CORE_CTIIN0 | RW | CTI0 Consumer Selection | | 0x0FC | PRS_CONSUM-<br>ER_CORE_CTIIN1 | RW | CTI1 Consumer Selection | | 0x100 | PRS_CONSUM-<br>ER_CORE_CTIIN2 | RW | CTI2 Consumer Selection | | 0x104 | PRS_CONSUM-<br>ER_CORE_CTIIN3 | RW | CTI3 Consumer Selection | | 0x108 | PRS_CONSUM-<br>ER_CORE_M33RXEV | RW | M33 Consumer Selection | | 0x10C | PRS_CONSUMER_TIM-<br>ER0_CC0 | RW | TIMER0 CC0 Consumer Selection | | 0x110 | PRS_CONSUMER_TIM-<br>ER0_CC1 | RW | TIMER0 CC1 Consumer Selection | | 0x114 | PRS_CONSUMER_TIM-<br>ER0_CC2 | RW | TIMER0 CC2 Consumer Selection | | 0x118 | PRS_CONSUMER_TIMER0_DTI | RW | TIMER0 DTI Consumer Selection | | 0x11C | PRS_CONSUMER_TIM-<br>ER0_DTIFS1 | RW | TIMER0 DTIFS1 Consumer Selection | | 0x120 | PRS_CONSUMER_TIM-<br>ER0_DTIFS2 | RW | TIMER0 DTIFS2 Consumer Selection | | 0x124 | PRS_CONSUMER_TIM-<br>ER1_CC0 | RW | TIMER1 CC0 Consumer Selection | | 0x128 | PRS_CONSUMER_TIM-<br>ER1_CC1 | RW | TIMER1 CC1 Consumer Selection | | 0x12C | PRS_CONSUMER_TIM-<br>ER1_CC2 | RW | TIMER1 CC2 Consumer Selection | | 0x130 | PRS_CONSUMER_TIMER1_DTI | RW | TIMER1 DTI Consumer Selection | | 0x134 | PRS_CONSUMER_TIM-<br>ER1_DTIFS1 | RW | TIMER1 DTIFS1 Consumer Selection | | 0x138 | PRS_CONSUMER_TIM-<br>ER1_DTIFS2 | RW | TIMER1 DTIFS2 Consumer Selection | | 0x13C | PRS_CONSUMER_TIM-<br>ER2_CC0 | RW | TIMER2 CC0 Consumer Selection | | 0x140 | PRS_CONSUMER_TIM-<br>ER2_CC1 | RW | TIMER2 CC1 Consumer Selection | | 0x144 | PRS_CONSUMER_TIM-<br>ER2_CC2 | RW | TIMER2 CC2 Consumer Selection | | 0x148 | PRS_CONSUMER_TIMER2_DTI | RW | TIMER2 DTI Consumer Selection | | 0x14C | PRS_CONSUMER_TIM-<br>ER2_DTIFS1 | RW | TIMER2 DTIFS1 Consumer Selection | | Offset | Name | Туре | Description | |--------|----------------------------------|------|-----------------------------------| | 0x150 | PRS_CONSUMER_TIM-<br>ER2_DTIFS2 | RW | TIMER2 DTIFS2 Consumer Selection | | 0x154 | PRS_CONSUMER_TIM-<br>ER3_CC0 | RW | TIMER3 CC0 Consumer Selection | | 0x158 | PRS_CONSUMER_TIM-<br>ER3_CC1 | RW | TIMER3 CC1 Consumer Selection | | 0x15C | PRS_CONSUMER_TIM-<br>ER3_CC2 | RW | TIMER3 CC2 Consumer Selection | | 0x160 | PRS_CONSUMER_TIMER3_DTI | RW | TIMER3 DTI Consumer Selection | | 0x164 | PRS_CONSUMER_TIM-<br>ER3_DTIFS1 | RW | TIMER3 DTIFS1 Consumer Selection | | 0x168 | PRS_CONSUMER_TIM-<br>ER3_DTIFS2 | RW | TIMER3 DTIFS2 Consumer Selection | | 0x16C | PRS_CONSUMER_TIM-<br>ER4_CC0 | RW | TIMER4 CC0 Consumer Selection | | 0x170 | PRS_CONSUMER_TIM-<br>ER4_CC1 | RW | TIMER4 CC1 Consumer Selection | | 0x174 | PRS_CONSUMER_TIM-<br>ER4_CC2 | RW | TIMER4 CC2 Consumer Selection | | 0x178 | PRS_CONSUMER_TIMER4_DTI | RW | TIMER4 DTI Consumer Selection | | 0x17C | PRS_CONSUMER_TIM-<br>ER4_DTIFS1 | RW | TIMER4 DTIFS1 Consumer Selection | | 0x180 | PRS_CONSUMER_TIM-<br>ER4_DTIFS2 | RW | TIMER4 DTIFS2 Consumer Selection | | 0x184 | PRS_CONSUM-<br>ER_USART0_CLK | RW | USART0 CLK Consumer Selection | | 0x188 | PRS_CONSUMER_USARTO_IR | RW | USART0 IR Consumer Selection | | 0x18C | PRS_CONSUMER_USART0_RX | RW | USART0 RX Consumer Selection | | 0x190 | PRS_CONSUM-<br>ER_USART0_TRIGGER | RW | USART0 TRIGGER Consumer Selection | | 0x194 | PRS_CONSUM-<br>ER_USART1_CLK | RW | USART1 CLK Consumer Selection | | 0x198 | PRS_CONSUMER_USART1_IR | RW | USART1 IR Consumer Selection | | 0x19C | PRS_CONSUMER_USART1_RX | RW | USART1 RX Consumer Selection | | 0x1A0 | PRS_CONSUM-<br>ER_USART1_TRIGGER | RW | USART1 TRIGGER Consumer Selection | | 0x1A4 | PRS_CONSUM-<br>ER_WDOG0_SRC0 | RW | WDOG0 SRC0 Consumer Selection | | 0x1A8 | PRS_CONSUM-<br>ER_WDOG0_SRC1 | RW | WDOG0 SRC1 Consumer Selection | | 0x1000 | PRS_IPVERSION_SET | R | IP version ID | | 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 | Туре | Description | |--------|----------------------------------------------|------|----------------------------------------| | 0x1014 | PRS_SYNC_PEEK_SET | RH | Sync Channel Values | | 0x1018 | PRS_ASYNC_CHx_CTRL_SET | RW | Async Channel Control Register | | 0x1048 | PRS_SYNC_CHx_CTRL_SET | RW | Sync Channel Control Register | | 0x1058 | PRS_CONSUM-<br>ER_CMU_CALDN_SET | RW | CMU CALDN Consumer Selection | | 0x105C | PRS_CONSUMER_CMU_CAL-<br>UP_SET | RW | CMU CALUP Consumer Selection | | 0x1064 | PRS_CONSUM-<br>ER_IADC0_SCANTRIG-<br>GER_SET | RW | IADC0 SCANTRIGGER Consumer Selection | | 0x1068 | PRS_CONSUMER_IADC0_SIN-GLETRIGGER_SET | RW | IADC0 SINGLETRIGGER Consumer Selection | | 0x106C | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ0_SET | RW | DMAREQ0 Consumer Selection | | 0x1070 | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ1_SET | RW | DMAREQ1 Consumer Selection | | 0x1074 | PRS_CONSUMER_LETIM-<br>ER0_CLEAR_SET | RW | LETIMER CLEAR Consumer Selection | | 0x1078 | PRS_CONSUMER_LETIM-<br>ER0_START_SET | RW | LETIMER START Consumer Selection | | 0x107C | PRS_CONSUMER_LETIM-<br>ER0_STOP_SET | RW | LETIMER STOP Consumer Selection | | 0x1080 | PRS_CONSUMER_EU-<br>ART0_RX_SET | RW | EUART0 RX consumer register | | 0x1084 | PRS_CONSUMER_EU-<br>ART0_TRIGGER_SET | RW | EUART0 TRIGGER Consumer register | | 0x1088 | PRS_CONSUMER_MO-<br>DEM_DIN_SET | RW | MODEM DIN Consumer Selection | | 0x10C0 | PRS_CONSUM-<br>ER_RAC_CLR_SET | RW | RAC CLR Consumer Selection | | 0x10C4 | PRS_CONSUM-<br>ER_RAC_CTIIN0_SET | RW | RAC CTIIN0 Consumer Selection | | 0x10C8 | PRS_CONSUM-<br>ER_RAC_CTIIN1_SET | RW | RAC CTIIN1 Consumer Selection | | 0x10CC | PRS_CONSUM-<br>ER_RAC_CTIIN2_SET | RW | RAC CTIIN2 Consumer Selection | | 0x10D0 | PRS_CONSUM-<br>ER_RAC_CTIIN3_SET | RW | RAC CTIIN3 Consumer Selection | | 0x10D4 | PRS_CONSUM-<br>ER_RAC_FORCETX_SET | RW | RAC FORCETX Consumer Selection | | 0x10D8 | PRS_CONSUM-<br>ER_RAC_RXDIS_SET | RW | RAC RXDIS Consumer Selection | | 0x10DC | PRS_CONSUM-<br>ER_RAC_RXEN_SET | RW | RAC RXEN Consumer Selection | | 0x10E0 | PRS_CONSUM-<br>ER_RAC_SEQ_SET | RW | RAC SEQ Consumer Selection | | Offset | Name | Туре | Description | |--------|-------------------------------------|------|----------------------------------| | 0x10E4 | PRS_CONSUM-<br>ER_RAC_TXEN_SET | RW | RAC TXEN Consumer Selection | | 0x10E8 | PRS_CONSUM-<br>ER_RTCC_CC0_SET | RW | RTCC CC0 Consumer Selection | | 0x10EC | PRS_CONSUM-<br>ER_RTCC_CC1_SET | RW | RTCC CC1 Consumer Selection | | 0x10F0 | PRS_CONSUM-<br>ER_RTCC_CC2_SET | RW | RTCC CC2 Consumer Selection | | 0x10F8 | PRS_CONSUM-<br>ER_CORE_CTIIN0_SET | RW | CTI0 Consumer Selection | | 0x10FC | PRS_CONSUM-<br>ER_CORE_CTIIN1_SET | RW | CTI1 Consumer Selection | | 0x1100 | PRS_CONSUM-<br>ER_CORE_CTIIN2_SET | RW | CTI2 Consumer Selection | | 0x1104 | PRS_CONSUM-<br>ER_CORE_CTIIN3_SET | RW | CTI3 Consumer Selection | | 0x1108 | PRS_CONSUM-<br>ER_CORE_M33RXEV_SET | RW | M33 Consumer Selection | | 0x110C | PRS_CONSUMER_TIM-<br>ER0_CC0_SET | RW | TIMER0 CC0 Consumer Selection | | 0x1110 | PRS_CONSUMER_TIM-<br>ER0_CC1_SET | RW | TIMER0 CC1 Consumer Selection | | 0x1114 | PRS_CONSUMER_TIM-<br>ER0_CC2_SET | RW | TIMER0 CC2 Consumer Selection | | 0x1118 | PRS_CONSUMER_TIM-<br>ER0_DTI_SET | RW | TIMER0 DTI Consumer Selection | | 0x111C | PRS_CONSUMER_TIM-<br>ER0_DTIFS1_SET | RW | TIMER0 DTIFS1 Consumer Selection | | 0x1120 | PRS_CONSUMER_TIM-<br>ER0_DTIFS2_SET | RW | TIMER0 DTIFS2 Consumer Selection | | 0x1124 | PRS_CONSUMER_TIM-<br>ER1_CC0_SET | RW | TIMER1 CC0 Consumer Selection | | 0x1128 | PRS_CONSUMER_TIM-<br>ER1_CC1_SET | RW | TIMER1 CC1 Consumer Selection | | 0x112C | PRS_CONSUMER_TIM-<br>ER1_CC2_SET | RW | TIMER1 CC2 Consumer Selection | | 0x1130 | PRS_CONSUMER_TIM-<br>ER1_DTI_SET | RW | TIMER1 DTI Consumer Selection | | 0x1134 | PRS_CONSUMER_TIM-<br>ER1_DTIFS1_SET | RW | TIMER1 DTIFS1 Consumer Selection | | 0x1138 | PRS_CONSUMER_TIM-<br>ER1_DTIFS2_SET | RW | TIMER1 DTIFS2 Consumer Selection | | 0x113C | PRS_CONSUMER_TIM-<br>ER2_CC0_SET | RW | TIMER2 CC0 Consumer Selection | | 0x1140 | PRS_CONSUMER_TIM-<br>ER2_CC1_SET | RW | TIMER2 CC1 Consumer Selection | | Offset | Name | Туре | Description | |--------|--------------------------------------|------|-----------------------------------| | 0x1144 | PRS_CONSUMER_TIM-<br>ER2_CC2_SET | RW | TIMER2 CC2 Consumer Selection | | 0x1148 | PRS_CONSUMER_TIM-<br>ER2_DTI_SET | RW | TIMER2 DTI Consumer Selection | | 0x114C | PRS_CONSUMER_TIM-<br>ER2_DTIFS1_SET | RW | TIMER2 DTIFS1 Consumer Selection | | 0x1150 | PRS_CONSUMER_TIM-<br>ER2_DTIFS2_SET | RW | TIMER2 DTIFS2 Consumer Selection | | 0x1154 | PRS_CONSUMER_TIM-<br>ER3_CC0_SET | RW | TIMER3 CC0 Consumer Selection | | 0x1158 | PRS_CONSUMER_TIM-<br>ER3_CC1_SET | RW | TIMER3 CC1 Consumer Selection | | 0x115C | PRS_CONSUMER_TIM-<br>ER3_CC2_SET | RW | TIMER3 CC2 Consumer Selection | | 0x1160 | PRS_CONSUMER_TIM-<br>ER3_DTI_SET | RW | TIMER3 DTI Consumer Selection | | 0x1164 | PRS_CONSUMER_TIM-<br>ER3_DTIFS1_SET | RW | TIMER3 DTIFS1 Consumer Selection | | 0x1168 | PRS_CONSUMER_TIM-<br>ER3_DTIFS2_SET | RW | TIMER3 DTIFS2 Consumer Selection | | 0x116C | PRS_CONSUMER_TIM-<br>ER4_CC0_SET | RW | TIMER4 CC0 Consumer Selection | | 0x1170 | PRS_CONSUMER_TIM-<br>ER4_CC1_SET | RW | TIMER4 CC1 Consumer Selection | | 0x1174 | PRS_CONSUMER_TIM-<br>ER4_CC2_SET | RW | TIMER4 CC2 Consumer Selection | | 0x1178 | PRS_CONSUMER_TIM-<br>ER4_DTI_SET | RW | TIMER4 DTI Consumer Selection | | 0x117C | PRS_CONSUMER_TIM-<br>ER4_DTIFS1_SET | RW | TIMER4 DTIFS1 Consumer Selection | | 0x1180 | PRS_CONSUMER_TIM-<br>ER4_DTIFS2_SET | RW | TIMER4 DTIFS2 Consumer Selection | | 0x1184 | PRS_CONSUM-<br>ER_USART0_CLK_SET | RW | USART0 CLK Consumer Selection | | 0x1188 | PRS_CONSUM-<br>ER_USART0_IR_SET | RW | USART0 IR Consumer Selection | | 0x118C | PRS_CONSUM-<br>ER_USART0_RX_SET | RW | USART0 RX Consumer Selection | | 0x1190 | PRS_CONSUM-<br>ER_USART0_TRIGGER_SET | RW | USART0 TRIGGER Consumer Selection | | 0x1194 | PRS_CONSUM-<br>ER_USART1_CLK_SET | RW | USART1 CLK Consumer Selection | | 0x1198 | PRS_CONSUM-<br>ER_USART1_IR_SET | RW | USART1 IR Consumer Selection | | 0x119C | PRS_CONSUM-<br>ER_USART1_RX_SET | RW | USART1 RX Consumer Selection | | Offset | Name | Туре | Description | |--------|----------------------------------------------|------|----------------------------------------| | 0x11A0 | PRS_CONSUM-<br>ER_USART1_TRIGGER_SET | RW | USART1 TRIGGER Consumer Selection | | 0x11A4 | PRS_CONSUM-<br>ER_WDOG0_SRC0_SET | RW | WDOG0 SRC0 Consumer Selection | | 0x11A8 | PRS_CONSUM-<br>ER_WDOG0_SRC1_SET | RW | WDOG0 SRC1 Consumer Selection | | 0x2000 | PRS_IPVERSION_CLR | R | IP version ID | | 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 | | 0x2048 | PRS_SYNC_CHx_CTRL_CLR | RW | Sync Channel Control Register | | 0x2058 | PRS_CONSUM-<br>ER_CMU_CALDN_CLR | RW | CMU CALDN Consumer Selection | | 0x205C | PRS_CONSUMER_CMU_CAL-<br>UP_CLR | RW | CMU CALUP Consumer Selection | | 0x2064 | PRS_CONSUM-<br>ER_IADC0_SCANTRIG-<br>GER_CLR | RW | IADC0 SCANTRIGGER Consumer Selection | | 0x2068 | PRS_CONSUMER_IADC0_SIN-GLETRIGGER_CLR | RW | IADC0 SINGLETRIGGER Consumer Selection | | 0x206C | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ0_CLR | RW | DMAREQ0 Consumer Selection | | 0x2070 | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ1_CLR | RW | DMAREQ1 Consumer Selection | | 0x2074 | PRS_CONSUMER_LETIM-<br>ER0_CLEAR_CLR | RW | LETIMER CLEAR Consumer Selection | | 0x2078 | PRS_CONSUMER_LETIM-<br>ER0_START_CLR | RW | LETIMER START Consumer Selection | | 0x207C | PRS_CONSUMER_LETIM-<br>ER0_STOP_CLR | RW | LETIMER STOP Consumer Selection | | 0x2080 | PRS_CONSUMER_EU-<br>ART0_RX_CLR | RW | EUART0 RX consumer register | | 0x2084 | PRS_CONSUMER_EU-<br>ART0_TRIGGER_CLR | RW | EUART0 TRIGGER Consumer register | | 0x2088 | PRS_CONSUMER_MO-<br>DEM_DIN_CLR | RW | MODEM DIN Consumer Selection | | 0x20C0 | PRS_CONSUM-<br>ER_RAC_CLR_CLR | RW | RAC CLR Consumer Selection | | 0x20C4 | PRS_CONSUM-<br>ER_RAC_CTIIN0_CLR | RW | RAC CTIIN0 Consumer Selection | | 0x20C8 | PRS_CONSUM-<br>ER_RAC_CTIIN1_CLR | RW | RAC CTIIN1 Consumer Selection | | Offset | Name | Туре | Description | |--------|-------------------------------------|------|----------------------------------| | 0x20CC | PRS_CONSUM-<br>ER_RAC_CTIIN2_CLR | RW | RAC CTIIN2 Consumer Selection | | 0x20D0 | PRS_CONSUM-<br>ER_RAC_CTIIN3_CLR | RW | RAC CTIIN3 Consumer Selection | | 0x20D4 | PRS_CONSUM-<br>ER_RAC_FORCETX_CLR | RW | RAC FORCETX Consumer Selection | | 0x20D8 | PRS_CONSUM-<br>ER_RAC_RXDIS_CLR | RW | RAC RXDIS Consumer Selection | | 0x20DC | PRS_CONSUM-<br>ER_RAC_RXEN_CLR | RW | RAC RXEN Consumer Selection | | 0x20E0 | PRS_CONSUM-<br>ER_RAC_SEQ_CLR | RW | RAC SEQ Consumer Selection | | 0x20E4 | PRS_CONSUM-<br>ER_RAC_TXEN_CLR | RW | RAC TXEN Consumer Selection | | 0x20E8 | PRS_CONSUM-<br>ER_RTCC_CC0_CLR | RW | RTCC CC0 Consumer Selection | | 0x20EC | PRS_CONSUM-<br>ER_RTCC_CC1_CLR | RW | RTCC CC1 Consumer Selection | | 0x20F0 | PRS_CONSUM-<br>ER_RTCC_CC2_CLR | RW | RTCC CC2 Consumer Selection | | 0x20F8 | PRS_CONSUM-<br>ER_CORE_CTIIN0_CLR | RW | CTI0 Consumer Selection | | 0x20FC | PRS_CONSUM-<br>ER_CORE_CTIIN1_CLR | RW | CTI1 Consumer Selection | | 0x2100 | PRS_CONSUM-<br>ER_CORE_CTIIN2_CLR | RW | CTI2 Consumer Selection | | 0x2104 | PRS_CONSUM-<br>ER_CORE_CTIIN3_CLR | RW | CTI3 Consumer Selection | | 0x2108 | PRS_CONSUM-<br>ER_CORE_M33RXEV_CLR | RW | M33 Consumer Selection | | 0x210C | PRS_CONSUMER_TIM-<br>ER0_CC0_CLR | RW | TIMER0 CC0 Consumer Selection | | 0x2110 | PRS_CONSUMER_TIM-<br>ER0_CC1_CLR | RW | TIMER0 CC1 Consumer Selection | | 0x2114 | PRS_CONSUMER_TIM-<br>ER0_CC2_CLR | RW | TIMER0 CC2 Consumer Selection | | 0x2118 | PRS_CONSUMER_TIM-<br>ER0_DTI_CLR | RW | TIMER0 DTI Consumer Selection | | 0x211C | PRS_CONSUMER_TIM-<br>ER0_DTIFS1_CLR | RW | TIMER0 DTIFS1 Consumer Selection | | 0x2120 | PRS_CONSUMER_TIM-<br>ER0_DTIFS2_CLR | RW | TIMER0 DTIFS2 Consumer Selection | | 0x2124 | PRS_CONSUMER_TIM-<br>ER1_CC0_CLR | RW | TIMER1 CC0 Consumer Selection | | 0x2128 | PRS_CONSUMER_TIM-<br>ER1_CC1_CLR | RW | TIMER1 CC1 Consumer Selection | | Offset | Name | Туре | Description | |--------|-------------------------------------|------|----------------------------------| | 0x212C | PRS_CONSUMER_TIM-<br>ER1_CC2_CLR | RW | TIMER1 CC2 Consumer Selection | | 0x2130 | PRS_CONSUMER_TIM-<br>ER1_DTI_CLR | RW | TIMER1 DTI Consumer Selection | | 0x2134 | PRS_CONSUMER_TIM-<br>ER1_DTIFS1_CLR | RW | TIMER1 DTIFS1 Consumer Selection | | 0x2138 | PRS_CONSUMER_TIM-<br>ER1_DTIFS2_CLR | RW | TIMER1 DTIFS2 Consumer Selection | | 0x213C | PRS_CONSUMER_TIM-<br>ER2_CC0_CLR | RW | TIMER2 CC0 Consumer Selection | | 0x2140 | PRS_CONSUMER_TIM-<br>ER2_CC1_CLR | RW | TIMER2 CC1 Consumer Selection | | 0x2144 | PRS_CONSUMER_TIM-<br>ER2_CC2_CLR | RW | TIMER2 CC2 Consumer Selection | | 0x2148 | PRS_CONSUMER_TIM-<br>ER2_DTI_CLR | RW | TIMER2 DTI Consumer Selection | | 0x214C | PRS_CONSUMER_TIM-<br>ER2_DTIFS1_CLR | RW | TIMER2 DTIFS1 Consumer Selection | | 0x2150 | PRS_CONSUMER_TIM-<br>ER2_DTIFS2_CLR | RW | TIMER2 DTIFS2 Consumer Selection | | 0x2154 | PRS_CONSUMER_TIM-<br>ER3_CC0_CLR | RW | TIMER3 CC0 Consumer Selection | | 0x2158 | PRS_CONSUMER_TIM-<br>ER3_CC1_CLR | RW | TIMER3 CC1 Consumer Selection | | 0x215C | PRS_CONSUMER_TIM-<br>ER3_CC2_CLR | RW | TIMER3 CC2 Consumer Selection | | 0x2160 | PRS_CONSUMER_TIM-<br>ER3_DTI_CLR | RW | TIMER3 DTI Consumer Selection | | 0x2164 | PRS_CONSUMER_TIM-<br>ER3_DTIFS1_CLR | RW | TIMER3 DTIFS1 Consumer Selection | | 0x2168 | PRS_CONSUMER_TIM-<br>ER3_DTIFS2_CLR | RW | TIMER3 DTIFS2 Consumer Selection | | 0x216C | PRS_CONSUMER_TIM-<br>ER4_CC0_CLR | RW | TIMER4 CC0 Consumer Selection | | 0x2170 | PRS_CONSUMER_TIM-<br>ER4_CC1_CLR | RW | TIMER4 CC1 Consumer Selection | | 0x2174 | PRS_CONSUMER_TIM-<br>ER4_CC2_CLR | RW | TIMER4 CC2 Consumer Selection | | 0x2178 | PRS_CONSUMER_TIM-<br>ER4_DTI_CLR | RW | TIMER4 DTI Consumer Selection | | 0x217C | PRS_CONSUMER_TIM-<br>ER4_DTIFS1_CLR | RW | TIMER4 DTIFS1 Consumer Selection | | 0x2180 | PRS_CONSUMER_TIM-<br>ER4_DTIFS2_CLR | RW | TIMER4 DTIFS2 Consumer Selection | | 0x2184 | PRS_CONSUM-<br>ER_USART0_CLK_CLR | RW | USART0 CLK Consumer Selection | | Offset | Name | Туре | Description | |--------|----------------------------------------------|------|----------------------------------------| | 0x2188 | PRS_CONSUM-<br>ER_USART0_IR_CLR | RW | USART0 IR Consumer Selection | | 0x218C | PRS_CONSUM-<br>ER_USART0_RX_CLR | RW | USART0 RX Consumer Selection | | 0x2190 | PRS_CONSUM-<br>ER_USART0_TRIGGER_CLR | RW | USART0 TRIGGER Consumer Selection | | 0x2194 | PRS_CONSUM-<br>ER_USART1_CLK_CLR | RW | USART1 CLK Consumer Selection | | 0x2198 | PRS_CONSUM-<br>ER_USART1_IR_CLR | RW | USART1 IR Consumer Selection | | 0x219C | PRS_CONSUM-<br>ER_USART1_RX_CLR | RW | USART1 RX Consumer Selection | | 0x21A0 | PRS_CONSUM-<br>ER_USART1_TRIGGER_CLR | RW | USART1 TRIGGER Consumer Selection | | 0x21A4 | PRS_CONSUM-<br>ER_WDOG0_SRC0_CLR | RW | WDOG0 SRC0 Consumer Selection | | 0x21A8 | PRS_CONSUM-<br>ER_WDOG0_SRC1_CLR | RW | WDOG0 SRC1 Consumer Selection | | 0x3000 | PRS_IPVERSION_TGL | R | IP version ID | | 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 | | 0x3048 | PRS_SYNC_CHx_CTRL_TGL | RW | Sync Channel Control Register | | 0x3058 | PRS_CONSUM-<br>ER_CMU_CALDN_TGL | RW | CMU CALDN Consumer Selection | | 0x305C | PRS_CONSUMER_CMU_CAL-<br>UP_TGL | RW | CMU CALUP Consumer Selection | | 0x3064 | PRS_CONSUM-<br>ER_IADC0_SCANTRIG-<br>GER_TGL | RW | IADC0 SCANTRIGGER Consumer Selection | | 0x3068 | PRS_CONSUMER_IADC0_SIN-GLETRIGGER_TGL | RW | IADC0 SINGLETRIGGER Consumer Selection | | 0x306C | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ0_TGL | RW | DMAREQ0 Consumer Selection | | 0x3070 | PRS_CONSUMER_LDMAX-<br>BAR_DMAREQ1_TGL | RW | DMAREQ1 Consumer Selection | | 0x3074 | PRS_CONSUMER_LETIM-<br>ER0_CLEAR_TGL | RW | LETIMER CLEAR Consumer Selection | | 0x3078 | PRS_CONSUMER_LETIM-<br>ER0_START_TGL | RW | LETIMER START Consumer Selection | | 0x307C | PRS_CONSUMER_LETIM-<br>ER0_STOP_TGL | RW | LETIMER STOP Consumer Selection | | Offset | Name | Туре | Description | |--------|--------------------------------------|------|----------------------------------| | 0x3080 | PRS_CONSUMER_EU-<br>ART0_RX_TGL | RW | EUART0 RX consumer register | | 0x3084 | PRS_CONSUMER_EU-<br>ART0_TRIGGER_TGL | RW | EUART0 TRIGGER Consumer register | | 0x3088 | PRS_CONSUMER_MO-<br>DEM_DIN_TGL | RW | MODEM DIN Consumer Selection | | 0x30C0 | PRS_CONSUM-<br>ER_RAC_CLR_TGL | RW | RAC CLR Consumer Selection | | 0x30C4 | PRS_CONSUM-<br>ER_RAC_CTIIN0_TGL | RW | RAC CTIIN0 Consumer Selection | | 0x30C8 | PRS_CONSUM-<br>ER_RAC_CTIIN1_TGL | RW | RAC CTIIN1 Consumer Selection | | 0x30CC | PRS_CONSUM-<br>ER_RAC_CTIIN2_TGL | RW | RAC CTIIN2 Consumer Selection | | 0x30D0 | PRS_CONSUM-<br>ER_RAC_CTIIN3_TGL | RW | RAC CTIIN3 Consumer Selection | | 0x30D4 | PRS_CONSUM-<br>ER_RAC_FORCETX_TGL | RW | RAC FORCETX Consumer Selection | | 0x30D8 | PRS_CONSUM-<br>ER_RAC_RXDIS_TGL | RW | RAC RXDIS Consumer Selection | | 0x30DC | PRS_CONSUM-<br>ER_RAC_RXEN_TGL | RW | RAC RXEN Consumer Selection | | 0x30E0 | PRS_CONSUM-<br>ER_RAC_SEQ_TGL | RW | RAC SEQ Consumer Selection | | 0x30E4 | PRS_CONSUM-<br>ER_RAC_TXEN_TGL | RW | RAC TXEN Consumer Selection | | 0x30E8 | PRS_CONSUM-<br>ER_RTCC_CC0_TGL | RW | RTCC CC0 Consumer Selection | | 0x30EC | PRS_CONSUM-<br>ER_RTCC_CC1_TGL | RW | RTCC CC1 Consumer Selection | | 0x30F0 | PRS_CONSUM-<br>ER_RTCC_CC2_TGL | RW | RTCC CC2 Consumer Selection | | 0x30F8 | PRS_CONSUM-<br>ER_CORE_CTIIN0_TGL | RW | CTI0 Consumer Selection | | 0x30FC | PRS_CONSUM-<br>ER_CORE_CTIIN1_TGL | RW | CTI1 Consumer Selection | | 0x3100 | PRS_CONSUM-<br>ER_CORE_CTIIN2_TGL | RW | CTI2 Consumer Selection | | 0x3104 | PRS_CONSUM-<br>ER_CORE_CTIIN3_TGL | RW | CTI3 Consumer Selection | | 0x3108 | PRS_CONSUM-<br>ER_CORE_M33RXEV_TGL | RW | M33 Consumer Selection | | 0x310C | PRS_CONSUMER_TIM-<br>ER0_CC0_TGL | RW | TIMER0 CC0 Consumer Selection | | 0x3110 | PRS_CONSUMER_TIM-<br>ER0_CC1_TGL | RW | TIMER0 CC1 Consumer Selection | | Offset | Name | Туре | Description | |--------|-------------------------------------|------|----------------------------------| | 0x3114 | PRS_CONSUMER_TIM-<br>ER0_CC2_TGL | RW | TIMER0 CC2 Consumer Selection | | 0x3118 | PRS_CONSUMER_TIM-<br>ER0_DTI_TGL | RW | TIMER0 DTI Consumer Selection | | 0x311C | PRS_CONSUMER_TIM-<br>ER0_DTIFS1_TGL | RW | TIMER0 DTIFS1 Consumer Selection | | 0x3120 | PRS_CONSUMER_TIM-<br>ER0_DTIFS2_TGL | RW | TIMER0 DTIFS2 Consumer Selection | | 0x3124 | PRS_CONSUMER_TIM-<br>ER1_CC0_TGL | RW | TIMER1 CC0 Consumer Selection | | 0x3128 | PRS_CONSUMER_TIM-<br>ER1_CC1_TGL | RW | TIMER1 CC1 Consumer Selection | | 0x312C | PRS_CONSUMER_TIM-<br>ER1_CC2_TGL | RW | TIMER1 CC2 Consumer Selection | | 0x3130 | PRS_CONSUMER_TIM-<br>ER1_DTI_TGL | RW | TIMER1 DTI Consumer Selection | | 0x3134 | PRS_CONSUMER_TIM-<br>ER1_DTIFS1_TGL | RW | TIMER1 DTIFS1 Consumer Selection | | 0x3138 | PRS_CONSUMER_TIM-<br>ER1_DTIFS2_TGL | RW | TIMER1 DTIFS2 Consumer Selection | | 0x313C | PRS_CONSUMER_TIM-<br>ER2_CC0_TGL | RW | TIMER2 CC0 Consumer Selection | | 0x3140 | PRS_CONSUMER_TIM-<br>ER2_CC1_TGL | RW | TIMER2 CC1 Consumer Selection | | 0x3144 | PRS_CONSUMER_TIM-<br>ER2_CC2_TGL | RW | TIMER2 CC2 Consumer Selection | | 0x3148 | PRS_CONSUMER_TIM-<br>ER2_DTI_TGL | RW | TIMER2 DTI Consumer Selection | | 0x314C | PRS_CONSUMER_TIM-<br>ER2_DTIFS1_TGL | RW | TIMER2 DTIFS1 Consumer Selection | | 0x3150 | PRS_CONSUMER_TIM-<br>ER2_DTIFS2_TGL | RW | TIMER2 DTIFS2 Consumer Selection | | 0x3154 | PRS_CONSUMER_TIM-<br>ER3_CC0_TGL | RW | TIMER3 CC0 Consumer Selection | | 0x3158 | PRS_CONSUMER_TIM-<br>ER3_CC1_TGL | RW | TIMER3 CC1 Consumer Selection | | 0x315C | PRS_CONSUMER_TIM-<br>ER3_CC2_TGL | RW | TIMER3 CC2 Consumer Selection | | 0x3160 | PRS_CONSUMER_TIM-<br>ER3_DTI_TGL | RW | TIMER3 DTI Consumer Selection | | 0x3164 | PRS_CONSUMER_TIM-<br>ER3_DTIFS1_TGL | RW | TIMER3 DTIFS1 Consumer Selection | | 0x3168 | PRS_CONSUMER_TIM-<br>ER3_DTIFS2_TGL | RW | TIMER3 DTIFS2 Consumer Selection | | 0x316C | PRS_CONSUMER_TIM-<br>ER4_CC0_TGL | RW | TIMER4 CC0 Consumer Selection | | Office | Nama | Turns | Description | |--------|--------------------------------------|-------|-----------------------------------| | Offset | Name | Туре | Description | | 0x3170 | PRS_CONSUMER_TIM-<br>ER4_CC1_TGL | RW | TIMER4 CC1 Consumer Selection | | 0x3174 | PRS_CONSUMER_TIM-<br>ER4_CC2_TGL | RW | TIMER4 CC2 Consumer Selection | | 0x3178 | PRS_CONSUMER_TIM-<br>ER4_DTI_TGL | RW | TIMER4 DTI Consumer Selection | | 0x317C | PRS_CONSUMER_TIM-<br>ER4_DTIFS1_TGL | RW | TIMER4 DTIFS1 Consumer Selection | | 0x3180 | PRS_CONSUMER_TIM-<br>ER4_DTIFS2_TGL | RW | TIMER4 DTIFS2 Consumer Selection | | 0x3184 | PRS_CONSUM-<br>ER_USART0_CLK_TGL | RW | USART0 CLK Consumer Selection | | 0x3188 | PRS_CONSUM-<br>ER_USART0_IR_TGL | RW | USART0 IR Consumer Selection | | 0x318C | PRS_CONSUM-<br>ER_USART0_RX_TGL | RW | USART0 RX Consumer Selection | | 0x3190 | PRS_CONSUM-<br>ER_USART0_TRIGGER_TGL | RW | USART0 TRIGGER Consumer Selection | | 0x3194 | PRS_CONSUM-<br>ER_USART1_CLK_TGL | RW | USART1 CLK Consumer Selection | | 0x3198 | PRS_CONSUM-<br>ER_USART1_IR_TGL | RW | USART1 IR Consumer Selection | | 0x319C | PRS_CONSUM-<br>ER_USART1_RX_TGL | RW | USART1 RX Consumer Selection | | 0x31A0 | PRS_CONSUM-<br>ER_USART1_TRIGGER_TGL | RW | USART1 TRIGGER Consumer Selection | | 0x31A4 | PRS_CONSUM-<br>ER_WDOG0_SRC0_TGL | RW | WDOG0 SRC0 Consumer Selection | | 0x31A8 | PRS_CONSUM-<br>ER_WDOG0_SRC1_TGL | RW | WDOG0 SRC1 Consumer Selection | ## 13.5 PRS Register Description # 13.5.1 PRS\_IPVERSION - IP version ID | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x000 | 33 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | \$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۲ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | IDVEDVION | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x1 | R | New BitField | | | The read only IPVERSION modules with different v | | | this module. There may be minor software changes required for | # 13.5.2 PRS\_ASYNC\_SWPULSE - Software Pulse Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | ' | ' | | | | | | | | | | | • | | | | | | • | 0x0 | 0×0 | 0x0 | 0×0 | 0x0 | 000 | 0x0 | 0×0 | 0×0 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | > | > | > | > | > | > | > | > | > | > | > | > | | Name | | | | | | | | | | | | | | | | | | | | | CH11PULSE | CH10PULSE | CH9PULSE | CH8PULSE | CH7PULSE | CH6PULSE | CH5PULSE | CH4PULSE | CH3PULSE | CH2PULSE | CH1PULSE | CH0PULSE | | Bit | Name | Reset | Access | Description | |-------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:12 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 11 | CH11PULSE | 0x0 | W | Channel pulse | | | Channel 11 pulse gener | ation | | | | 10 | CH10PULSE | 0x0 | W | Channel pulse | | | Channel 10 pulse gener | ation | | | | 9 | CH9PULSE | 0x0 | W | Channel pulse | | | Channel 9 pulse genera | tion | | | | 8 | CH8PULSE | 0x0 | W | Channel pulse | | | Channel 8 pulse genera | tion | | | | 7 | CH7PULSE | 0x0 | W | Channel pulse | | | Channel 7 pulse genera | tion | | | | 6 | CH6PULSE | 0x0 | W | Channel pulse | | | Channel 6 pulse genera | tion | | | | 5 | CH5PULSE | 0x0 | W | Channel pulse | | | Channel 5 pulse genera | tion | | | | 4 | CH4PULSE | 0x0 | W | Channel pulse | | | Channel 4 pulse genera | tion | | | | 3 | CH3PULSE | 0x0 | W | Channel pulse | | | Channel 3 pulse genera | tion | | | | 2 | CH2PULSE | 0x0 | W | Channel pulse | | | Channel 2 pulse genera | tion | | | | 1 | CH1PULSE | 0x0 | W | Channel pulse | | | Channel 1 pulse genera | tion | | | | 0 | CH0PULSE | 0x0 | W | Channel pulse | | | Channel 0 pulse genera | tion | | | | | | | | | ## 13.5.3 PRS\_ASYNC\_SWLEVEL - Software Level Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | • | | | | | • | • | | • | | • | • | 000 | 000 | 0x0 | 000 | 000 | 0x0 | 000 | 000 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | ₩<br>M | ₹ | ₩<br>W | ₩<br>M | ₩ | ₩<br>W | ₩<br>M | ₩<br>M | ₩ | ₽ | Z<br>N | R<br>M | | Name | | | | | | | | | | | | | | | | | | | | | CH11LEVEL | CH10LEVEL | CH9LEVEL | CH8LEVEL | CH7LEVEL | CH6LEVEL | CH5LEVEL | CH4LEVEL | CH3LEVEL | CH2LEVEL | CH1LEVEL | CHOLEVEL | | Bit | Name | Reset | Access | Description | |-------|------------------------|----------|-------------------|------------------------------------------------------------------------| | 31:12 | Reserved | | | n future devices, always write bits to 0. More information in 1.2 Con- | | 01.12 | Neserveu | ventions | compationity with | Tatale devices, always while bits to 6. More information in 1.2 con | | 11 | CH11LEVEL | 0x0 | RW | Channel Level | | | Channel 11 Software Le | vel | | | | 10 | CH10LEVEL | 0x0 | RW | Channel Level | | | Channel 10 Software Le | vel | | | | 9 | CH9LEVEL | 0x0 | RW | Channel Level | | | Channel 9 Software Lev | el | | | | 8 | CH8LEVEL | 0x0 | RW | Channel Level | | | Channel 8 Software Lev | el | | | | 7 | CH7LEVEL | 0x0 | RW | Channel Level | | | Channel 7 Software Lev | el | | | | 6 | CH6LEVEL | 0x0 | RW | Channel Level | | | Channel 6 Software Lev | el | | | | 5 | CH5LEVEL | 0x0 | RW | Channel Level | | | Channel 5 Software Lev | el | | | | 4 | CH4LEVEL | 0x0 | RW | Channel Level | | | Channel 4 Software Lev | el | | | | 3 | CH3LEVEL | 0x0 | RW | Channel Level | | | Channel 3 Software Lev | el | | | | 2 | CH2LEVEL | 0x0 | RW | Channel Level | | | Channel 2 Software Lev | el | | | | 1 | CH1LEVEL | 0x0 | RW | Channel Level | | | Channel 1 Software Lev | el | | | | 0 | CH0LEVEL | 0x0 | RW | Channel Level | | | Channel 0 Software Lev | el | | | | | | | | | ## 13.5.4 PRS\_ASYNC\_PEEK - Async Channel Values | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----------|---------|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | • | • | | • | | • | • | | | • | • | • | • | • | 0x0 | 000 | 0x0 | 000 | 000 | 000 | 000 | 000 | 000 | 000 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | <u>~</u> | œ | <u>~</u> | œ | œ | œ | œ | œ | œ | œ | œ | ď | | Name | | | | | | | | | | | | | | | | | | | | | CH11VAL | CH10VAL | CH9VAL | CH8VAL | CH7VAL | CH6VAL | CH5VAL | CH4VAL | CH3VAL | CH2VAL | CH1VAL | CH0VAL | | Bit | Name | Reset | Access | Description | |-------|-------------------|-----------------------|-------------------|---------------------------------------------------------------------------| | 31:12 | Reserved | To ensure<br>ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 11 | CH11VAL | 0x0 | R | Channel 11 Current Value | | | See bit 0. | | | | | 10 | CH10VAL | 0x0 | R | Channel 10 Current Value | | | See bit 0. | | | | | 9 | CH9VAL | 0x0 | R | Channel 9 Current Value | | | See bit 0. | | | | | 8 | CH8VAL | 0x0 | R | Channel 8 Current Value | | | See bit 0. | | | | | 7 | CH7VAL | 0x0 | R | Channel 7 Current Value | | | See bit 0. | | | | | 6 | CH6VAL | 0x0 | R | Channel 6 Current Value | | | See bit 0. | | | | | 5 | CH5VAL | 0x0 | R | Channel 5 Current Value | | | See bit 0. | | | | | 4 | CH4VAL | 0x0 | R | Channel 4 Current Value | | | See bit 0. | | | | | 3 | CH3VAL | 0x0 | R | Channel 3 Current Value | | | See bit 0. | | | | | 2 | CH2VAL | 0x0 | R | Channel 2 Current Value | | | See bit 0. | | | | | 1 | CH1VAL | 0x0 | R | Channel 1 Current Value | | | See bit 0. | | | | | 0 | CH0VAL | 0x0 | R | Channel 0 Current Value | | | Sample the currer | nt output value of o | channel 0. This | value may be one or two clock delayed | ## 13.5.5 PRS\_SYNC\_PEEK - Sync Channel Values | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|----|----|---|---|---|---|---|---|--------|----------|--------|--------| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | • | • | • | • | • | • | • | | • | | • | • | • | | • | • | • | | | | • | • | • | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | œ | <u>~</u> | œ | ď | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CH3VAL | CH2VAL | CH1VAL | CHOVAL | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 3 | CH3VAL | 0x0 | R | Channel Value | | | Channel 3 current value | | | | | 2 | CH2VAL | 0x0 | R | Channel Value | | | Channel 2 current value | | | | | 1 | CH1VAL | 0x0 | R | Channel Value | | | Channel 1 current value | | | | | 0 | CH0VAL | 0x0 | R | Channel Value | | | Channel 0 current value | | | | # 13.5.6 PRS\_ASYNC\_CHx\_CTRL - Async Channel Control Register | Offset | | | Bit Pos | sition | | | |--------|----------------------------------------------------------------|------------|----------|-----------|---------------------------------------------------------------------------|--------| | 0x018 | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>26<br>27<br>27<br>27 | 22 23 20 5 | 19 19 19 | 2 | 7 8 4 8 8 8 4 8 | 0 1 2 | | Reset | 0×0 | | 0XC | 000 | | 0×0 | | Access | RW | | RW | RW | | Ŋ. | | Name | AUXSEL | | FNSEL | SOURCESEL | | SIGSEL | | Bit | Name | Reset Access | Description | |-------|------------------------|----------------------------------|---------------------------------------------------------------------------| | 31:28 | Reserved | To ensure compatibility ventions | with future devices, always write bits to 0. More information in 1.2 Con- | | 27:24 | AUXSEL | 0x0 RW | Auxiliary LUT Input Select | | | Select Asynchronous | s PRS channel as input B of L | LUT function. Async PRS[n] is selected with AUXSEL = n. | | 23:20 | Reserved | To ensure compatibility ventions | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | FNSEL | 0xC RW | Function Select | | | Look up Table function | on select | | | | 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 | В | В | | | 11 | NOT_A_OR_B | (!A) OR B | | | 12 | Α | A | | | 13 | A_OR_NOT_B | A OR (!B) | | | 14 | A_OR_B | A OR B | | | 15 | LOGICAL_ONE | Logical 1 | | 15 | Reserved | To ensure compatibility ventions | with future devices, always write bits to 0. More information in 1.2 Con- | | 14:8 | SOURCESEL | 0x0 RW | Source Select | | Bit | Name | Reset | Access | Description | |-----|---------------------|--------------------|---------------|---------------------------------------------------------------------------| | | Select input source | e to async PRS ch | annel. | | | 7:3 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 2:0 | SIGSEL | 0x0 | RW | Signal Select | | | Select signal inpu | t to async PRS cha | innel. | | | | Value | Mode | | Description | | | 0 | NONE | | | | | 0 | NONE | | | ### 13.5.7 PRS\_SYNC\_CHx\_CTRL - Sync Channel Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|-----------|----|---|---|---|---|---|---|---|---|--------|---| | 0x048 | 33 | 99 | 29 | 78 | 27 | 56 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | • | • | | • | | | • | • | • | • | • | • | | | | | 0x0 | | • | | | • | • | • | | | 0x0 | | | Access | | | | | | | | | | | | | | | | | | | | | Z<br>≪ | | | | | | | | | | X<br>≪ | | | Name | | | | | | | | | | | | | | | | | | | | | SOURCESEL | | | | | | | | | | SIGSEL | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:15 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 14:8 | SOURCESEL | 0x0 | RW | Source Select | | | Select input source to sy | nc PRS chan | nel. | | | 7:3 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 2:0 | SIGSEL | 0x0 | RW | Signal Select | | | Select signal input to syr | nc PRS chann | nel. | | #### 13.5.8 PRS\_CONSUMER\_CMU\_CALDN - CMU CALDN Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|----------|-------|---| | 0x058 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | • | • | • | • | • | • | | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | | > | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DDOOD | 11001 | | | Bit | Name | Reset | Access | Description | |------|-----------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CALDN async channel select | | | CALDN async channel s | elect | | | ## 13.5.9 PRS\_CONSUMER\_CMU\_CALUP - CMU CALUP Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|------------|---|---| | 0x05C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | | | | | | | | | | • | | | | | | | • | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | II O O O O | 1 | | | Bit | Name | Reset | Access | Description | |------|-----------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CALUP async channel select | | | CALUP async channel s | elect | | | #### 13.5.10 PRS\_CONSUMER\_IADC0\_SCANTRIGGER - IADC0 SCANTRIGGER Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|-----------------------------------------|---|---|---|---|---|---|-------------------------------------------------|---|---| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | ' | | ' | | | | | | • | • | ' | • | | | | • | • | • | | | Š | 2 | | • | | • | | OXO | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | | N<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | ווויייייייייייייייייייייייייייייייייייי | 2 | | | | | | В. S. S. В. | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | SCAN sync channel select | | | SCAN sync channel sel | ect | | | | 7:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | SCAN async channel select | | | SCAN async channel se | elect | | | #### 13.5.11 PRS\_CONSUMER\_IADC0\_SINGLETRIGGER - IADC0 SINGLETRIGGER Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|---|----------|----------|---|---|---|---|---|--------|---|---| | 0x068 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | | | ' | | | | | 2 | 2 | | | | | | 0×0 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | <u> </u> | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | CDDCCEI | SFRSSEL | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |-------|------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | SINGLE sync channel select | | | SINGLE sync char | nel select | | | | 7:4 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | SINGLE async channel select | | | SINGLE async cha | nnel select | | | #### 13.5.12 PRS\_CONSUMER\_LDMAXBAR\_DMAREQ0 - DMAREQ0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|----------|---|---|----------|---|---| | 0x06C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | ' | | | | | | | | | | | | | | • | | | ' | | ' | | | | | <u>'</u> | | | > | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|----------------------|-------------|-------------------|----------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DMAREQ0 async channel select | | | DMAREQ0 async channe | el select | | | #### 13.5.13 PRS\_CONSUMER\_LDMAXBAR\_DMAREQ1 - DMAREQ1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x070 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|---------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DMAREQ1 async channel select | | | DMAREQ1 async chann | el select | | | #### 13.5.14 PRS\_CONSUMER\_LETIMER0\_CLEAR - LETIMER CLEAR Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------|---|---| | 0x074 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | | • | • | • | | | • | | • | • | • | • | • | | • | • | • | | | | • | | • | | 2 | 8 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | λ<br>Δ | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | D<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|-----------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CLEAR async channel select | | | CLEAR async channel s | elect | | | ## 13.5.15 PRS\_CONSUMER\_LETIMER0\_START - LETIMER START Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|-----------------------------------------|---|---| | 0x078 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | ' | • | • | | • | | | | • | | • | | • | | | • | | • | | • | | | | | OXO | 8 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | T C C C C C C C C C C C C C C C C C C C | | | | Bit | Name | Reset | Access | Description | |------|-----------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | START async channel select | | | START async channel s | elect | | | #### 13.5.16 PRS\_CONSUMER\_LETIMER0\_STOP - LETIMER STOP Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|-----------------------------------------|---|---| | 0x07C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | • | | | | | | • | | • | | | | | | | | | • | • | | | Š | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N<br>N | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | T C C C C C C C C C C C C C C C C C C C | - | | | Bit | Name | Reset | Access | Description | |------|-----------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | STOP async channel select | | | STOP async channel se | lect | | | ## 13.5.17 PRS\_CONSUMER\_EUART0\_RX - EUART0 RX consumer register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x080 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | | | • | • | | • | • | • | | • | • | | • | • | • | • | • | | • | • | | | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | RX async channel select | | | RX async channel select | t | | | #### 13.5.18 PRS\_CONSUMER\_EUART0\_TRIGGER - EUART0 TRIGGER Consumer register | Offset | Bit Position | | |--------|-------------------------------------------------------|---------| | 0x084 | 33 34 55 56 57 58 58 58 58 58 58 58 58 58 58 58 58 58 | 0 7 7 3 | | Reset | | 0×0 | | Access | | RW | | Name | | PRSSEL | | Bit | Name | Reset | Access | Description | |------|----------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | TRIGGER async channel select | | | TRIGGER async channe | l select | | | #### 13.5.19 PRS\_CONSUMER\_MODEM\_DIN - MODEM DIN Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---| | 0x088 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | • | • | • | • | • | | • | | • | | • | | | • | | • | • | • | | • | • | | | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | THE CONTRACT OF O | - | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DIN async channel select | | | DIN async channel selec | ct | | | #### 13.5.20 PRS\_CONSUMER\_RAC\_CLR - RAC CLR Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---------|---| | 0x0C0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | | > | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | \<br>0 | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7 733EF | | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CLR async channel select | | | CLR async channel sele | ct | | | ## 13.5.21 PRS\_CONSUMER\_RAC\_CTIIN0 - RAC CTIIN0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x0C4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | • | | | | | | | | | • | | | | | | | | | | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|------------------------|-----------------------|-----------------|--------------------------------------------------------------------------| | 31:4 | Reserved | To ensure<br>ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel sele | ct | | | #### 13.5.22 PRS\_CONSUMER\_RAC\_CTIIN1 - RAC CTIIN1 Consumer Selection | Offset | Bit Position | | |--------|-----------------------------------------|---------| | 0x0C8 | 30 30 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 | 0 7 7 3 | | Reset | | 0×0 | | Access | | S S | | Name | | PRSSEL | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel selec | ot | | | ## 13.5.23 PRS\_CONSUMER\_RAC\_CTIIN2 - RAC CTIIN2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|---|--------|-------|---| | 0x0CC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | ~ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Č | <br>} | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel selec | ot | | | #### 13.5.24 PRS\_CONSUMER\_RAC\_CTIIN3 - RAC CTIIN3 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---------|---| | 0x0D0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | • | • | • | • | • | | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | | > | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | \<br>0 | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7 733EF | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel selec | t | | | ## 13.5.25 PRS\_CONSUMER\_RAC\_FORCETX - RAC FORCETX Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|------------|---|---| | 0x0D4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | II O O O O | 1 | | | Bit | Name | Reset | Access | Description | |------|---------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | FORCETX async channel select | | | FORCETX async chann | el select | | | #### 13.5.26 PRS\_CONSUMER\_RAC\_RXDIS - RAC RXDIS Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---------|---|---| | 0x0D8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | • | | | | | | | | • | • | | | | | | • | | | | • | • | • | | OX<br>O | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | RXDIS async channel select | | | RXDIS async channel se | elect | | | ## 13.5.27 PRS\_CONSUMER\_RAC\_RXEN - RAC RXEN Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x0DC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | • | • | • | • | • | • | • | • | • | • | • | | • | | | | | • | | • | • | • | | • | • | | | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|-----------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | RXEN async channel select | | | RXEN async channel se | elect | | | #### 13.5.28 PRS\_CONSUMER\_RAC\_SEQ - RAC SEQ Consumer Selection | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|---|---|----------|------|---| | 0x0E0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | | > | 3 | • | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1100 | | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | SEQ async channel select | | | SEQ async channel sele | ect | | | # 13.5.29 PRS\_CONSUMER\_RAC\_TXEN - RAC TXEN Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|---|----------|---|---| | 0x0E4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 9 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | U C | ) | | | Bit | Name | Reset | Access | Description | |------|-----------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | TXEN async channel select | | | TXEN async channel se | lect | | | #### 13.5.30 PRS\_CONSUMER\_RTCC\_CC0 - RTCC CC0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---------|---| | 0x0E8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | • | • | • | • | • | | • | • | • | • | • | • | • | • | • | • | • | • | • | • | | • | | > | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | \<br>0 | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7 733EF | | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC0 async channel select | | | CC0 async channel sele | ct | | | ## 13.5.31 PRS\_CONSUMER\_RTCC\_CC1 - RTCC CC1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x0EC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š. | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC1 async channel select | | | CC1 async channel sele | ct | | | #### 13.5.32 PRS\_CONSUMER\_RTCC\_CC2 - RTCC CC2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|----------|---------|---| | 0x0F0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | • | • | | • | | • | • | | • | • | | • | • | | • | | • | | • | | • | | | > | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7 733EF | | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC2 async channel select | | | CC2 async channel sele | ct | | | ## 13.5.33 PRS\_CONSUMER\_CORE\_CTIIN0 - CTI0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|-----------------------------------------|---|---| | 0x0F8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | • | • | • | • | • | • | • | | • | | | | | • | | • | • | • | | • | • | | | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | T C C C C C C C C C C C C C C C C C C C | - | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel selec | t | | | #### 13.5.34 PRS\_CONSUMER\_CORE\_CTIIN1 - CTI1 Consumer Selection | Offset | Bit Position | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| | 0x0FC | 33 34 37 38 39 30 30 31 32 33 34 35 36 37 47 48 41 41 41 41 41 42 43 44 45 46 47 48 40 40 40 40 40 41 42 43 44 45 46 47 48 49 40 40 40 40 40 40 40 41 42 43 44 45 46 47 48 48 49 40 40 40 40 40 40 40 <th>0 7 2 3</th> | 0 7 2 3 | | Reset | | 0×0 | | Access | | A S | | Name | | PRSSEL | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel selec | t | | | ## 13.5.35 PRS\_CONSUMER\_CORE\_CTIIN2 - CTI2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|----------|---|---| | 0x100 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | | | • | • | | • | • | • | | | • | | • | • | • | • | • | | • | • | | | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u>ک</u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | II O | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel selec | et | | | #### 13.5.36 PRS\_CONSUMER\_CORE\_CTIIN3 - CTI3 Consumer Selection | Offset | Bit Position | | |--------|----------------------------------------------|---------| | 0x104 | 30 30 50 50 50 50 50 50 50 50 50 50 50 50 50 | 0 7 7 3 | | Reset | | 0x0 | | Access | | RW<br>W | | Name | | PRSSEL | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CTI async channel select | | | CTI async channel selec | t | | | ## 13.5.37 PRS\_CONSUMER\_CORE\_M33RXEV - M33 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|------------|---|---| | 0x108 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | = | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | | | | | | • | | | | • | | | | | | | • | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | II O O O O | 1 | | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | M33 async channel select | | | M33 async channel sele | ct | | | #### 13.5.38 PRS\_CONSUMER\_TIMER0\_CC0 - TIMER0 CC0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|-----|--------|-----| | 0x10C | 31 | 30 | 59 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | e . | 7 - | - 0 | | Reset | · | • | | | | | | | | | | | | | | | | | | | | | Ç | S<br>S | | | • | | | 0×0 | · · | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | W. | | | Name | | | | | | | | | | | | | | | | | | | | | | | 0 | SPRSSEL | | | | | | PRSSEL | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC0 sync channel select | | | CC0 sync channel select | : | | | | 7:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC0 async channel select | | | CC0 async channel selection | ct | | | #### 13.5.39 PRS\_CONSUMER\_TIMER0\_CC1 - TIMER0 CC1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|---|----------|----------|---|---|---|---|---|--------|---|---| | 0x110 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | | 0×0 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | <u> </u> | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | CDDCCEI | SFRSSEL | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC1 sync channel select | | | CC1 sync channel selec | t | | | | 7:4 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC1 async channel select | | | CC1 async channel sele | ct | | | #### 13.5.40 PRS\_CONSUMER\_TIMER0\_CC2 - TIMER0 CC2 Consumer Selection | Offset | Bit Position | | | |--------|----------------------------------------|-----------|---------| | 0x114 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 0 8 1 9 4 | e 2 - 0 | | Reset | | 0x0 | 0×0 | | Access | | ₩<br>W | A W | | Name | | SPRSSEL | PRSSEL | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC2 sync channel select | | | CC2 sync channel select | t | | | | 7:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC2 async channel select | | | CC2 async channel sele | ct | | | #### 13.5.41 PRS\_CONSUMER\_TIMER0\_DTI - TIMER0 DTI Consumer Selection | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|--------|---|---| | 0x118 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | :t | | | #### 13.5.42 PRS\_CONSUMER\_TIMER0\_DTIFS1 - TIMER0 DTIFS1 Consumer Selection | Offset | Bit Position | | | | | | | | | | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--|--|--|--|--|--|--|--|--|--| | 0x11C | 30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>4<br>4<br>4<br>4<br>5<br>5<br>5<br>5<br>6<br>5<br>6<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | 0 7 7 3 | | | | | | | | | | | | | Reset | | 0×0 | | | | | | | | | | | | | Access | | A<br>W | | | | | | | | | | | | | Name | | PRSSEL | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | ot . | | | ## 13.5.43 PRS\_CONSUMER\_TIMER0\_DTIFS2 - TIMER0 DTIFS2 Consumer Selection | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----|---|---|---|---|---|---|---|----------|---|---| | 0x120 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | U C | ) | | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | ct | | | #### 13.5.44 PRS\_CONSUMER\_TIMER1\_CC0 - TIMER1 CC0 Consumer Selection | Offset | Bit Position | | | |--------|----------------------------------------------------------|------------------|---------| | 0x124 | 33 34 36 37 38 38 39 39 39 39 39 39 39 39 39 39 39 39 39 | 20 80 1- 00 12 4 | 0 1 2 3 | | Reset | | 0x0 | 0x0 | | Access | | XX XX | RW | | Name | | SPRSSEL | PRSSEL | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC0 sync channel select | | | CC0 sync channel select | : | | | | 7:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC0 async channel select | | | CC0 async channel selection | ct | | | #### 13.5.45 PRS\_CONSUMER\_TIMER1\_CC1 - TIMER1 CC1 Consumer Selection | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|----|---|----|----|---|----|----------|----------|---|---|---|---|---|--------|---|---| | 0x128 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | 3 | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | | 0×0 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | <u>}</u> | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | CDDCCEI | ⊔ | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC1 sync channel select | | | CC1 sync channel selec | t | | | | 7:4 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC1 async channel select | | | CC1 async channel sele | ct | | | #### 13.5.46 PRS\_CONSUMER\_TIMER1\_CC2 - TIMER1 CC2 Consumer Selection | Offset | Bit Position | | | |--------|-----------------------------------------|-------------|---------| | 0x12C | 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | 0 8 1 9 1 4 | 0 7 7 0 | | Reset | | 0x0 | 0x0 | | Access | | WA . | S S | | Name | | SPRSSEL | PRSSEL | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC2 sync channel select | | | CC2 sync channel select | t | | | | 7:4 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC2 async channel select | | | CC2 async channel selec | ct | | | #### 13.5.47 PRS\_CONSUMER\_TIMER1\_DTI - TIMER1 DTI Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---|---| | 0x130 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ÖXO | 8 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | :t | | | #### 13.5.48 PRS\_CONSUMER\_TIMER1\_DTIFS1 - TIMER1 DTIFS1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---|---| | 0x134 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | • | | | | | | | | • | • | • | | 000 | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSEL | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | t | | | ## 13.5.49 PRS\_CONSUMER\_TIMER1\_DTIFS2 - TIMER1 DTIFS2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|---|-------------|---|---| | 0x138 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | G<br>G<br>G | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | ot | | | #### 13.5.50 PRS\_CONSUMER\_TIMER2\_CC0 - TIMER2 CC0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|-----|--------|-----| | 0x13C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | e . | 7 - | - 0 | | Reset | | | | | | • | | | | | | | | | | | | | | | | | Ç | Š | | | • | | | 0×0 | | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | W. | | | Name | | | | | | | | | | | | | | | | | | | | | | | 0 | SPRSSEL | | | | | | PRSSEL | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC0 sync channel select | | | CC0 sync channel select | : | | | | 7:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC0 async channel select | | | CC0 async channel selection | ct | | | #### 13.5.51 PRS\_CONSUMER\_TIMER2\_CC1 - TIMER2 CC1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|----------|----------|---|---|---|---|---|--------|---|---| | 0x140 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | 2 | Š | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | }<br>Ľ | | | | | | Ž | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | CDDCCEI | 00Y<br>L | | | | | | HOO GO | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC1 sync channel select | | | CC1 sync channel select | : | | | | 7:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC1 async channel select | | | CC1 async channel sele | ct | | | #### 13.5.52 PRS\_CONSUMER\_TIMER2\_CC2 - TIMER2 CC2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|---|--------|-----| | 0x144 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 7 | - 0 | | Reset | | • | • | | | | | • | | | | | | | • | • | | | • | | | | Š | e<br>X | | | • | | | 000 | | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | RW | | | Name | | | | | | | | | | | | | | | | | | | | | | | 0 | SPRSSEL | | | | | | PRSSEL | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC2 sync channel select | | | CC2 sync channel select | t | | | | 7:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC2 async channel select | | | CC2 async channel sele | ct | | | #### 13.5.53 PRS\_CONSUMER\_TIMER2\_DTI - TIMER2 DTI Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|-------------|---| | 0x148 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Σ<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSE | ]<br>]<br>) | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | :t | | | #### 13.5.54 PRS\_CONSUMER\_TIMER2\_DTIFS1 - TIMER2 DTIFS1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---|---| | 0x14C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | • | | | | | | | | | | • | • | | | 0×0 | · | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSEL | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | t | | | # 13.5.55 PRS\_CONSUMER\_TIMER2\_DTIFS2 - TIMER2 DTIFS2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x150 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | | | • | | • | • | • | • | | | • | | • | • | • | • | • | | • | | | | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | ct | | | #### 13.5.56 PRS\_CONSUMER\_TIMER3\_CC0 - TIMER3 CC0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|---|--------|-----| | 0x154 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | - 0 | | Reset | | | | • | | • | | | | | | | | | | | | | | | | | Ç | Š | | | • | • | | 0x0 | · | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | RW | | | Name | | | | | | | | | | | | | | | | | | | | | | | 0 | SPRSSEL | | | | | | PRSSEL | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC0 sync channel select | | | CC0 sync channel select | t | | | | 7:4 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC0 async channel select | | | CC0 async channel sele | ct | | | #### 13.5.57 PRS\_CONSUMER\_TIMER3\_CC1 - TIMER3 CC1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|----------|----------|---|---|---|---|---|--------|---|---| | 0x158 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | ' | | | | | 2 | 2 | | | | | | 0×0 | ? | | | Access | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | <u> </u> | | | | | | S<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | CDDCCEI | SFRSSEL | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC1 sync channel select | | | CC1 sync channel selec | t | | | | 7:4 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC1 async channel select | | | CC1 async channel sele | ct | | | #### 13.5.58 PRS\_CONSUMER\_TIMER3\_CC2 - TIMER3 CC2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|---|--------|---|---| | 0x15C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | ' | | ' | | | | • | | ' | • | | | | ' | | | | | Š | Š | | | | • | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | L | SPRSSEL | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC2 sync channel select | | | CC2 sync channel select | : | | | | 7:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC2 async channel select | | | CC2 async channel selection | ct | | | #### 13.5.59 PRS\_CONSUMER\_TIMER3\_DTI - TIMER3 DTI Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---|---| | 0x160 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 000 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | X<br>X | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSEL | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | :t | | | #### 13.5.60 PRS\_CONSUMER\_TIMER3\_DTIFS1 - TIMER3 DTIFS1 Consumer Selection | Offset | Bit Position | | |--------|----------------------------------------------|---------| | 0x164 | 30 30 50 50 50 50 50 50 50 50 50 50 50 50 50 | 0 7 7 3 | | Reset | | 0×0 | | Access | | A<br>W | | Name | | PRSSEL | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | t | | | ## 13.5.61 PRS\_CONSUMER\_TIMER3\_DTIFS2 - TIMER3 DTIFS2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------------|---|---| | 0x168 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | \ <u>\</u> | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | S S S S S S S S S S S S S S S S S S S | ) | | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | ct | | | #### 13.5.62 PRS\_CONSUMER\_TIMER4\_CC0 - TIMER4 CC0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|---|---|---|---|---|--------|-----| | 0x16C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | - 0 | | Reset | | | | • | | • | | | | | | | | | | • | | | | | | | Ç | Š | | | • | • | | 0x0 | · | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | RW | | | Name | | | | | | | | | | | | | | | | | | | | | | | 0 | SPRSSEL | | | | | | PRSSEL | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC0 sync channel select | | | CC0 sync channel select | t | | | | 7:4 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC0 async channel select | | | CC0 async channel sele | ct | | | #### 13.5.63 PRS\_CONSUMER\_TIMER4\_CC1 - TIMER4 CC1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|--------|----------|---|---|---|---|---|--------|---|---| | 0x170 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | ဖ | 2 | 4 | က | 2 | 1 | 0 | | Reset | | • | ' | | | | | | | | | | | • | | | | ' | • | • | | | Š | Š | | ' | ' | • | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | 100000 | ⊔ | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | e compatibility ( | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC1 sync channel select | | | CC1 sync channel selec | t | | | | 7:4 | Reserved | To ensure ventions | e compatibility ( | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC1 async channel select | | | CC1 async channel sele | ct | | | #### 13.5.64 PRS\_CONSUMER\_TIMER4\_CC2 - TIMER4 CC2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---------|---|---|---|---|---|--------|-----| | 0x174 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 7 | - 0 | | Reset | | | | | | | | • | | • | | | | | • | • | | | | | | | Ç | Š | | | • | | | 000 | • | | Access | | | | | | | | | | | | | | | | | | | | | | | 2 | ≥<br>Y | | | | | | Z. | | | Name | | | | | | | | | | | | | | | | | | | | | | | 0 | SPRSSEL | | | | | | PRSSEL | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | SPRSSEL | 0x0 | RW | CC2 sync channel select | | | CC2 sync channel select | t | | | | 7:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CC2 async channel select | | | CC2 async channel sele | ct | | | #### 13.5.65 PRS\_CONSUMER\_TIMER4\_DTI - TIMER4 DTI Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---|---| | 0x178 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ÖXO | 8 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | :t | | | #### 13.5.66 PRS\_CONSUMER\_TIMER4\_DTIFS1 - TIMER4 DTIFS1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|--------|---|---| | 0x17C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | • | • | | • | | | | | | | • | | | | | | | | | | • | • | • | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PRSSE | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | t | | | ## 13.5.67 PRS\_CONSUMER\_TIMER4\_DTIFS2 - TIMER4 DTIFS2 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|-----------------------------------------|---|---| | 0x180 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | • | • | • | • | • | | • | | • | • | • | | • | • | | • | | • | • | • | • | • | | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | T C C C C C C C C C C C C C C C C C C C | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | DTI async channel select | | | DTI async channel selec | t | | | #### 13.5.68 PRS\_CONSUMER\_USART0\_CLK - USART0 CLK Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|----------|--------|---| | 0x184 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | | > | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | } | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DDOOD | T NOOF | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CLK async channel select | | | CLK async channel selec | ot | | | # 13.5.69 PRS\_CONSUMER\_USART0\_IR - USART0 IR Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x188 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | | | • | • | | • | • | • | | • | • | | • | • | • | • | • | | • | • | | | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | IR async channel select | | | IR async channel select | | | | #### 13.5.70 PRS\_CONSUMER\_USART0\_RX - USART0 RX Consumer Selection | Offset | Bit Position | | |--------|----------------------------------------------|---------| | 0x18C | 33 37 38 38 38 38 38 38 38 38 38 38 38 38 38 | 0 7 7 3 | | Reset | | 0×0 | | Access | | S<br>S | | Name | | PRSSEL | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | RX async channel select | | | RX async channel selec | t | | | #### 13.5.71 PRS\_CONSUMER\_USART0\_TRIGGER - USART0 TRIGGER Consumer Selection | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|---------------------------------------|--|--|--|---|--|--|---|--|--|---|---|--|---|---|---|---|---|---|---|---|---|---|--|-------------------------------------------|---|--| | 0x190 | 31 | 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | | | | | | | | | | | | | 4 | က | 2 | _ | 0 | | | | | | | | | | | Reset | | • | | | | • | | | • | | | • | • | | • | • | • | • | | • | • | • | • | • | | 2 | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | χ<br>Δ | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | U. O. | - | | | Bit | Name | Reset | Access | Description | |------|----------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | TRIGGER async channel select | | | TRIGGER async channe | el select | | | #### 13.5.72 PRS\_CONSUMER\_USART1\_CLK - USART1 CLK Consumer Selection | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|--|--|---|--|--|---|--|---|---|---|---|---|---|---|---|---|--|---|--|--|------------------|---------|--| | 0x194 | 31 | 4 4 5 6 6 6 7 7 8 8 8 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 <t< th=""><th>4</th><th>က</th><th>2</th><th>_</th><th>0</th></t<> | | | | | | | | | | | | | 4 | က | 2 | _ | 0 | | | | | | | | | | | | Reset | | | • | • | • | • | | | • | | | • | | • | • | • | • | • | • | • | • | • | | • | | | > | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | 110000<br>110000 | 7 733EF | | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | CLK async channel select | | | CLK async channel sele | ct | | | ## 13.5.73 PRS\_CONSUMER\_USART1\_IR - USART1 IR Consumer Selection | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----|---|---|---|---|---|---|---|-----------------------------------------|---|---| | 0x198 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | | | • | • | | • | • | • | | • | • | | • | • | • | • | • | | • | | | | | OXO | 2 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | \ <u>\</u> | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | T C C C C C C C C C C C C C C C C C C C | - | | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | IR async channel select | | | IR async channel select | | | | ## 13.5.74 PRS\_CONSUMER\_USART1\_RX - USART1 RX Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---| | 0x19C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | • | • | | | • | | • | | | • | | • | | | • | | • | | • | | | | | | OXO | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | THE CONTRACT OF O | - | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | RX async channel select | | | RX async channel select | t | | | # 13.5.75 PRS\_CONSUMER\_USART1\_TRIGGER - USART1 TRIGGER Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------------------------|---|---| | 0x1A0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | • | | | | | | | | | • | | | | • | | | | | | | • | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | H<br>C<br>C<br>C<br>C<br>C<br>C | - | | | Bit | Name | Reset | Access | Description | |------|----------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | TRIGGER async channel select | | | TRIGGER async channe | el select | | | ## 13.5.76 PRS\_CONSUMER\_WDOG0\_SRC0 - WDOG0 SRC0 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|----------|---|---| | 0x1A4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | ' | | | • | | | | | | | | | | | • | | | ' | | ' | | | | | | | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | U C | | | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | SRC0 async channel select | | | SRC0 async channel sel | ect | | | ## 13.5.77 PRS\_CONSUMER\_WDOG0\_SRC1 - WDOG0 SRC1 Consumer Selection | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|-----------------------------------------|---|---| | 0x1A8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 2 | 4 | ဗ | 2 | _ | 0 | | Reset | | • | • | • | • | • | • | • | • | • | • | • | | • | | | | | • | | • | • | • | | • | • | | | | OXO | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | T C C C C C C C C C C C C C C C C C C C | | | | Bit | Name | Reset | Access | Description | |------|-----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | PRSSEL | 0x0 | RW | SRC1 async channel select | | | SRC1 async channel se | elect | | | ### 14. GPCRC - General Purpose Cyclic Redundancy Check #### **Quick Facts** ### What? The GPCRC is an error-detecting module commonly used in digital networks and storage systems to detect accidental changes to data. ### Why? The GPCRC module can detect errors in data, giving a higher system reliability and robustness. #### How? 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 400. 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^0$ 16 term and an $x^0$ 0 term. Theoretically, a 16-bit polynomial has 17 terms total. The convention used is to omit the $x^1$ 6 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$ 0 term, and the least significant bit in CRC\_POLY represents the $x^1$ 15 term. The highest significant bit of CRC\_POLY should always set to 1. The polynomial representation for the CRC-16-CCIT polynomial $x^1$ 6 + $x^1$ 7 + $x^1$ 7 + $x^1$ 7 + $x^2$ 7 + $x^2$ 8 + 1, or 0x8408 in reversed order, is shown in Figure 14.2 Polynomial Representation on page 401. CRC-16-CCITT Normal: 0x1021 Reversed: 0x8408 Figure 14.2. Polynomial Representation ### 14.3.2 Input and Output Specification The CRC input data can be written to the GPCRC\_INPUTDATA, GPCRC\_INPUTDATAHWORD 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 402. 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 403. In this example, 16-bit data is written to GPCRC\_IN-PUTDATAHWORD, BYTEREVERSE is set for byte ordering, and BITREVERSE is set for byte-level bit reversal. 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 403. 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 | 1. X indicates a "don't care". | | | | | | | | | | 2. Bn is the byte field | within the word. | | | | | | | | | | 3. 'Bn is the bit-revers | ed byte field within the word. | | | | | | | | | ## 14.4 GPCRC Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | 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 | R(r)H | CRC Data Register | | 0x028 | GPCRC_DATAREV | R(r)H | CRC Data Reverse Register | | 0x02C | GPCRC_DATABYTEREV | R(r)H | 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_INPUTDATAH-<br>WORD_SET | W | Input 16-bit Data Register | | 0x1020 | GPCRC_INPUTDATA-<br>BYTE_SET | W | Input 8-bit Data Register | | 0x1024 | GPCRC_DATA_SET | R(r)H | CRC Data Register | | 0x1028 | GPCRC_DATAREV_SET | R(r)H | CRC Data Reverse Register | | 0x102C | GPCRC_DATABYTEREV_SET | R(r)H | 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_INPUTDATAH-<br>WORD_CLR | W | Input 16-bit Data Register | | 0x2020 | GPCRC_INPUTDATA-<br>BYTE_CLR | W | Input 8-bit Data Register | | Offset | Name | Туре | Description | |--------|-------------------------------|-------|--------------------------------| | 0x2024 | GPCRC_DATA_CLR | R(r)H | CRC Data Register | | 0x2028 | GPCRC_DATAREV_CLR | R(r)H | CRC Data Reverse Register | | 0x202C | GPCRC_DATABYTEREV_CLR | R(r)H | 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-<br>WORD_TGL | W | Input 16-bit Data Register | | 0x3020 | GPCRC_INPUTDATA-<br>BYTE_TGL | W | Input 8-bit Data Register | | 0x3024 | GPCRC_DATA_TGL | R(r)H | CRC Data Register | | 0x3028 | GPCRC_DATAREV_TGL | R(r)H | CRC Data Reverse Register | | 0x302C | GPCRC_DATABYTEREV_TGL | R(r)H | CRC Data Byte Reverse Register | ## 14.5 GPCRC Register Description # 14.5.1 GPCRC\_IPVERSION - IP Version ID | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|---------------------------------------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | <br>Δ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | INCIO GENERAL | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP Version ID | | | The read only IPVERSIOn modules with different values | • | | this module. There may be minor software changes required for | ## 14.5.2 GPCRC\_EN - CRC Enable | Offset | Bit Position | | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------| | 0x004 | 33 4 5 6 6 7 7 8 8 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 0 | | Reset | | 0x0 | | Access | | A<br>M | | Name | | Z<br>Z | | Bit | Name | Reset | Access | Description | |------|-------------------|-----------------------|-----------------|--------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | CRC Enable | | | The ENABLE bit | onables the module | Software shou | ald write to CONFIG type registers before setting the ENABLE bit. | | | Software should v | write to SYNC type re | | fter setting the ENABLE bit. | | | Software should v | write to SYNC type re | | fter setting the ENABLE bit. Description | | | Software should v | write to SYNC type re | | fter setting the ENABLE bit. | # 14.5.3 GPCRC\_CTRL - Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----------|----|---|-------------|------------|----------|---|---|---|---------|---|---|---|---| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | • | | | | | | • | | | | • | | | 000 | | | 0×0 | 0x0 | 0×0 | | | • | 0x0 | | | | | | Access | | | | | | | | | | | | | | | | | | | ₹ | | | W. | RW | W. | | | | ₩<br>M | | | | | | Name | | | | | | | | | | | | | | | | | | | AUTOINIT | | | BYTEREVERSE | BITREVERSE | BYTEMODE | | | | POLYSEL | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------------|----------------|--------------------|--------------------------------------------------------------------------| | 31:14 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 13 | AUTOINIT | 0x0 | RW | Auto Init Enable | | | Enables auto init by re-se TEREV. | eding the CR | C result based | on the value in INIT after reading of DATA, DATAREV or DATABY- | | 12:11 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 10 | BYTEREVERSE | 0x0 | RW | Byte Reverse Mode | | | Allows byte level reverse | of bytes B3, I | B2, B1, B0 withi | n 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 | Byte-level Bit Reverse Enable | | | Reverses bits within each | byte of the 3 | 2-bit data word | | | | Value | Mode | | Description | | | 0 | NORMAL | | No reverse | | | 1 | REVERSED | ) | Reverse bit order in each byte | | 8 | BYTEMODE | 0x0 | RW | Byte Mode Enable | | | Treats all writes as bytes | Only the leas | st significant byt | e of the data-word will be used for CRC calculation for all writes | | 7:5 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | POLYSEL | 0x0 | RW | Polynomial Select | | | Selects 16-bit CRC progr | ammable pol | ynomial or 32-bi | t 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 | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | # 14.5.4 GPCRC\_CMD - Command Register | Offset | Bit Position | | |--------|-------------------------------------------------|-------| | 0x00C | 3 4 5 2 6 7 8 8 6 7 7 7 7 8 6 6 7 7 8 7 7 8 7 8 | 0 - 2 | | Reset | | 0x0 | | Access | | > | | Name | | LZ | | Bit | Name | Reset | Access | Description | |------|-------------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | INIT | 0x0 | W | Initialization Enable | | | Writing 1 to this bit initial | ize the CRC I | by writing the IN | IT value in CRC_INIT to CRC_DATA. | ## 14.5.5 GPCRC\_INIT - CRC Init Value | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|-------------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | | | | | | | | | | 2 | 3 | • | | • | • | | | | | | | | • | | | | | Access | | | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | Ė | -<br>-<br>- | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|------------------|----------------------------| | 31:0 | INIT | 0x0 | RW | CRC Initialization Value | | | This value is loaded in | to CRC_DATA | A upon issuing t | ne INIT command in CRC_CMD | ## 14.5.6 GPCRC\_POLY - CRC Polynomial Value | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|----------|-------|---|---|---|---|---|---|---| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | œ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | ' | | ' | | • | | | | | | • | ' | | | | | • | | | | | 2 | 2 | | • | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | > | _<br> | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------|--------------------|---------------|---------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | POLY | 0x0 | RW | CRC Polynomial Value | 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 | 30 31 31 32 33 34 35 36 37 38 39 30 31 32 33 34 35 36 37 38 48 48 49 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×0 | | Access | > | | Name | INPUTDATA | | Bit | Name | Reset | Access | Description | |------|--------------------------|-----------------|---------------------|---------------------------------------------------------------| | 31:0 | INPUTDATA | 0x0 | W | Input Data for 32-bit | | | CRC Input 32-bit Data ca | an be written t | to this register. I | Each time this register is written, the CRC value is updated. | ## 14.5.8 GPCRC\_INPUTDATAHWORD - Input 16-bit Data Register | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|--------|----------------|---|---|---|---|---|---|---| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | | | | | | | | | | | | | | • | | • | | | ( | S<br>S | | | • | | | • | | | Access | | | | | | | | | | | | | | | | | | | | | | | | ; | ≥ | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | !<br>! | INPUIDALAHWORD | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | INPUTDATAHWORD | 0x0 | W | Input Data for 16-bit | | | CRC Input 16-bit Data c | an 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 | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|---|---|---|---|---|---|---------------|---|---|---|---| | 0x020 | 31 | 30 | 29 | 78 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0×0 | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | INPUTDATABYTE | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | INPUTDATABYTE | 0x0 | W | Input Data for 8-bit | | | CRC Input 8-bit Data car | n be written to | this register. Ea | ach time this register is written, the CRC value is updated. | ## 14.5.10 GPCRC\_DATA - CRC Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | æ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | 2 | 2 | • | • | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | 7 | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | \<br>\<br>\ | <u> </u> | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------------------------------|-------|--------|----------------------------------------------------------------------| | 31:0 | DATA | 0x0 | R(r) | CRC Data Register | | | CRC Data Register, rear register and then issue a | • | - | r may still be indirectly written from software, by writing the INIT | # 14.5.11 GPCRC\_DATAREV - CRC Data Reverse Register | Offset | Bit Position | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x028 | 33 34 35 36 37 38 38 39 30 30 30 31 32 33 34 45 46 47 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | Reset | 0×0 | | Access | R(r) | | Name | DATAREV | | Bit | Name | Reset | Access | Description | |------|---------|-------|--------|-------------------------------------------------------------------------------------------------------| | 31:0 | DATAREV | 0x0 | R(r) | Data Reverse Value | | | | • | | 2-bit CRC polynomial is selected, the reversal occurs on the entire ed, the bits [15:0] are reversed. | ## 14.5.12 GPCRC\_DATABYTEREV - CRC Data Byte Reverse Register | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | • | • | | | | • | Š | OX O | | • | | | • | • | | | • | | | • | | | | | Access | | | | | | | | | | | | | | | | Š | | | | | | | | | | | | | | | | - | | Name | | | | | | | | | | | | | | | | 7 | - AD | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------|-------|--------|-----------------------------------------------------------------------------------------------------------------| | 31:0 | DATABYTEREV | 0x0 | R(r) | Data Byte Reverse Value | | | , | | 0 | 32-bit CRC polynomial is selected, the bytes are swizzled to {B0, ed, the bytes are swizzled to {0, 0, B0, B1}. | ### 15. RTCC - Real Time Clock with Capture #### **Quick Facts** ### What? The Real Time Clock with Capture (RTCC)) is a 32-bit Real Time Clock ensuring timekeeping in low energy modes. ### Why? Timekeeping over long time periods while using as little power as possible is required in many low power applications. #### How? A low frequency oscillator is used as clock signal and the RTCC has three different Capture/Compare channels which can trigger wake-up, generate PRS signalling, or capture system events. 32-bit resolution and selectable prescaling allow the system to stay in low energy modes for long periods of time and still maintain reliable timekeeping. ### 15.1 Introduction The Real Time Clock with Capture (RTCC), with three capture/compare channels, is a 32-bit counter kept running down to energy mode EM3. It can be used as an EM2/3 wakeup source as well as a timekeeping counter during low energy mode. Time keeping over long time periods while using as little power as possible is required in many low-power applications. The 32-bit counter is in combination with a 15-bit pre-counter to allow flexible pre-scaling of the main counter. Three individually configurable Capture/Compare channels can be used to trigger interrupts, generate PRS signals, capture system events, and to wake the device up from EM2, or EM3 when using the ULFRCO as a clock source. ### 15.2 Features A low frequency oscillator is used as clock signal and the RTCC has three different Capture/Compare channels which can trigger wakeup, generate PRS signalling, or capture system events. 32-bit resolution and selectable pre-scaling 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 or for use as an independent counter - EM2/EM3 operation and wakeup (EM3 when using ULFRCO as clock source) - · Can survive system reset, only POR and EM4 wakeup will reset RTCC - · Three Capture/Compare channels - · Capture of PRS events from other parts of the system, value stored in ICVALUE - · Compare match or input capture can trigger interrupts - Compare channel 1, RTCC\_CC1\_OCVALUE can be used as a top value for the main counter - · Compare channel 0, RTCC CC0 OCVALUE can be used as a top value for the pre-counter - · Compare match events are available to other peripherals through the Peripheral Reflex System (PRS) ### 15.3 Functional Description An overview of the RTCC is shown in Figure 15.1 RTCC Overview on page 415. Figure 15.1. RTCC Overview ### 15.3.1 RTCC Counter The RTCC consists of two counters; the 32-bit main counter, RTCC\_CNT, and a 15-bit pre-counter, RTCC\_PRECNT. The pre-counter can be used as an independent counter, or to generate a specific frequency for the main counter. In both configurations, the pre-counter can be used to generate compare match events or be captured in the Capture/Compare channels as a result of an external PRS event. Refer to Capture/Compare Channels for details on how to configure the Capture/Compare channels for use with the pre-counter. Figure 15.2. RTCC counter Block Diagram The RTCC peripheral clock is requested by setting the EN bit in RTCC\_EN. Then RTCC can be enabled by setting the command register START in RTCC\_CMD. When the RTCC is enabled, the pre-counter (RTCC\_PRECNT) increments upon each positive clock edge of low frequency clock. If CNTTICK in RTCC\_CFG is set to PRESC, the pre-counter will continue to count up, wrapping around to zero when it overflows. If CNTTICK in RTCC\_CFG is set to CCV0MATCH, the pre-counter will wrap around when it hits the value configured in RTCC\_CC0\_OCVALUE. The main counter is available in RTCC\_CNT and increments upon each tick given from the pre-counter. Refer to Normal Mode for a description on how to configure the frequency of these ticks. The main counter can receive a tick based on different dividers from the pre-counter, allowing the ticks to be power of 2 divisions of the LF clock. For more accurate configuration of the tick frequency, RTCC CC0 OCVALUE[14:0] can be used as a top value for RTCC\_PRECNT. When reaching the top value, the main counter receives a tick, and the pre-counter wraps around. Table below shows RTCC Resolution vs Overflow, FLFCLK = 32768 Hz, which summarizes the resolutions available when using a 32768 Hz oscillator as source for LF clock of RTCC. Table 15.1. RTCC Resolution vs Overflow, F<sub>LFCLK</sub> = 32768 Hz | RTCC_CTRL_CNTTICK | RTCC_CTRL_CNTPRESC | Main counter period, T <sub>CNT</sub> | Overflow | |-------------------|--------------------|---------------------------------------------|-------------------------------------------| | CCV0MATCH | Don't care | (RTCC_CC0_OCVALUE + 1)/F <sub>LFCLK</sub> s | 2 <sup>32</sup> *T <sub>CNT</sub> seconds | | RTCC_CTRL_CNTTICK | RTCC_CTRL_CNTPRESC | Main counter period, T <sub>CNT</sub> | Overflow | | | | | |-------------------|--------------------|---------------------------------------|-------------|--|--|--|--| | | 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 | | | | | | PRESC | DIV128 | 3.91 ms | 194 days | | | | | | PRESC | 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, 0xFFFFFFF, before it wraps around and continues counting from zero. By setting CCV1TOP in RTCC\_CFG, a Capture/Compare channel 1 compare match will result in the main counter wrapping to 0. The timer will then wrap around on a channel 1 compare match (RTCC\_CNT = RTCC\_CC1\_OCVALUE). If using the CCV1TOP setting, make sure to set this bit prior to or at the same time the RTCC is enabled. Setting CCV1TOP after enabling the RTCC may cause unintended operation (e.g. if RTCC\_CNT > RTCC\_CC1\_OCVALUE, RTCC\_CNT will wrap when reaching 0xFFFFFFF rather than RTCC\_CC1\_OCVALUE). The counters of the RTCC, RTCC\_CNT and RTCC\_PRECNT, can at any time be written by software, as long as the registers are not locked using RTCC LOCKKEY. All RTCC registers use the new immediate synchronization scheme. **Note:** Writing to the RTCC\_PRECNT register may alter the frequency of the ticks for the RTCC\_CNT register. ### 15.3.2 Capture/Compare Channels Three capture/compare channels are available in the RTCC. Each channel can be configured as input capture or output compare, by setting the corresponding MODE in the RTCC\_CCx\_CTRL register. Figure 15.3. RTCC Compare Match and PRS Output Illustration In input capture mode the RTCC\_CNT register is captured into the RTCC\_CCx\_ICVALUE register when an edge is detected on the selected PRS input channel. The active capture edge is configured in the ICEDGE control bits. In output compare mode the compare values are set by writing to the RTCC compare channel registers RTCC\_CCx\_OCVALUE. These values will be compared to the main counter, RTCC\_CNT or a mixture of the main counter and the pre-counter, as illustrated in Figure 15.4 RTCC Compare Base Illustration on page 419. Compare base for the capture compare channels is set by configuring COMP-BASE in RTCC\_CCx\_CTRL. Figure 15.4. RTCC Compare Base Illustration Table RTCC Capture/Compare subjects summarizes which registers being subject to comparison for different configurations of RTCC\_CTRL\_CNTMODE and RTCC\_CCx\_CTRL\_COMPBASE. Table 15.2. RTCC Capture/Compare subjects | RTCC_CTRL_CNTMODE | NORMAL | |---------------------------------|---------------------------------------------------------| | RTCC_CCx_CTRL_COMPBASE = CNT | RTCC_CNT vs. RTCC_CCx_OCVALUE | | RTCC_CCx_CTRL_COMPBASE = PRECNT | {RTCC_CNT[16:0],RTCC_PRECNT[14:0]} vs. RTCC_CCx_OCVALUE | ### 15.3.3 Interrupts and PRS Output The RTCC has interrupts for each of its 3 Capture/Compare channels (CC0, CC1, and CC2), as well as a counter tick interrupt (CNTTICK) and an overflow interrupt (OF). The counter tick interrupt is set each time the main counter receives a tick, while the overflow interrupt occurs when the main counter overflows. Each Capture/Compare channel has a PRS output with configurable actions upon compare match. The output action is determined by the CMOA field in register RTCC\_CCx\_CTRL. See 13.3.3 Producers for more details on how to connect PRS channels to these outputs. ### 15.3.4 Register Lock To prevent accidental writes to the RTCC registers, the RTCC\_LOCK register can be written to any other value than the unlock value. To unlock the register, write the unlock value to RTCC\_LOCKKEY. Registers affected by this lock are: - · RTCC CFG - RTCC EN - RTCC\_CMD - RTCC PRECNT - RTCC\_CNT - RTCC\_CCx\_CTRL - RTCC\_CCx\_OCVALUE - RTCC CCx ICVALUE ### 15.3.5 Programmer's Model The registers of RTCC can be divided into a few groups as below, CFG: config registers EN: enable register to make the peripheral clock available to RTCC CTRL: control or other registers can be programmed during run CMD: command registers to start/stop RTCC running STATUS: read only status registers Generally speaking, in order to use and program RTCC properly, it should follow the sequence below, Set CFG->Set EN->Set CTRL->START CMD->adjust CTRL->STOP CMD All the registers have been separated into different synchronization types. The CFG register is WSTATIC, which means only when EN=0, it will allow the programming of CFG, otherwise there will be a bus fault for the CFG register write. Here is an example of programming CFG prior to setting EN to 1. ``` RTCC->CC[0].OCVALUE = 2; RTCC->CC[0].CTRL = RTCC_CC_CTRL_CC_MODE_OUTPUTCOMPARE; RTCC->CC[0].OCVALUE = 5; RTCC->EN = RTCC_EN_EN; ``` All the other registers with low frequency synchronization types need to be programmed after setting EN to 1. Counter will only start to count once START command is issued. For LFRWSYNC registers, user needs to keep polling sync busy, e.g. START, before programming the same register once again. ``` // Bang on start till it's running do { RTCC->CMD = RTCC_CMD_START; while(RTCC->SYNCBUSY & _RTCC_SYNCBUSY_MASK); } while ( (RTCC->STATUS & _RTCC_STATUS_RUNNING_MASK) != RTCC_STATUS_RUNNING ); ``` For QUICKLFWSYNC registers, when writing to it, the write will stall the bus until the write action is completed, so there is no sync busy bit for those registers, RTCC\_CCn\_CTRL is an example for that. ### 15.3.6 Debug Features and Description By default, the RTCC is halted when code execution is halted from the debugger. By setting the DEBUGRUN bit in the RTCC\_CTRL register, the RTCC will continue to run even when the debugger has halted the system. ## 15.4 RTCC Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|----------------------|-------------|---------------------------------------| | 0x000 | RTCC_IPVERSION | R | IP VERSION | | 0x004 | RTCC_EN | RW ENABLE | Module Enable Register | | 0x008 | RTCC_CFG | RW CONFIG | Configuration Register | | 0x00C | RTCC_CMD | W LFSYNC | Command Register | | 0x010 | RTCC_STATUS | RH | Status register | | 0x014 | RTCC_IF | RWH INTFLAG | RTCC Interrupt Flags | | 0x018 | RTCC_IEN | RW | Interrupt Enable Register | | 0x01C | RTCC_PRECNT | RWH LFSYNC | Pre-Counter Value Register | | 0x020 | RTCC_CNT | RWH LFSYNC | Counter Value Register | | 0x024 | RTCC_COMBCNT | RH | Combined Pre-Counter and Counter Valu | | 0x028 | RTCC_SYNCBUSY | RH | Synchronization Busy Register | | 0x02C | RTCC_LOCK | W | Configuration Lock Register | | 0x030 | RTCC_CCx_CTRL | RW | CC Channel Control Register | | 0x034 | RTCC_CCx_OCVALUE | RW | Output Compare Value Register | | 0x038 | RTCC_CCx_ICVALUE | RH | Input Capture Value Register | | 0x1000 | RTCC_IPVERSION_SET | R | IP VERSION | | 0x1004 | RTCC_EN_SET | RW ENABLE | Module Enable Register | | 0x1008 | RTCC_CFG_SET | RW CONFIG | Configuration Register | | 0x100C | RTCC_CMD_SET | W LFSYNC | Command Register | | 0x1010 | RTCC_STATUS_SET | RH | Status register | | 0x1014 | RTCC_IF_SET | RWH INTFLAG | RTCC Interrupt Flags | | 0x1018 | RTCC_IEN_SET | RW | Interrupt Enable Register | | 0x101C | RTCC_PRECNT_SET | RWH LFSYNC | Pre-Counter Value Register | | 0x1020 | RTCC_CNT_SET | RWH LFSYNC | Counter Value Register | | 0x1024 | RTCC_COMBCNT_SET | RH | Combined Pre-Counter and Counter Valu | | 0x1028 | RTCC_SYNCBUSY_SET | RH | Synchronization Busy Register | | 0x102C | RTCC_LOCK_SET | W | Configuration Lock Register | | 0x1030 | RTCC_CCx_CTRL_SET | RW | CC Channel Control Register | | 0x1034 | RTCC_CCx_OCVALUE_SET | RW | Output Compare Value Register | | 0x1038 | RTCC_CCx_ICVALUE_SET | RH | Input Capture Value Register | | 0x2000 | RTCC_IPVERSION_CLR | R | IP VERSION | | 0x2004 | RTCC_EN_CLR | RW ENABLE | Module Enable Register | | 0x2008 | RTCC_CFG_CLR | RW CONFIG | Configuration Register | | 0x200C | RTCC_CMD_CLR | W LFSYNC | Command Register | | 0x2010 | RTCC_STATUS_CLR | RH | Status register | | Offset | Name | Туре | Description | |--------|----------------------|-------------|---------------------------------------| | 0x2014 | RTCC_IF_CLR | RWH INTFLAG | RTCC Interrupt Flags | | 0x2018 | RTCC_IEN_CLR | RW | Interrupt Enable Register | | 0x201C | RTCC_PRECNT_CLR | RWH LFSYNC | Pre-Counter Value Register | | 0x2020 | RTCC_CNT_CLR | RWH LFSYNC | Counter Value Register | | 0x2024 | RTCC_COMBCNT_CLR | RH | Combined Pre-Counter and Counter Valu | | 0x2028 | RTCC_SYNCBUSY_CLR | RH | Synchronization Busy Register | | 0x202C | RTCC_LOCK_CLR | W | Configuration Lock Register | | 0x2030 | RTCC_CCx_CTRL_CLR | RW | CC Channel Control Register | | 0x2034 | RTCC_CCx_OCVALUE_CLR | RW | Output Compare Value Register | | 0x2038 | RTCC_CCx_ICVALUE_CLR | RH | Input Capture Value Register | | 0x3000 | RTCC_IPVERSION_TGL | R | IP VERSION | | 0x3004 | RTCC_EN_TGL | RW ENABLE | Module Enable Register | | 0x3008 | RTCC_CFG_TGL | RW CONFIG | Configuration Register | | 0x300C | RTCC_CMD_TGL | W LFSYNC | Command Register | | 0x3010 | RTCC_STATUS_TGL | RH | Status register | | 0x3014 | RTCC_IF_TGL | RWH INTFLAG | RTCC Interrupt Flags | | 0x3018 | RTCC_IEN_TGL | RW | Interrupt Enable Register | | 0x301C | RTCC_PRECNT_TGL | RWH LFSYNC | Pre-Counter Value Register | | 0x3020 | RTCC_CNT_TGL | RWH LFSYNC | Counter Value Register | | 0x3024 | RTCC_COMBCNT_TGL | RH | Combined Pre-Counter and Counter Valu | | 0x3028 | RTCC_SYNCBUSY_TGL | RH | Synchronization Busy Register | | 0x302C | RTCC_LOCK_TGL | w | Configuration Lock Register | | 0x3030 | RTCC_CCx_CTRL_TGL | RW | CC Channel Control Register | | 0x3034 | RTCC_CCx_OCVALUE_TGL | RW | Output Compare Value Register | | 0x3038 | RTCC_CCx_ICVALUE_TGL | RH | Input Capture Value Register | ## 15.5 RTCC Register Description ## 15.5.1 RTCC\_IPVERSION - IP VERSION | Offset | Bit Position | |--------|--------------| | 0x000 | 33 | | Reset | 0×1 | | Access | α | | Name | IPVERSION | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------|-------|--------|------------------------------------------------------------------| | 31:0 | IPVERSION | 0x1 | R | IP VERSION | | | The read only IPVE modules with different | | | or this module. There may be minor software changes required for | ## 15.5.2 RTCC\_EN - Module Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|--------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | • | | • | | | | | | | | | | | | | • | | | | | | | | | • | | • | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z | | Bit | Name | Reset | Access | Description | |------|----------|-------------|--------------------|--------------------------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility witl | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | RTCC Enable | | | | | | d write to CONFIG type registers before setting the ENABLE bit. er setting the ENABLE bit. | ## 15.5.3 RTCC\_CFG - Configuration Register | Offset | Bit Position | | | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------|---------------------------| | 0x008 | 33 34 35 36 37 38 39 30 30 30 30 30 30 30 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>7 6 6</th> <th>2 3</th> <th>- 0</th> | 7 6 6 | 2 3 | - 0 | | Reset | | 0×0 | 000 | 000 | | Access | | RW | RW WW | RW RW | | Name | | CNTPRESC | CNTTICK<br>CNTCCV1TOP | PRECNTCCV0TOP<br>DEBUGRUN | | Bit | Name | Reset Access | Description | | | | | | | | | | |------|---------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:8 | Reserved | To ensure compatibility ventions | ty with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 7:4 | CNTPRESC | 0x0 RW | Counter prescaler value. | | | | | | | | | | | | Configure counting frequency of the CNT register. | | | | | | | | | | | | | | Value | Mode | Description | | | | | | | | | | | | 0 | DIV1 | CLK_CNT = (RTCC LF CLK)/1 | | | | | | | | | | | | 1 | DIV2 | CLK_CNT = (RTCC LF CLK)/2 | | | | | | | | | | | | 2 | DIV4 | CLK_CNT = (RTCC LF CLK)/4 | | | | | | | | | | | | 3 | DIV8 | CLK_CNT = (RTCC LF CLK)/8 | | | | | | | | | | | | 4 | DIV16 | CLK_CNT = (RTCC LF CLK)/16 | | | | | | | | | | | | 5 | DIV32 | CLK_CNT = (RTCC LF CLK)/32 | | | | | | | | | | | | 6 | DIV64 | CLK_CNT = (RTCC LF CLK)/64 | | | | | | | | | | | | 7 | DIV128 | CLK_CNT = (RTCC LF CLK)/128 | | | | | | | | | | | | 8 | DIV256 | CLK_CNT = (RTCC LF CLK)/256 | | | | | | | | | | | | 9 | DIV512 | CLK_CNT = (RTCC LF CLK)/512 | | | | | | | | | | | | 10 | DIV1024 | CLK_CNT = (RTCC LF CLK)/1024 | | | | | | | | | | | | 11 | DIV2048 | CLK_CNT = (RTCC LF CLK)/2048 | | | | | | | | | | | | 12 | DIV4096 | CLK_CNT = (RTCC LF CLK)/4096 | | | | | | | | | | | | 13 | DIV8192 | CLK_CNT = (RTCC LF CLK)/8192 | | | | | | | | | | | | 14 | DIV16384 | CLK_CNT = (RTCC LF CLK)/16384 | | | | | | | | | | | | 15 | DIV32768 | CLK_CNT = (RTCC LF CLK)/32768 | | | | | | | | | | | 3 | CNTTICK | 0x0 RW | Counter prescaler mode. | | | | | | | | | | | | | | RTCC_CC0_OCVALUE[14:0] compare match with the pre-counter or tick field in the RTCC_CTRL register. | | | | | | | | | | Description CNT register ticks according to configuration in CNTPRESC. Mode **PRESC** Value 0 | Bit | Name | Reset | Access | Description | |-----|--------------------------|----------------|------------------|----------------------------------------------------------| | | 1 | CCV0MA | TCH | CNT register ticks when PRECNT matches RTCC_CC0_OC[14:0] | | 2 | CNTCCV1TOP | 0x0 | RW | CCV1 top value enable | | | When set, the counter | wraps around | d on a CC1 even | t | | 1 | PRECNTCCV0TOP | 0x0 | RW | Pre-counter CCV0 top value enable. | | | When set, the pre-cour | nter wraps ard | ound when PRE | CNT equals RTCC_CC0_OCVALUE[14:0]. | | 0 | DEBUGRUN | 0x0 | RW | Debug Mode Run Enable | | | Set this bit to keep the | RTCC runnin | ig during a debu | g halt. | | | Value | Mode | | Description | | | 0 | X0 | | RTCC is frozen in debug mode | | | 1 | X1 | | RTCC is running in debug mode | # 15.5.4 RTCC\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|-------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | • | • | | • | | • | | • | | • | | • | | | • | • | • | | | | | | | • | | | 0x0 | 0×0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | STOP | START | | Bit | Name | Reset | Access | Description | |------|--------------------------|--------------------|-------------------|--------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | e compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 1 | STOP | 0x0 | W | Stop RTCC main counter | | | Write a 1 to stop the R | TCC | | | | 0 | START | 0x0 | W | Start RTCC main counter | | | Write a 1 to start the R | TCC | | | # 15.5.5 RTCC\_STATUS - Status register | Offset | Bit Position | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | 0x010 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>- 0</th> | - 0 | | Reset | | 000 | | Access | | <u>د</u> د | | Name | | RTCCLOCKSTATUS<br>RUNNING | | Bit | Name | Reset | Access | Description | |------|---------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | RTCCLOCKSTATUS | 0x0 | R | Lock Status | | | Indicates the current sta | itus of RTCC | Lock | | | | Value | Mode | | Description | | | 0 | UNLOCKE | D | RTCC registers are unlocked | | | 1 | LOCKED | | RTCC registers are locked | | 0 | RUNNING | 0x0 | R | RTCC running status | | | Indicates the current sta | tus of RTCC | running | | ## 15.5.6 RTCC\_IF - RTCC Interrupt Flags | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|-----|---|--------|---|-----|---|---|---------|-----| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | ' | | | • | ' | | | | • | • | • | ' | | | | • | | | | | | 0X0 | | 0X0 | | 000 | | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | Σ | | S<br>S | | Z. | | | ₩<br>M | Z. | | Name | | | | | | | | | | | | | | | | | | | | | | | | CC2 | | CC1 | | 000 | | | CNTTICK | OF | | Bit | Name | Reset | Access | Description | |------|-----------------------------|-----------------|--------------------|----------------------------------------------------------------------| | 31:9 | Reserved | | | future devices, always write bits to 0. More information in 1.2 Con- | | 07.0 | 7.0007.700 | ventions | ompationity with | ratare devises, amaye time site to a misro membratary in 112 com | | 8 | CC2 | 0x0 | RW | CC Channel n Interrupt Flag | | | This bit indicates that the | ere has been a | an interrupt ever | t on Compare/Capture channel | | 7 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 6 | CC1 | 0x0 | RW | CC Channel n Interrupt Flag | | | This bit indicates that the | ere has been a | an interrupt ever | nt on Compare/Capture channel | | 5 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | CC0 | 0x0 | RW | CC Channel n Interrupt Flag | | | This bit indicates that the | ere has been a | an interrupt ever | nt on Compare/Capture channel | | 3:2 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 1 | CNTTICK | 0x0 | RW | Main counter tick | | | Set each time the main of | counter is upda | ated. | | | 0 | OF | 0x0 | RW | Overflow Interrupt Flag | | | Set when a RTCC overfl | ow has occur | red. | | ## 15.5.7 RTCC\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|--------|---|-----|---|-----|---|---|---------|-----| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | တ | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | | | • | • | • | | • | • | | | | • | | | • | | | 000 | | 0X0 | | 0x0 | | • | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | | Z. | | RW | | | ₩<br>M | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | CC2 | | CC1 | | 000 | | | CNTTICK | OF | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|-------------------|----------------------------------------------------------------------| | 31:9 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 8 | CC2 | 0x0 | RW | CC Channel n Interrupt Enable | | | Enable CC channel inter | rupts | | | | 7 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 6 | CC1 | 0x0 | RW | CC Channel n Interrupt Enable | | | Enable CC channel inter | rupts | | | | 5 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | CC0 | 0x0 | RW | CC Channel n Interrupt Enable | | | Enable CC channel inter | rupts | | | | 3:2 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 1 | CNTTICK | 0x0 | RW | CNTTICK Interrupt Enable | | | Enable cnttick interrupt | | | | | 0 | OF | 0x0 | RW | OF Interrupt Enable | | | Enable overflow interrup | t | | | ## 15.5.8 RTCC\_PRECNT - Pre-Counter Value Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|--------|---|---|---|---|---|---|---| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | 0×0 | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | RW | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | PRECNT | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:15 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 14:0 | PRECNT | 0x0 | RW | Pre-Counter Value | | | Gives access to the Pre- | counter value | of the RTCC. | | # 15.5.9 RTCC\_CNT - Counter Value Register | Offset | Bit Position | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x020 | 33 34 4 5 6 6 6 7 7 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 <tr< th=""></tr<> | | Reset | ОХО | | Access | R | | Name | ON | | Bit | Name | Reset | Access | Description | |------|-------------------------|---------------|--------|---------------| | 31:0 | CNT | 0x0 | RW | Counter Value | | | Gives access to the mai | n counter val | | | ## 15.5.10 RTCC\_COMBCNT - Combined Pre-Counter and Counter Valu... | Offset | Bit Position | | | | | | | | | | |--------|----------------------------------------------------------------------------------|---------------------------------|--|--|--|--|--|--|--|--| | 0x024 | 31<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30 | 0 1 2 3 4 5 6 7 8 8 7 9 9 7 7 9 | | | | | | | | | | Reset | o xo | 0×0 | | | | | | | | | | Access | <b>~</b> | <u>«</u> | | | | | | | | | | Name | CNTLSB | PRECNT | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------|-----------------|-------------------| | 31:15 | CNTLSB | 0x0 | R | Counter Value | | | Gives access to the 17 L | SBs of the m | ain counter, CN | т. | | 14:0 | PRECNT | 0x0 | R | Pre-Counter Value | | | Gives access to the pre- | counter, PRE | CNT. | | # 15.5.11 RTCC\_SYNCBUSY - Synchronization Busy Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|-----|--------|------|-------| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | • | | | | • | | • | • | • | | • | | | | | • | | | | 0x0 | 0×0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ~ | Я | ~ | œ | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CNT | PRECNT | STOP | START | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3 | CNT | 0x0 | R | Sync busy for CNT | | | Last writing of CNT is sy | nchronizing to | LF clock | | | 2 | PRECNT | 0x0 | R | Sync busy for PRECNT | | | Last writing of PRECNT | is synchroniz | ing to LF clock | | | 1 | STOP | 0x0 | R | Sync busy for STOP | | | Last writing of STOP is s | synchronizing | to LF clock | | | 0 | START | 0x0 | R | Sync busy for START | | | Last writing of START is | synchronizin | g to LF clock | | # 15.5.12 RTCC\_LOCK - Configuration Lock Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----------|--------|---|---|---|---|---|---|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | • | | • | • | | • | | • | | | | | | | • | | | Š | OX O | | | • | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | I<br>L | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------|--------------------|---------------|---------------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0x0 | W | Configuration Lock Key | | | | | | RTCC_CFG, RTCC_EN, RTCC_CMD, RTCC_PRECNT, RTCC_CNT e the unlock code to unlock. | | | Value | Mode | , | Description | | | 44776 | UNLOCK | | Write to unlock RTCC lockable registers | # 15.5.13 RTCC\_CCx\_CTRL - CC Channel Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|----------|----------|----------|---|------|---| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | ' | | | | | | • | | | | | | | | | • | | | | | • | 2 | Š | 0x0 | > | 2 | 0x0 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | RW | <u>ک</u> | 2 | ΑŠ | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | ICEDGE | COMPBASE | AOM O | | MODE | | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|-----------------|-------------------------------------------------------------------------------| | 31:7 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 6:5 | ICEDGE | 0x0 | RW | Input Capture Edge Select | | | These bits control w | vhich edges the F | PRS edge detec | ctor triggers on. | | | Value | Mode | | Description | | | 0 | RISING | | Rising edges detected | | | 1 | FALLING | | Falling edges detected | | | 2 | вотн | | Both edges detected | | | 3 | NONE | | No edge detection, signal is left as it is | | 4 | COMPBASE | 0x0 | RW | Capture compare channel comparison base. | | | Configure comparis | on base for comp | pare channel. | | | | Value | Mode | | Description | | | 0 | CNT | | RTCC_CCx_ICVALUE/OCVALUE is compared with CNT register. | | | 1 | PRECNT | | Least significant bits of RTCC_CCx_ICVALUE/OCVALUE are compared with COMBCNT. | | 3:2 | СМОА | 0x0 | RW | Compare Match Output Action | | | Select output action | n on compare ma | tch. | | | | Value | Mode | | Description | | | 0 | PULSE | | A single clock cycle pulse is generated on output | | | 1 | TOGGLE | | Toggle output on compare match | | | 2 | CLEAR | | Clear output on compare match | | | 3 | SET | | Set output on compare match | | 1:0 | MODE | 0x0 | RW | CC Channel Mode | | | These bits select th | e mode for Comp | oare/Capture ch | nannel. | | | Value | Mode | | Description | | | 0 | OFF | | Compare/Capture channel turned off | | Bit | Name | Reset Access | Description | |-----|------|---------------|----------------| | | 1 | INPUTCAPTURE | Input capture | | | 2 | OUTPUTCOMPARE | Output compare | # 15.5.14 RTCC\_CCx\_OCVALUE - Output Compare Value Register | Offset | Bit Position | | | | | | | | | | | | |--------|----------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x034 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | | | | | | | | | | | | | Reset | 0×0 | | | | | | | | | | | | | Access | | | | | | | | | | | | | | Name | o<br>O | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-----------------------|----------------|--------|----------------------| | 31:0 | OC | 0x0 RW | | Output Compare Value | | | Shows the Compare Val | ue for the cha | annel | | # 15.5.15 RTCC\_CCx\_ICVALUE - Input Capture Value Register | Offset | Bit Position | | | | | | | | | | | | |--------|-----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x038 | 0 1 2 3 4 5 2 6 7 8 8 8 7 9 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | Reset | 0×0 | | | | | | | | | | | | | Access | <u> </u> | | | | | | | | | | | | | Name | <u> </u> | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|------------------------|----------------|--------|---------------------| | 31:0 | IC | 0x0 | R | Input Capture Value | | | Shows the Capture Valu | e for the char | nnel | | # 16. BURTC - Back-Up Real Time Counter ### **Quick Facts** ## What? The BURTC is a 32 bit counter which operates on a low frequency oscillator, and is capable of running in all Energy Modes. ## Why? 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. ## How? 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 435. 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 EM4GRPACLKCTRL.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 BURTC can be enabled by setting the command register START in BURTC\_CMD. When the BURTC is enabled 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 bitfiled 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 436 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, FBURTCCLK = 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 2 interrupts: one for Overflow and another for 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 | Туре | 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 | RW LFSYNC | Pre-Counter Value Register | | 0x020 | BURTC_CNT | RW 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 | RW LFSYNC | Pre-Counter Value Register | | 0x1020 | BURTC_CNT_SET | RW 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 | RW LFSYNC | Pre-Counter Value Register | | 0x2020 | BURTC_CNT_CLR | RW LFSYNC | Counter Value Register | | Offset | Name | Туре | 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 | RW LFSYNC | Pre-Counter Value Register | | 0x3020 | BURTC_CNT_TGL | RW 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 | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|----------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------|---|--|--|--|--|--|--|--|--| | 0x000 | 31 | 31 31 32 33 34 35 35 36 37 36 37 37 37 37 37 37 37 37 37 37 37 37 37 | | | | | | | | | | | | | | 0 | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | 2 | 3 | | | | | | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | Name | | | | | | | | | | | | | | | | INCIDED/(GI | > | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP Version ID | | | The read only IPVERSIOn modules with different values | • | | this module. There may be minor software changes required for | # 16.5.2 BURTC\_EN - Module Enable Register | Offset | Bit Position | | |--------|------------------------------------------|-----| | 0x004 | 33 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | 0 | | Reset | | 0x0 | | Access | | RW | | Name | | EN | | Bit | Name | Reset | Access | Description | | | | | | | | |------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------|--|--|--|--|--|--|--| | 31:1 | Reserved | To ensure o | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 0 | EN | 0x0 | RW | BURTC Enable | | | | | | | | | | | the module. Software should write to CONFIG type registers before setting the ENABLE bit. SYNC type registers only after setting the ENABLE bit. | | | | | | | | | | # 16.5.3 BURTC\_CFG - Configuration Register | Offset | Bit Position | | | | |--------|--------------------------------------------------------------------------------------------|-------------------|---|---------| | 0x008 | 31<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 | 7 6 4 | 3 | - 0 | | Reset | | 0×0 | | 000 | | Access | | RW | | W W | | Name | | CNTPRESC | | COMPTOP | | Bit | Name | Reset | Access | Description | |------|--------------------|----------------------|-------------------|---------------------------------------------------------------------------| | 31:8 | Reserved | To ensur<br>ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 7:4 | CNTPRESC | 0x0 | RW | Counter prescaler value. | | | 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 | 4 | CLK_CNT = (BURTC LF CLK)/16384 | | | 15 | DIV32768 | 3 | CLK_CNT = (BURTC LF CLK)/32768 | | 3:2 | Reserved | To ensur | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1 | COMPTOP | 0x0 | RW | Compare Channel is Top Value | | | When set, the cour | nter 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 (0xFFFFFFF) | | Bit | Name | Reset | Access | Description | |-----|-----------------------|------------------|-----------------|---------------------------------------------| | | 1 | ENABLE | | The top value of the BURTC is given by COMP | | 0 | DEBUGRUN | 0x0 | RW | Debug Mode Run Enable | | | Set this bit to enabl | e the BURTC to I | keep running in | debug | | | Value | Mode | | Description | | | 0 | DISABLE | | BURTC is frozen in debug mode | | | 1 | ENABLE | | BURTC is running in debug mode | | | | | | | # 16.5.4 BURTC\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|-------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | • | • | | • | • | • | • | | • | | • | • | • | • | • | | | • | | • | | | | • | • | • | | • | • | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | × | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | STOP | START | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------|--------------------|------------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1 | STOP | 0x0 | W | Stop BURTC counter | | | Write a 1 to stop the to same register wh | | er. Differs from | SLOWLFWSYNC behavior in that multiple writes cannot be queued up | | 0 | START | 0x0 | W | Start BURTC counter | | | Write a 1 to start the up to same register | | er. Differs from | SLOWLFWSYNC behavior in that multiple writes cannot be queued | # 16.5.5 BURTC\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|---------| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ~ | 2 | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LOCK | RUNNING | | Bit | Name | Reset | Access | Description | |------|---------------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | LOCK | 0x0 | R | Configuration Lock Status | | | Indicates the current sta | tus of BURTC | Lock | | | | Value | Mode | | Description | | | 0 | UNLOCKE | ) | All BURTC lockable registers are unlocked. | | | 1 | LOCKED | | All BURTC lockable registers are locked. | | 0 | RUNNING | 0x0 | R | BURTC running status | | | Indicates the current sta | tus of BURTC | running | | # 16.5.6 BURTC\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------|-----| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | | | | | | | | | | • | | | | | | | | | | | • | | • | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | W<br>W | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | COMP | OF | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | COMP | 0x0 | RW | Compare Match Interrupt Flag | | | Set on a compare match | between CN | Γ and COMP. | | | 0 | OF | 0x0 | RW | Overflow Interrupt Flag | | | Set on a CNT value over | flow. | | | # 16.5.7 BURTC\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Ві | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|-----| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | • | • | • | | | | | • | | | • | | • | | | | • | | • | | • | • | | | • | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | R | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | COMP | OF | | Bit | Name | Reset | Access | Description | |------|---------------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | COMP | 0x0 | RW | Compare Match Interrupt Flag | | | Set to enable the COMP | IF Interrupt | | | | 0 | OF | 0x0 | RW | Overflow Interrupt Flag | | | Set to enable the OFIF In | nterrupt | | | # 16.5.8 BURTC\_PRECNT - Pre-Counter Value Register | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|--------|---|---|---|---|---|---|---| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 0 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | 0x0 | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>N | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | PRECNT | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:15 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 14:0 | PRECNT | 0x0 | RW | Pre-Counter Value | | | Gives access to the Pre-<br>cannot be queued up to s | | | Differs from SLOWLFRWSYNC behavior in that multiple writes | # 16.5.9 BURTC\_CNT - Counter Value Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|----------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | | • | • | | | | | | | | | 2 | 2 | | | | | | | | | • | • | • | • | • | | | | Access | | | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | F | 5 | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | CNT | 0x0 | RW | Counter Value | | | Gives access to the could be queued up to same re | | | ers from SLOWLFRWSYNC behavior in that multiple writes cannot | # 16.5.10 BURTC\_EM4WUEN - EM4 wakeup request Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------|-----------| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | | | | | | | | | • | • | | | | • | | | | | • | • | | • | • | | | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | ₩<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | COMPEM4WUEN | OFEM4WUEN | | Bit | Name | Reset | Access | Description | |------|-----------------------|---------------|-------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | COMPEM4WUEN | 0x0 | RW | Compare Match EM4 Wakeup Enable | | | Compare Match EM4 wa | keup request | s. No Synchron | ization done into peripheral clock domain. | | 0 | OFEM4WUEN | 0x0 | RW | Overflow EM4 Wakeup Enable | | | Overflow EM4 Wakeup r | equest. No Sy | nchronization o | lone into peripheral clock domain. | # 16.5.11 BURTC\_SYNCBUSY - Synchronization Busy Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---------|------|-----|----------|------|-------| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | • | | | | • | | • | | | • | | • | | | | | | • | • | • | 0X0 | 0×0 | 0x0 | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | 22 | Я | ~ | <u>~</u> | 22 | ~ | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | N<br>EN | COMP | CNT | PRECNT | STOP | START | | Bit | Name | Reset | Access | Description | |------|----------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | EN | 0x0 | R | Sync busy for EN | | | Last writing of EN is synd | chronizing to | BURTC clock | | | 4 | COMP | 0x0 | R | Sync busy for COMP | | | Last writing of COMP is | synchronizing | to BURTC cloc | k | | 3 | CNT | 0x0 | R | Sync busy for CNT | | | Last writing of CNT is sy | nchronizing to | BURTC clock | | | 2 | PRECNT | 0x0 | R | Sync busy for PRECNT | | | Last writing of PRECNT | is synchroniz | ing to BURTC cl | ock | | 1 | STOP | 0x0 | R | Sync busy for STOP | | | Last writing of STOP is s | ynchronizing | to BURTC clock | S. | | 0 | START | 0x0 | R | Sync busy for START | | | Last writing of START is | synchronizin | g to BURTC cloc | ck | # 16.5.12 BURTC\_LOCK - Configuration Lock Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---------|---|---|---|---|---|---|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | • | L | UXAEE8 | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | 3 | > | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | ) | LOCKNEY | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------|-------------|-----------------|----------------------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility и | vith future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0xAEE8 | W | Configuration Lock Key | | | | | | BURTC_EN, BURTC_CFG, BURTC_CMD, BURTC_PRECNT, diting. 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 | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | | | • | | | | | | | | • | Š | OXO | • | | | | | | | | | | • | | | | | | Access | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | COMP | 0x0 | RW | Compare Value | | | · · | | | to this value. This event sets the COMP interrupt flag. It is also avail-IC behavior in that multiple writes cannot be queued up to same reg- | # 17. BURAM - Backup RAM ### **Quick Facts** ## What? The BURAM is a dedicated 128-byte low-power RAM that is retained in EM4. ## Why? 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. ### How? 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 | Туре | 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<br>32<br>33<br>34<br>35<br>36<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37 | | | | | | | | | | | | | | | Reset | | 0×0 | | | | | | | | | | | | | | Access | | R | | | | | | | | | | | | | | Name | | RETREG RM | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |------|-------------------------------------------------|-------|------------------|------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:0 | RETREG | 0x0 | RW | Latch based Retention register | | | | | | | | | | The RETREG registers a than a brownout or power | | out of reset. An | y written RETREG values will be retained through any event other | | | | | | | | # 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 RTCC. ### How? With buffered repeat and top value registers, the LE-TIMER can provide glitch-free waveforms at frequencies up to 16 kHz. It can be coupled with RTCC 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 RTCC. 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 451. 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\_REP0 allows the timer to count a specified number of times before it stops. Both the LETIMERn\_TOP and LETIMERn\_REP0 registers can be double buffered by the LETIMERn\_TOPBUFF and LETIMERn\_REP1 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 0xFFFFFF. 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 0xFFFFFF 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 452. 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 LETI-MERn_REP0 != 0. LETIMERn_REP0 is decremented at each timer underflow. | | 0b10 | Buffered | The timer runs as long as LETI-MERn_REP0 != 0. LETIMERn_REP0 is decremented on each timer underflow. If LETIMERn_REP1 has been written with Non zero value, then it is loaded into LETIMERn_REP0 when LETIMERn_REP0 is about to be decremented to 0 and Timer countinue counting with new LETI-MERn_REP0. | | 0b11 | Double | The timer runs as long as LETI-MERn_REP0 != 0 or LETIMERn_REP1 != 0. Both LETIMERn_REP0 and LETI-MERn_REP1 are decremented at each timer underflow. | The interrupt flags REP0 and REP1 in LETIMERn\_IF are set whenever LETIMERn\_REP0 or LETIMERn\_REP1 are decremented to 0 respectively. REP0 is also set when the value of LETIMERn REP1 is loaded into LETIMERn REP0 in buffered mode. Write operations to LETIMERn REP0 have priority over buffer loads from LETIMERn REP1. ## · 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\_REP0 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 453. 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 0xFFFFFF. 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\_REP0 is decremented every time the timer underflows, and the timer stops when LETIMERn\_REP0 goes from 1 to 0. In this mode, the timer counts down LETIMERn REP0 times, i.e. the timer underflows LETIMERn REP0 times. **Note:** Note that write operations to LETIMERn\_REP0 have priority over the timer decrement event. If LETIMERn\_REP0 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\_REP0 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\_REP0 should be done after checking SYNC busy statusFigure 18.3 LETIMER One-shot Repeat State Machine on page 454. 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\_REP0 number of times. If LETI-MERn\_REP1 has been written since the last time it was used and if it is nonzero, LETIMERn\_REP1 is then loaded into LETI-MERn\_REP0, and counting continues the new number of times. The timer keeps going as long as LETIMERn\_REP1 is updated with a nonzero value before LETIMERn\_REP0 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\_REP0 are zero but LETIMERn\_REP1 is non-zero, LETIMERn\_REP1 is loaded into LETIMERn REP0, 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 455. REP1<sub>USED</sub> shown in the state machine is an internal variable that keeps track of whether the value in LETIMERn\_REP1 has been loaded into LETIMERn\_REP0 or not. The purpose of this is that a value written to LETIMERn\_REP1 should only be counted once. REP1<sub>USED</sub> is cleared whenever LETIMERn\_REP1 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\_REP0 is larger than 0, the double mode counts as long as either LETIMERn\_REP0 or LETIMERn\_REP1 is larger than 0. As an example, say LETIMERn\_REP0 is 3 and LETIMERn\_REP1 is 10 when the timer is started. If no further interaction is done with the timer, LETIMERn\_REP0 will now be decremented 3 times, and LETIMERn\_REP1 will be decremented 10 times. The timer counts a total of 10 times, and LETIMERn\_REP0 is 0 after the first three timer underflows and stays at 0. LETIMERn\_REP0 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 456. Figure 18.5. LETIMER Double Repeat State Machine ## 18.4 Clock Frequency The LETIMER clock source (EM23GRPACLK) 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 457. EM0/1/2 - Clocked by LFRCO $f_{LETIMERn\_CLK} = 32768/2^{CNTPRESC}$ EM3 - Clocked by ULFRCO f<sub>LETIMERn\_CLK</sub> = 1024/2<sup>CNTPRESC</sup> 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 458. 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\_LETIMER\_CLEAR, PRS\_LETIMER\_START, and PRS\_LETIMER\_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 459. 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 makesure 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 clearing CMU\_LFCLKSEL\_LFA and setting CMU\_LFCLKSEL\_LFAE to 1. This will make the RTCC use the internal 1 kHz ultra low frequency RC oscillator (ULFRCO), consuming very little energy. Please note that the ULFRCO is not accurate over temperature and voltage, and it should be verified that the ULFRCO fulfills the timekeeping needs of the application before using this in the design. ## 18.11 Register access This module is a Low Energy Peripheral, and supports immediate synchronization. For description regarding immediate synchronization, the reader is referred to the ../../EFR32XG22-RM/EFR32XG22\_xrefkeys.dita#xrefs/peripheral\_access section. Since this module is a Low Energy Peripheral, and runs off a clock which is asynchronous to the HFCORECLK, 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 461. In this example, REPMODE 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(LETIMERn\_TOP + 1), and for the pulse modes, the periods of the output signals are 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 462. 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\_REP0 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\_REP0 times. By using LETIMERn\_REP0 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 462. 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\_REP0 respectiverly. If both LETIMERn\_TOP and LETIMERn\_REP0 are 0 in buffered mode, and CNTTOPEN and BUFTOP in LETIMERn\_CTRL are set, the values of LETIMERn\_TOPBUFF and LETIMERn\_REP1 are loaded into LETIMERn\_TOP and LETIMERn\_REP0 respectively when the timer is started. If no additional writes to LETIMERn\_REP1 are done before the timer stops, LETIMERn\_REP1 determines the number of pulses/toggles generated on the output, and LETIMERn\_TOPBUFF determines the period lengths. As the RTCC can also be used via PRS to start the LETIMER, the RTCC and LETIMER can thus be combined to generate specific pulse-trains at given intervals. Software can update LETIMERn\_TOPBUFF and LETIMERn\_REP1 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 463, 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 461, 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 464, 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\_REP0 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\_REP1 is set to 4. The LETIMER is set to trigger an interrupt when LETIMERn\_REP0 is done by setting REP0 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 464. 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 464 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 465shows 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 LETI-MERn\_TOP. # 18.13 LETIMER Register Map The offset register address is relative to the registers base address. | 0x000 LETIMER_IPVERSION 0x004 LETIMER_EN 0x008 LETIMER_CTRL 0x00C LETIMER_CMD 0x010 LETIMER_STATUS | R RW ENABLE RW W LFSYNC RH RWH LFSYNC RW | IP version module en Control Register Command Register Status Register Counter Value Register | |--------------------------------------------------------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------------| | 0x008 LETIMER_CTRL 0x00C LETIMER_CMD 0x010 LETIMER_STATUS | RW W LFSYNC RH RWH LFSYNC | Control Register Command Register Status Register Counter Value Register | | 0x00C LETIMER_CMD 0x010 LETIMER_STATUS | W LFSYNC RH RWH LFSYNC | Command Register Status Register Counter Value Register | | 0x010 LETIMER_STATUS | RH<br>RWH LFSYNC | Status Register Counter Value Register | | _ | RWH LFSYNC | Counter Value Register | | | | · · · · · · · · · · · · · · · · · · · | | 0x018 LETIMER_CNT | RW | | | 0x01C LETIMER_COMP0 | | 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 | | 0x040 LETIMER_SYNCBUSY | RH | Synchronization Busy Register | | 0x050 LETIMER_PRSMODE | RW | PRS Input mode select Register | | 0x1000 LETIMER_IPVERSION_SE | T R | IP version | | 0x1004 LETIMER_EN_SET | RW ENABLE | module en | | 0x1008 LETIMER_CTRL_SET | RW | Control Register | | 0x100C LETIMER_CMD_SET | W LFSYNC | Command Register | | 0x1010 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 | | 0x1040 LETIMER_SYNCBUSY_SE | T RH | Synchronization Busy Register | | 0x1050 LETIMER_PRSMODE_SE | T RW | PRS Input mode select Register | | 0x2000 LETIMER_IPVERSION_CL | R R | IP version | | 0x2004 LETIMER_EN_CLR | RW ENABLE | module en | | 0x2008 LETIMER_CTRL_CLR | RW | Control Register | | Offset | Name | Туре | Description | |--------|-----------------------|-------------|--------------------------------| | 0x200C | LETIMER_CMD_CLR | W LFSYNC | Command Register | | 0x2010 | 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 | | 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_CTRL_TGL | RW | Control Register | | 0x300C | LETIMER_CMD_TGL | W LFSYNC | Command Register | | 0x3010 | 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 | | 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 | Offset | Bit Position | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 0x000 | 30 30 30 31 31 32 32 32 32 33 30 31 31 31 32 33 30 31 31 31 31 31 31 31 31 31 31 31 31 31 | | | | | | | | | | | | Reset | 0X0 | | | | | | | | | | | | Access | α | | | | | | | | | | | | Name | IPVERSION | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP Version | | | The read only IPVERSIO modules with different va | • | | this module. There may be minor software changes required for | # 18.14.2 LETIMER\_EN - module en | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|---|----|----|----|---|----|----|---|----|---|---|---|---|---|---|---|---|---|-------------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | | • | | | | | | | | | | • | | | | | | | | | • | | • | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>E<br>N | | Bit | Name | Reset | Access | Description | | | | | | |------|----------|-------------|--------------------|--------------------------------------------------------------------------------------------|--|--|--|--|--| | 31:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 0 | EN | 0x0 | 0x0 RW module en | | | | | | | | | | | | d write to CONFIG type registers before setting the ENABLE bit. er setting the ENABLE bit. | | | | | | ## 18.14.3 LETIMER\_CTRL - Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|------|--------|----------|----|---------|----------|--------|-------|-------|---|---|---------|--------|---------|---|-----| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ω | 7 | 9 | 2 | 4 | 3 | 2 | - 0 | | Reset | | | | | | | | | • | • | | Š | OXO | • | | | | 000 | | | 000 | 0X0 | 0x0 | 000 | Ş | 2 | 2 | 2 | 0x0 | | | | Access | | | | | | | | | | | 2 | <u>}</u> | | | | | \<br>N | | | RW<br>W | W. | S. | Z. | 2 | 2 | Š | ^ | R<br>W | | | | | Name | | | | | | | | | | | | | ON THE PROPERTY OF PROPERT | | | | | DEBUGRUN | | | CNTTOPEN | BUFTOP | OPOL1 | OPOL0 | 7 | 5 | IEO A O | ) | REPMODE | | | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | CNTPRESC | 0x0 | RW | Counter prescaler value | | | 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 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 12 | DEBUGRUN | 0x0 | RW | Debug Mode Run Enable | | | Set to keep the LET | TIMER 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 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 9 | CNTTOPEN | 0x0 | RW | Compare Value 0 Is Top Value | | | When set, TOP value | ue will be used as | Counter Top | √alue | | | 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 COMP0 | | 8 | BUFTOP | 0x0 | RW | Buffered Top | | | Set to load TOPBL | JFF into TOP whe | n REP0 reache | s 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 | Output 1 Polarity | | | Defines the idle va | lue of output 1. | | | | 6 | OPOL0 | 0x0 | RW | Output 0 Polarity | | | Defines the idle va | lue of output 0. | | | | 5:4 | UFOA1 | 0x0 | RW | Underflow Output Action 1 | | | Defines the action | on OUT1 on a LE | TIMER underflo | w - 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 | Underflow Output Action 0 | | | Defines the action | on OUT0 on a LE | TIMER underflo | w - IDLE/TOGGLE/PULSE/PWM | | | Value | Mode | | Description | | | 0 | NONE | | LETIMERn_OUT0 is held at its idle value as defined by OPOL0 | | | 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 OPOL0 | | | 3 | PWM | | LETIMERn_OUT0 is set idle on CNT underflow, and active on compare match with COMP1 | | 1:0 | REPMODE | 0x0 | RW | Repeat Mode | | | Repeat Mode - FR | EE/ONESHOT/BU | JFFERED/DOU | BLE | | | Value | Mode | | Description | | | 0 | FREE | | When started, the LETIMER counts down until it is stopped by software | | | 1 | ONESHO | Т | 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.4 LETIMER\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|------|------|-------|------|-------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | | | | | | | | • | • | | | | | | | | | | • | | • | 0x0 | 0x0 | 0×0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | > | M | > | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | СТО1 | СТОО | CLEAR | STOP | START | | Bit | Name | Reset | Access | Description | |------|----------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 4 | CTO1 | 0x0 | W | Clear Toggle Output 1 | | | Set to drive toggle output | t 1 to its idle | /alue | | | 3 | CTO0 | 0x0 | W | Clear Toggle Output 0 | | | Set to drive toggle output | t 0 to its idle | /alue | | | 2 | CLEAR | 0x0 | W | Clear LETIMER | | | Set to clear LETIMER | | | | | 1 | STOP | 0x0 | W | Stop LETIMER | | | Set to stop LETIMER | | | | | 0 | START | 0x0 | W | Start LETIMER | | | Set to start LETIMER | | | | | | | | | | ## 18.14.5 LETIMER\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---------| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RUNNING | | Bit | Name | Reset | Access | Description | |------|------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | RUNNING | 0x0 | R | LETIMER Running | | | Set when LETIMER is ru | ınning. | | | # 18.14.6 LETIMER\_CNT - Counter Value Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | 2 | Š | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | Ė | 5 | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:24 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 23:0 | CNT | 0x0 | RW | Counter Value | | | Use to read the current v | alue of the Li | ETIMER. | | ## 18.14.7 LETIMER\_COMP0 - Compare Value Register 0 | Offset | Bit Position | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x01C | 31 31 32 33 34 35 36 36 36 36 36 36 36 36 36 36 36 36 36 | | Reset | 0×0 | | Access | R<br>Marian Marian Marian<br>Marian Marian Manda Marian Marian Marian Marian Marian Marian Marian Marian Maria | | Name | COMPO | | Bit | Name | Reset | Access | Description | |-------|------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:24 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 23:0 | COMP0 | 0x0 | RW | Compare Value 0 | | | Compare value for LETI | MER. | | | # 18.14.8 LETIMER\_COMP1 - Compare Value Register 1 | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----------|---------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | 0 | 040 | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | LOMO C | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:24 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 23:0 | COMP1 | 0x0 | RW | Compare Value 1 | | | Compare and optionally | buffered top | value for LETIM | ER. | ## 18.14.9 LETIMER\_TOP - Counter TOP Value Register | Offset | Bit Position | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x024 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Reset | 000 | | Access | RW | | Name | TOP | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------|-------------------|------------------------------------------------------------------------| | 31:24 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 23:0 | TOP | 0x0 | RW | Counter TOP Value | | | TOP will be used as Cou | unter TOP Va | lue if CNTTOPE | N is set to 1 | # 18.14.10 LETIMER\_TOPBUFF - Buffered Counter TOP Value | Offset | Bit Position | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x028 | 33 34 5 5 6 7 7 8 8 8 7 7 9 8 7 7 9 8 7 7 9 8 8 7 9 9 8 7 9 9 9 9 | | Reset | 0×0 | | Access | \text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tin}\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\ti}\tint{\text{\text{\text{\text{\text{\tin}\tint{\text{\text{\ti}\tint{\text{\text{\text{\texi}\tinz{\text{\texit{\text{\texi}\tint{\text{\texi}\tint{\text{\texi}\tint{\text{\texi}\tinz}\tint{\texittt{\text{\texi}\tint{\text{\tint}\text{\texit{\text{ | | Name | TOPBUFF | | Bit | Name | Reset | Access | Description | |-------|------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:24 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 23:0 | TOPBUFF | 0x0 | RW | Buffered Counter TOP Value | | | TOPBUFF will be used a | as Counter TO | OP Value in BUF | FFERED Mode if CNTTOPEN and BUFFTOP is set set to 1 | ## 18.14.11 LETIMER\_REP0 - Repeat Counter Register 0 | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|--------------|---|---|---|-------------|-------------|---|---|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | ' | | | 1 | | | | | ' | | | <u>'</u> | | ' | • | | | | | | | | | Š | Š | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | ≥<br>Y | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | ר<br>ב<br>ב | Х<br>П<br>Г | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | REP0 | 0x0 | RW | Repeat Counter 0 | | | Optional repeat counter. | | | | # 18.14.12 LETIMER\_REP1 - Repeat Counter Register 1 | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|--------|----------|---|---|---| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | | • | | • | • | | • | | • | | | | • | • | • | | • | | | | | | | | | | Š | )<br>X | • | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | ר<br>ה | ፓ<br>ከ | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | REP1 | 0x0 | RW | Repeat Counter 1 | | | Optional repeat counter of | or buffer for R | EP0. | | ## 18.14.13 LETIMER\_IF - Interrupt Flag Register | Offset | Bit Position | | | | |--------|--------------------------------------------------|-------|-----|-------| | 0x034 | 33 31<br>30 30 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 | 4 ر | 2 د | - 0 | | Reset | | 0 0 0 | 2 2 | 000 | | Access | | W 9 | ¥ 8 | W W | | Name | | REP1 | ጉ | COMP1 | | Bit | Name | Reset | Access | Description | |------|-------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 4 | REP1 | 0x0 | RW | Repeat Counter 1 Interrupt Flag | | | Set when repeat counter | 1 reaches ze | ero. | | | 3 | REP0 | 0x0 | RW | Repeat Counter 0 Interrupt Flag | | | Set when repeat counter | 0 reaches ze | ero or when the | REP1 interrupt flag is loaded into the REP0 interrupt flag. | | 2 | UF | 0x0 | RW | Underflow Interrupt Flag | | | Set on LETIMER underfl | ow. | | | | 1 | COMP1 | 0x0 | RW | Compare Match 1 Interrupt Flag | | | Set when LETIMER read | ches the value | e of COMP1. | | | 0 | COMP0 | 0x0 | RW | Compare Match 0 Interrupt Flag | | | Set when LETIMER read | ches the value | e of COMP0. | | # 18.14.14 LETIMER\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|------|--------|-----|-------|-------| | 0x038 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | • | | • | • | | | | • | • | • | • | • | • | • | | • | • | • | | • | | | 0x0 | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₽ | ₩<br>M | RW | ₽ | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | REP1 | REP0 | H. | COMP1 | COMPO | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 4 | REP1 | 0x0 | RW | Repeat Counter 1 Interrupt Enable | | | Repeat Counter 1 Interru | upt Enable | | | | 3 | REP0 | 0x0 | RW | Repeat Counter 0 Interrupt Enable | | | Repeat Counter 0 Interru | upt Enable | | | | 2 | UF | 0x0 | RW | Underflow Interrupt Enable | | | Underflow Interrupt Enal | ole | | | | 1 | COMP1 | 0x0 | RW | Compare Match 1 Interrupt Enable | | | Compare Match 1 Interru | upt Enable | | | | 0 | COMP0 | 0x0 | RW | Compare Match 0 Interrupt Enable | | | Compare Match 0 Interru | upt Enable | | | # 18.14.15 LETIMER\_SYNCBUSY - Synchronization Busy Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|------|------|-------|------|-------|------|------|-----|---|-----| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | | | | | | • | | | | | • | | • | • | | • | • | 000 | 000 | 000 | 000 | 000 | 000 | 000 | 0x0 | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | œ | œ | œ | œ | œ | œ | œ | œ | | 2 | | Name | | | | | | | | | | | | | | | | | | | | | | | СТО1 | СТОО | CLEAR | STOP | START | REP1 | REP0 | TOP | | CNT | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 9 | CTO1 | 0x0 | R | Sync busy for CTO1 | | | Sync busy for CTO1 | | | | | 8 | CTO0 | 0x0 | R | Sync busy for CTO0 | | | Sync busy for CTO0 | | | | | 7 | CLEAR | 0x0 | R | Sync busy for CLEAR | | | Sync busy for CLEAR | | | | | 6 | STOP | 0x0 | R | Sync busy for STOP | | | Sync busy for STOP | | | | | 5 | START | 0x0 | R | Sync busy for START | | | Sync busy for START | | | | | 4 | REP1 | 0x0 | R | Sync busy for REP1 | | | Sync busy for REP1 | | | | | 3 | REP0 | 0x0 | R | Sync busy for REP0 | | | Sync busy for REP0 | | | | | 2 | TOP | 0x0 | R | Sync busy for TOP | | | Sync busy for TOP | | | | | 1 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | CNT | 0x0 | R | Sync busy for CNT | | | Sync busy for CNT | | | | ## 18.14.16 LETIMER\_PRSMODE - PRS Input mode select Register | Offset | | | | Bit Position | |--------|-------------|----------------------|----------------|-------------------------------------------------| | 0x050 | 30 30 28 28 | 27<br>26<br>25<br>24 | 23 23 24 20 20 | 0 1 2 3 4 4 7 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Reset | | 0x0 | 0x0 | 0X0 | | Access | | XW. | AN N | S S S S S S S S S S S S S S S S S S S | | Name | | PRSCLEARMODE | PRSSTOPMODE | PRSSTARTMODE | | Bit | Name | Reset | Access | Description | |-------|--------------------|--------------------|--------------------|---------------------------------------------------------------------------------| | 31:28 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 27:26 | PRSCLEARMODE | 0x0 | RW | PRS Clear Mode | | | Mode-NONE/RISING/F | ALLING/BOTH | 4 | | | | 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 the rising or falling edge of the selected PRS input can clear the LETIMER | | 25:24 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 23:22 | PRSSTOPMODE | 0x0 | RW | PRS Stop Mode | | | Mode-NONE/RISING/F | FALLING/BOTH | 4 | | | | 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 the rising or falling edge of the selected PRS input can stop the LETIMER | | 21:20 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 19:18 | PRSSTARTMODE | 0x0 | RW | PRS Start Mode | | | Mode-NONE/RISING/F | FALLING/BOTH | 4 | | | | 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 the rising or falling edge of the selected PRS input can start the LETIMER | | 17:0 | Reserved | To ensure compatibili | ty with future devices, always write bits to 0. More information in 1.2 Con- | ### 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 - HFPERCLKTIMERn - · 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 483 and it consists of a 16/32 bit up/down counter with 3 compare/capture channels connected to pins TIMn CC0, TIMn CC1, and TIMn CC2. 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 (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 (TIMERn\_EN\_EN = 1). A typical setup sequence for a TIMER module is as follows: - 1. With the TIMER disabled (TIMERn\_EN\_EN = 0), program any CONFIG registers required for the application. - 2. Enable the TIMER by setting EN in TIMERn EN to 1. - 3. Program any non-CONFIG registers required for the application. - 4. 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 485 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 485. Figure 19.3. TIMER Clock Selection ## 19.3.2.4 Peripheral Clock The peripheral clock for the timer (HFPERCLK<sub>TIMERn</sub>) 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 (HFPERCLK<sub>TIMERn</sub>). The peripheral clock to each timer can be used as a source with a configurable 10-bit prescaler. The PRESC bitfield in TIMERn\_CFG sets the prescaler value, and the incoming peripheral clock will be divided by a factor of (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 TIMn\_CC1 pin or one of the PRS channels. The input signal must not have a higher frequency than f<sub>HFPERCLK\_TIMERn</sub>/3 when running from a pin input or a PRS input with FILT enabled in TIMERn\_CCx\_CFG. When running from PRS without FILT, the frequency can be as high as f<sub>HFPERCLK\_TIMERn</sub>. Note that when clocking the timer from the same pulse that triggers a start (through RISEA/FALLA in 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 486), 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 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 487). **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 488). 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. Figure 19.6. TIMER Quadrature Encoded Inputs 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 488 #### 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 489 and Figure 19.8 TIMER X2 Decoding Mode on page 489. Table 19.1. TIMER Counter Response in X2 Decoding Mode | Channel B | Channel A | | | | | | | | | | |--------------|-----------|-----------|--|--|--|--|--|--|--|--| | Citatillei B | 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 489 and Table 19.2 TIMER Counter Response in X4 Decoding Mode on page 489. Table 19.2. TIMER Counter Response in X4 Decoding Mode | Opposite Channel | Chan | nel A | Chan | nnel 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 490 can be used. $$pos^{\circ} = (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 490). 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 aynchronous 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 HFPERCLK<sub>TIMERn</sub> clock cycles. An additional 5 HFPERCLK<sub>TIMERn</sub> 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 HFPERCLK<sub>TIMERn</sub>, this mode requires at least 3 HFPERCLK<sub>TIMERn</sub> 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 HFPERCLK<sub>TIMERn</sub> 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 491). 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 (ICFUF 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 inTIMERn\_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 492. 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 493. 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 494. 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 495) 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 495 $$f_{FRG} = f_{HFPERCLK\_TIMERn} / [2 x (PRESC + 1) x (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 496). 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 496. Figure 19.20. TIMER Up-count PWM Generation $$R_{PWM_{UD}} = log(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 496: $$f_{PWM_{IID}} = f_{HFPERCLK\ TIMERn} / [(PRESC + 1) x (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 496 $$DS_{up} = OCx/(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 497 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 497. $R_{PWM_{2xmode}} = log(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 497: $f_{PWM_{2xmode}} = f_{HFPERCLK TIMERn} / [(PRESC + 1) x (floor(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 497 $DS_{2xmode} = OCx/((floor(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 498. The resolution (in bits) is given by Figure 19.30 TIMER Up/Down-count PWM Resolution Equation on page 498. 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 498: 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 498 $$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 499 Figure 19.34. TIMER CC out in 2x mode Figure 19.35 TIMER 2x PWM Resolution Equation on page 499. $R_{PWM_{2xmode}} = log(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 499: f<sub>PWM2xmode</sub> = f<sub>HFPERCLK</sub> TIMERn/ (2 x (PRESC + 1) x (floor(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 499 and Figure 19.38 TIMER 2x Mode Duty Cycle Equation for all other OCx = odd values on page 499 $DS_{2xmode} = (OCx*2)/(floor(TOP/2)*4)$ Figure 19.37. TIMER 2x Mode Duty Cycle Equation for OCx = 1 or OCx = even $DS_{2xmode} = (OCx*2 - OCx)/(floor(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 synchrous 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 HFPERCLK<sub>TIMERn</sub> 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 501. 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 501). 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 502. Figure 19.41. TIMER Overview of Dead-Time Insertion Block for a Single PWM channel The DTI unit is enabled by setting DTEN in TIMERO\_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 502. 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 TIMERO\_DTFCFG register to the safe values and set the DTFATS bitfield in the TIMERO\_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 TIMERO\_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 503. 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 TIMERO\_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 TIMERO\_DTCFG will override the source of the first DTI channel, driving TIMO\_CC0 and TIMO\_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 TIMERO\_DTCFG. When this bit is set, it uses DTPRESC=0 regardless of the value programmed in DTPRESC in TIMERO\_DTTI-MECFG. **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\_CON-SUMER\_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\_DTCFG 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\_DTFCFG, TIMER0\_DTCTRL, 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 HFPERCLK<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 505. 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 | Туре | 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 | R(r)H | 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 | Туре | 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 | R(r)H | 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_DTFAULTC_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 | R(r)H | 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 | Туре | 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_DTFAULTC_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 | R(r)H | 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_DTFAULTC_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 | 33 34 36 37 38 39 30 30 30 31 32 33 34 35 36 37 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | | | | | | | | | | | | | | | Reset | 0×0 | | | | | | | | | | | | | | | | Access | α | | | | | | | | | | | | | | | | Name | IPVERSION | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------|-------|--------|------------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP Version ID | | | The read only IPVE modules with different | • | | or this module. There may be minor software changes required for | #### 19.5.2 TIMER\_CFG - Configuration Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|-------|----|----|----|----|----|----|----|----|---|----|------|------|----|----|-----------|------------|----------|----------|----------|-----------|----------|-----|-------|--------|---|------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | ' | | 0×0 | | | | | | | | | | | | | | • | 0X0 | 0x0 | 0X0 | ć | S<br>S | 0X0 | 000 | 000 | 0×0 | 000 | | 0x0 | | Access | | | | | | | | | 2 | Š | | | | | W. | Z. | | | | ₩<br>M | RW | W. | ć | <u>}</u> | RW | W. | W. | W. | ₩<br>M | | RW | | Name | | | | | PRESC | | | | | | | | | | | АТІ | | | | RETIMESEL | DISSYNCOUT | RETIMEEN | <u> </u> | CLKSEL | DMACLRACT | DEBUGRUN | QDM | OSMEN | SYNC | | MODE | | Bit | Name | Reset | Access | Description | |-------|----------|--------------------|---------------|---------------------------------------------------------------------------| | 31:28 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 27:18 | PRESC | 0x0 | RW | Prescaler Setting | 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 | Reload-Start Sets COIST | | | | | | | | | When enabled, com | pare output is s | et to COIST v | alue on a Reload-Start event. | | | | | | | | 16 | ATI | 0x0 | RW | Always Track Inputs | | | | | | | | | Enabling ATI makes | CCPOL always | s track the pol | arity of the inputs. | | | | | | | | 15:13 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 12 | RETIMESEL | 0x0 | RW | PWM output retime select | | | | | | | | | | | | vill be re-timed to synchronize edges with radio clocks and reduce RF ock jutter between PWM outputs. | | | | | | | | 11 | DISSYNCOUT | 0x0 | RW | Disable Timer Start/Stop/Reload output | | | | | | | | | When this bit is set, | the Timer does | not start/stop/ | oad 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 | PWM output retimed enable | | | | | | | | | | | | Enable retiming of P | WM output. | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | 0 | DISABLE | | PWM outputs are not re-timed. | | | | | | | | | | | | 1 | ENABLE | | PWM outputs are re-timed. | | | | | | | | | | | ):8 | CLKSEL | 0x0 | RW | Clock Source Select | | | | | | | | | | | | These bits select the | e clock source fo | r the timer. | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | 0 | PRESCE | M01GRPACLK | Prescaled EM01GRPACLK | | | | | | | | | | | | 1 | CC1 | | Compare/Capture Channel 1 Input | | | | | | | | | | | | 2 | TIMEROU | IF | Timer is clocked by underflow(down-count) or overflow(up-count) in the lower numbered neighbor Timer | | | | | | | | | | | , | DMACLRACT | 0x0 | RW | DMA Request Clear on Active | | | | | | | | | | | | When this bit is set, timer DMA requests | | | hen the corresponding DMA channel is active. This enables the the timer. | | | | | | | | | | | 6 | DEBUGRUN | 0x0 | RW | Debug Mode Run Enable | | | | | | | | | | | | Set this bit to enable | timer to run in c | lebug mode. | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | 0 | HALT | | Times is helted in debug mede | | | | | | | | | | | | · · | | | Timer is halted in debug mode | | | | | | | | | | | | 1 | RUN | | Timer is running in debug mode Timer is running in debug mode | | | | | | | | | | | 5 | | | RW | | | | | | | | | | | | 5 | 1 | RUN<br>0x0 | | Timer is running in debug mode | | | | | | | | | | | 5 | 1<br>QDM | RUN<br>0x0 | | Timer is running in debug mode | | | | | | | | | | | 5 | QDM This bit sets the mod | RUN 0x0 de for the quadra | | Timer is running in debug mode Quadrature Decoder Mode Selection | | | | | | | | | | | ; | QDM This bit sets the mod | RUN 0x0 de for the quadra Mode | | Timer is running in debug mode Quadrature Decoder Mode Selection Description | | | | | | | | | | | | QDM This bit sets the mod Value 0 | RUN 0x0 de for the quadra Mode X2 | | Timer is running in debug mode Quadrature Decoder Mode Selection Description X2 mode selected | | | | | | | | | | | | QDM This bit sets the mod Value 0 1 | RUN 0x0 de for the quadra Mode X2 X4 0x0 | ature decoder. | Timer is running in debug mode Quadrature Decoder Mode Selection Description X2 mode selected X4 mode selected | | | | | | | | | | | 4 | QDM This bit sets the mod Value 0 1 OSMEN | RUN 0x0 de for the quadra Mode X2 X4 0x0 | ature decoder. | Timer is running in debug mode Quadrature Decoder Mode Selection Description X2 mode selected X4 mode selected | | | | | | | | | | | 5 4 3 | QDM This bit sets the mod Value 0 1 OSMEN Enable/disable one s | RUN 0x0 de for the quadra Mode X2 X4 0x0 shot mode. 0x0 | RW | Timer is running in debug mode Quadrature Decoder Mode Selection Description X2 mode selected X4 mode selected One-shot Mode Enable | | | | | | | | | | | 1 | QDM This bit sets the mod Value 0 1 OSMEN Enable/disable one s | RUN 0x0 de for the quadra Mode X2 X4 0x0 shot mode. 0x0 | RW | Timer is running in debug mode Quadrature Decoder Mode Selection Description X2 mode selected X4 mode selected One-shot Mode Enable Timer Start/Stop/Reload Synchronization | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-----|----------|--------------------|---------------|---------------------------------------------------------------------------------------------| | | 1 | ENABLE | | Timer may be started, stopped and re-loaded from other timer instances. | | 2 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | MODE | 0x0 | RW | Timer Mode | | | | • | | ote, when Quadrature Decoder Mode is selected (MODE = 'b11), the Decoder Mode clock output. | | | Value | Mode | | | | | | | | Description | | | 0 | UP | | Up-count mode | | | 0 | UP<br>DOWN | | | | | | <u> </u> | | Up-count 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 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | | • | | | • | | • | | • | | • | • | | • | • | • | • | | | | • | • | 0x0 | > | 2 | > | 25 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | \<br>0 | ^ | \<br>0 | <br>}<br>Ľ | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | X2CNT | \<br>-<br>-<br>- | j | DICE | ר<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב<br>ב | | Bit | Name | Reset | Access | Description | |------|---------------------------|-----------------|--------------------|----------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | X2CNT | 0x0 | RW | 2x Count Mode | | | Enable 2x count mode | | | | | 3:2 | FALLA | 0x0 | RW | Timer Falling Input Edge Action | | | These bits select the act | ion taken in th | ne 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 | RELOADS1 | ΓART | Reload and start counter | | 1:0 | RISEA | 0x0 | RW | Timer Rising Input Edge Action | | | These bits select the act | ion taken in th | ne 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 | RELOADS1 | ΓART | Reload and start counter | # 19.5.4 TIMER\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|-------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | • | | | | | | | | | | | | • | | | | | | | | | | • | | | • | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ν | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | STOP | START | | Bit | Name | Reset | Access | Description | |------|------------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | STOP | 0x0 | W | Stop Timer | | | Write a 1 to this bit to sto | p timer | | | | 0 | START | 0x0 | W | Start Timer | | | Write a 1 to this bit to sta | rt timer | | | ### 19.5.5 TIMER\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|--------|--------|--------|----|----|----|----|----|-----------|-----------|-----------|------|----|----|----|---|-------|-------|-------|---|----------|---------------|-----------------|---|-------|-----|---------| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | ' | | | | 0x0 | 0×0 | 0x0 | | | ' | | | 0x0 | 0×0 | 0×0 | | | • | ' | | 0×0 | 0x0 | 0x0 | | 0x0 | 0×0 | 0×0 | | 0x0 | 0×0 | 0x0 | | Access | | | | | | 22 | 22 | 22 | | | | | | 22 | 22 | 2 | | | | | | 22 | 2 | 2 | | 2 | 2 | 22 | | 2 | 22 | 22 | | Name | | | | | | CCPOL2 | CCPOL1 | CCPOL0 | | | | | | ICFEMPTY2 | ICFEMPTY1 | ICFEMPTY0 | | | | | | OCBV2 | OCBV1 | OCBV0 | | SYNCBUSY | DTILOCKSTATUS | TIMERLOCKSTATUS | | TOPBV | DIR | RUNNING | | | | | | 교 교 | | 8 8 | 00 | SYI | DI | ≧ | 101 | PR PS | |----------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------|-------|-------|---------|---------| | Bit | Name | Reset | Access | Descri | ntion | | | | | | | | | 31:27 | Reserved | To ensur | | | devices, always | write bits | to 0 | More | infor | matio | n in 1. | .2 Con- | | | | ventions | | | | | | | | | | | | 26 | CCPOL2 | 0x0 | R | CCn P | olarity | | | | | | | | | | In Input Capture mo<br>pare/PWM mode, the<br>CCMODE is written | his bit indicates | | | | | | | | | | | | | Value | Mode | | Descri | otion | | | | | | | | | | 0 | LOWRIS | E | CC0 p | olarity low level | /rising ed | ge | | | | | | | | 1 | HIGHFA | LL | CC0 p | olarity high leve | el/falling e | dge | | | | | | | 25 | CCPOL1 | 0x0 | R | CCn P | olarity | | | | | | | | | | In Input Capture mo<br>pare/PWM mode, the<br>CCMODE is written<br>Value | his bit indicates in to 0b00 (Off). | | f the selected | input to CC cha | | | | | | | | | | | | | I IACCTI | | | | | | | | | | | | Mode | | Descri | | Urioina od | ~~ | | | | | | | | 0 | LOWRIS | | CC0 p | olarity low level | | | | | | | | | | | | | CC0 p | | | | | | | | | | 24 | 0 | LOWRIS | | CC0 p | plarity low level | | | | | | | | | 24 | 0 | LOWRIS HIGHFAI 0x0 ode, this bit indicates | R cates the pola | CC0 po | olarity low level clarity high level clarity e that triggered | el/falling e | dge<br>in TIN | | | | | | | 24 | 0 1 CCPOL0 In Input Capture mo | LOWRIS HIGHFAI 0x0 ode, this bit indicates | R cates the pola | CC0 po | olarity low level<br>olarity high leven<br>olarity<br>e that triggered<br>input to CC cha | el/falling e | dge<br>in TIN | | | | | | | 24 | 0 1 CCPOL0 In Input Capture mo pare/PWM mode, the CCMODE is written | LOWRIS HIGHFAI 0x0 ode, this bit indicates in to 0b00 (Off). | R cates the polarity o | CC0 po CCn P arity of the edg f the selected Descri | olarity low level<br>olarity high leven<br>olarity<br>e that triggered<br>input to CC cha | el/falling e | dge<br>in TIN<br>hese | | | | | | | 24 | 0 1 CCPOL0 In Input Capture mo pare/PWM mode, th CCMODE is written | Dode, this bit indicates in to 0b00 (Off). | R cates the polarity o | CC0 po | olarity low level clarity high leve clarity e that triggered input to CC cha | el/falling ed<br>d capture in annel 0. The | dge<br>in TIN<br>hese | | | | | | | 24 23:19 | 0 1 CCPOL0 In Input Capture mo pare/PWM mode, the CCMODE is written Value 0 | LOWRIS HIGHFAI 0x0 ode, this bit indicates in to 0b00 (Off). Mode LOWRIS HIGHFAI | R cates the polarity of the polarity of E | CC0 per CCn Per control of the selected CC0 per pe | olarity low level clarity high level clarity e that triggered input to CC cha cotion colarity low level | d capture in annel 0. The large education of | dge in TIN hese ge dge | bits ar | e cle | eared | when | | | | 0 1 CCPOL0 In Input Capture more pare/PWM mode, the CCMODE is written Value 0 1 | LOWRIS HIGHFAI 0x0 ode, this bit indicates in to 0b00 (Off). Mode LOWRIS HIGHFAI | R cates the polarity of the polarity of E | CC0 per CCn Per control of the selected CC0 per CC0 per CC0 per CC0 per control of the selected CC0 per CC0 per control of the selected | olarity low level clarity high level clarity e that triggered input to CC cha cotion clarity low level colarity high level | d capture in annel 0. The life in | dge in TIN hese ge dge | bits ar | e cle | eared | when | | | Bit | Name | Reset | Access | Description | |-------|---------------------------------------------|--------------------|------------------|------------------------------------------------------------------------------------------------------------| | 17 | ICFEMPTY1 | 0x0 | R | Input capture fifo empty | | | Set when input capture | | | mpat suptais inc simply | | 16 | ICFEMPTY0 | 0x0 | R | Input capture fifo empty | | | Set when input capture | FIFO is empt | Y | | | 15:11 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 10 | OCBV2 | 0x0 | R | Output Compare Buffer Valid | | | | | | gisters contain data which have not been written to TPUTCOMPARE or PWM mode and are cleared when CCMODE is | | 9 | OCBV1 | 0x0 | R | Output Compare Buffer Valid | | | | | | gisters contain data which have not been written to TPUTCOMPARE or PWM mode and are cleared when CCMODE is | | 8 | OCBV0 | 0x0 | R | Output Compare Buffer Valid | | | | | | gisters contain data which have not been written to TPUTCOMPARE or PWM mode and are cleared when CCMODE is | | 7 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 6 | SYNCBUSY | 0x0 | R | Sync Busy | | | Indicates synchronization | on ongoing | | | | 5 | DTILOCKSTATUS | 0x0 | R | DTI lock status | | | Indicates current status | of DTI lock | | | | | Value | Mode | | Description | | | 0 | UNLOCKE | ED | DTI registers are unlocked | | | 1 | LOCKED | | DTI registers are locked | | 4 | TIMERLOCKSTATUS | 0x0 | R | Timer lock status | | | Indicates current status | of Timer lock | ζ. | | | | Value | Mode | | Description | | | 0 | UNLOCKE | ED | TIMER registers are unlocked | | | 1 | LOCKED | | TIMER registers are locked | | 3 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 2 | TOPBV | 0x0 | R | TOP Buffer Valid | | | This indicates that TIMI when TIMERn_TOP is | | ontains valid da | ta that has not been written to TIMERn_TOP. This bit is also cleared | | 1 | DIR | 0x0 | R | Direction | | | Indicates count directio | n. | | | | | Value | Mode | | Description | | Bit | Name | Reset | Access | Description | |-----|-----------------------|-----------------|--------|---------------| | | 0 | UP | | Counting up | | | 1 | DOWN | | Counting down | | 0 | RUNNING | 0x0 | R | Running | | | Indicates if timer is | running or not. | | | # 19.5.6 TIMER\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|--------|--------|--------|----|--------|--------|--------|----|------------|------------|------------|------|----|----|----|---|----|---|---|---|-----|-----|--------|---|--------|-----|-----| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | ဖ | 2 | 4 | က | 7 | _ | 0 | | Reset | | | • | • | 1 | 000 | 0X0 | 0×0 | | 0x0 | 0X0 | 0X0 | | 0X0 | 0X0 | 000 | | | | | | | | | • | 0X0 | 000 | 000 | | 000 | 0X0 | 0x0 | | Access | | | | | | ₩<br>M | %<br>≷ | S. | | ₩<br>M | S. | Z. | | ₩ | %<br>M | Z. | | | | | | | | | | ₹ | S. | ₩<br>M | | ₽ | ₹ | RW | | Name | | | | | | ICFUF2 | ICFUF1 | ICFUF0 | | ICFOF2 | ICFOF1 | ICFOF0 | | ICFWLFULL2 | ICFWLFULL1 | ICFWLFULL0 | | | | | | | | | | CC2 | CC1 | CCO | | DIRCHG | UF | OF | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------------|-----------------------|-------------------|---------------------------------------------------------------------------| | 31:27 | Reserved | To ensure<br>ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 26 | ICFUF2 | 0x0 | RW | Input capture FIFO underflow | | | Indicates that softw | are tried to read | an empty FIFO | on channel 2. | | 25 | ICFUF1 | 0x0 | RW | Input capture FIFO underflow | | | Indicates that softw | are tried to read | an empty FIFO | on channel 1. | | 24 | ICFUF0 | 0x0 | RW | Input capture FIFO underflow | | | Indicates that softw | are tried to read | an empty FIFO | on channel 0. | | 23 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 22 | ICFOF2 | 0x0 | RW | Input Capture FIFO overflow | | | Indicates that input value can be read for | | | overflown, and a prior captured value was lost. The latest captured | | 21 | ICFOF1 | 0x0 | RW | Input Capture FIFO overflow | | | Indicates that input value can be read for | | | overflown, and a prior captured value was lost. The latest captured | | 20 | ICFOF0 | 0x0 | RW | Input Capture FIFO overflow | | | Indicates that input value can be read for | | | overflown, and a prior captured value was lost. The latest captured | | 19 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 18 | ICFWLFULL2 | 0x0 | RW | Input Capture Watermark Level Full | | | This bit indicates the | at the Input capto | ure FIFO water | mark for channel 2 has been exceeded. | | 17 | ICFWLFULL1 | 0x0 | RW | Input Capture Watermark Level Full | | | This bit indicates the | at the Input capto | ure FIFO water | mark for channel 1 has been exceeded. | | 16 | ICFWLFULL0 | 0x0 | RW | Input Capture Watermark Level Full | | | This bit indicates the | at the Input capto | ure FIFO water | mark for channel 0 has been exceeded. | | 15:7 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 6 | CC2 | 0x0 | RW | Capture Compare Channel 2 Interrupt Flag | | Bit | Name | Reset | Access | Description | |-----|---------------------|----------------------------------------|-----------------|---------------------------------------------------------------------------| | | | JRE mode this bit incates that a match | | a new Capture event has taken place. In OUTPUTCOMPARE or PWM ten place | | 5 | CC1 | 0x0 | RW | Capture Compare Channel 1 Interrupt Flag | | | | JRE mode this bit incates that a match | | a new Capture event has taken place. In OUTPUTCOMPARE or PWM ten place | | 4 | CC0 | 0x0 | RW | Capture Compare Channel 0 Interrupt Flag | | | | JRE mode this bit incates that a match | | a new Capture event has taken place. In OUTPUTCOMPARE or PWM ten place | | 3 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 2 | DIRCHG | 0x0 | RW | Direction Change Detect Interrupt Flag | | | This bit is set who | en count direction | changes. Set | only in Quadrature Decoder mode | | 1 | UF | 0x0 | RW | Underflow Interrupt Flag | | | This bit indicates | that there has bee | n an underflo | w. | | 0 | OF | 0x0 | RW | Overflow Interrupt Flag | | | This bit indicates | that there has bee | n an overflow | | # 19.5.7 TIMER\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|--------|--------|--------|----|--------|--------|--------|----|------------|------------|------------|------|----|----|----|---|----|---|---|---|-----|-----|--------|---|--------|--------|--------| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | ' | | • | 1 | 000 | 0X0 | 0×0 | | 0x0 | 0X0 | 0X0 | | 0X0 | 0X0 | 000 | | | | | | | | • | • | 000 | 000 | 0X0 | | 000 | 000 | 0x0 | | Access | | | | | | ₩<br>M | %<br>≷ | ₩<br>M | | ₩<br>M | S. | Z. | | ₩ | %<br>M | Z. | | | | | | | | | | 8 | S. | %<br>⊗ | | ₽ | S<br>S | ₩<br>M | | Name | | | | | | ICFUF2 | ICFUF1 | ICFUF0 | | ICFOF2 | ICFOF1 | ICFOF0 | | ICFWLFULL2 | ICFWLFULL1 | ICFWLFULL0 | | | | | | | | | | CC2 | CC1 | 000 | | DIRCHG | UF | OF | | Bit | Name | Reset | Access | Description | |-------|--------------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:27 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 26 | ICFUF2 | 0x0 | RW | ICFUF2 Interrupt Enable | | | Enable/Disable the | ICFUF2 interrupt | | | | 25 | ICFUF1 | 0x0 | RW | ICFUF1 Interrupt Enable | | | Enable/Disable the | ICFUF1 interrupt | | | | 24 | ICFUF0 | 0x0 | RW | ICFUF0 Interrupt Enable | | | Enable/Disable the | ICFUF0 interrupt | | | | 23 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 22 | ICFOF2 | 0x0 | RW | ICFOF2 Interrupt Enable | | | Enable/Disable the | ICFOF2 interrupt | | | | 21 | ICFOF1 | 0x0 | RW | ICFOF1 Interrupt Enable | | | Enable/Disable the | ICFOF1 interrupt | | | | 20 | ICFOF0 | 0x0 | RW | ICFOF0 Interrupt Enable | | | Enable/Disable the | ICFOF0 interrupt | | | | 19 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 18 | ICFWLFULL2 | 0x0 | RW | ICFWLFULL2 Interrupt Enable | | | Enable/Disable the | ICFWLFULL2 inte | errupt | | | 17 | ICFWLFULL1 | 0x0 | RW | ICFWLFULL1 Interrupt Enable | | | Enable/Disable the | ICFWLFULL1 inte | errupt | | | 16 | ICFWLFULL0 | 0x0 | RW | ICFWLFULL0 Interrupt Enable | | | Enable/Disable the | ICFWLFULL0 inte | errupt | | | 15:7 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 6 | CC2 | 0x0 | RW | CC2 Interrupt Enable | | | Enable/Disable the | CC2 interrupt | | | | 5 | CC1 | 0x0 | RW | CC1 Interrupt Enable | | Bit | Name | e Reset Access | | Description | | | | | | | |-----|---------------------------------------------------------------------------------------------------------------|----------------|----|------------------------------------------|--|--|--|--|--|--| | | Enable/Disable the CC1 | interrupt | | | | | | | | | | 4 | CC0 | 0x0 | RW | CC0 Interrupt Enable | | | | | | | | | Enable/Disable the CC0 | | | | | | | | | | | 3 | Reserved To ensure compatibility with future devices, always write bits to 0. More information in 1. ventions | | | | | | | | | | | 2 | DIRCHG | 0x0 | RW | Direction Change Detect Interrupt Enable | | | | | | | | | Enable/Disable the DIR | CHG interrupt | | | | | | | | | | 1 | UF | 0x0 | RW | Underflow Interrupt Enable | | | | | | | | | Enable/Disable the UF interrupt | | | | | | | | | | | 0 | OF | 0x0 | RW | Overflow Interrupt Enable | | | | | | | | | Enable/Disable the OF | nterrupt | | | | | | | | | # 19.5.8 TIMER\_TOP - Counter Top Value Register | Offset | Bit Position | | | | | | | | | | | | | | | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x01C | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | | | | Reset | OXFF<br>FF<br>FF<br>FF<br>FF<br>FF<br>FF<br>FF<br>FF<br>FF<br>FF<br>FF<br>FF | | | | | | | | | | | | | | | | Access | R<br>≪ | | | | | | | | | | | | | | | | Name | TOP | | | | | | | | | | | | | | | | Bit | Name | Reset | | Description | |------|-------------------------|---------------|---------|-------------------| | 31:0 | TOP | 0xFFFF | RW | Counter Top Value | | | These bits hold the TOP | value for the | counter | | # 19.5.9 TIMER\_TOPB - Counter Top Value Buffer Register | Offset | Bit Position | | | | | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x020 | 33 34 37 38 39 30 30 30 30 31 32 33 34 35 36 37 47 41 41 41 41 41 42 43 44 45 46 47 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | | | | | | | | | | | | | | | Reset | 0×0 | | | | | | | | | | | | | | | | Access | \text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tin}\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tetx{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tetx{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\ti}\\\ \ti}\\\ \tittt{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\texi}\tittit{\text{\texi}\titt{\text{\texi}\tittt{\text{\texi}\tilit{\text{\texi}\tilit{\texit{\text{\text{\texi}\text{\text{\texi}\text{\texit{\text{ | | | | | | | | | | | | | | | | Name | TOPB | | | | | | | | | | | | | | | | Bit | Name | Name Reset | | Description | |------|-------------------------|---------------|--|-----------------------------| | 31:0 | TOPB | 0x0 RW | | Counter Top Buffer Register | | | These bits hold the TOP | buffer value. | | | ### 19.5.10 TIMER\_CNT - Counter Value Register | Offset | Bit Position | | | | | | | | | | | | | | | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x024 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | | | | Reset | OXO | | | | | | | | | | | | | | | | Access | RW | | | | | | | | | | | | | | | | Name | NO O | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------|---------------| | 31:0 | CNT | 0x0 | RW | Counter Value | | | These bits hold the coun | iter value. | | | # 19.5.11 TIMER\_LOCK - TIMER Configuration Lock Register | Offset | Bit Position | sition | | | | | | | | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--| | 0x02C | 30 31 32 33 34 35 36 37 38 38 39 30 31 32 33 34 35 36 37 38 39 30 31 41 42 43 44 45 46 47 48 47 48 49 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 41 42 43 44 45 46 47 48 40 40 40 40 40 41 42 43 44 <th>1 2 1 1 2 2 7 7 8 8 7 9 9 7 7 7 7 9</th> | 1 2 1 1 2 2 7 7 8 8 7 9 9 7 7 7 7 9 | | | | | | | | | | | | Reset | | 0×0 | | | | | | | | | | | | Access | | > = = = = = = = = = = = = = = = = = = = | | | | | | | | | | | | Name | | LOCKKEY | | | | | | | | | | | | Name | Reset Access | | Description | | | | | | | |------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Reserved | To ensure ventions | compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | LOCKKEY | 0x0 | W | Timer Lock Key | | | | | | | | TIMERn_CNT, TIME | ERn_CCx_CTRL | | TIMERn_CTRL, TIMERn_CFG, TIMERn_CMD, TIMERn_TOP, c_CFG, and TIMERn_CCx_OC from editing. Write the unlock code to | | | | | | | | Value | Description | | | | | | | | | | 52864 | UNLOCK | | Write to unlock TIMER registers | | | | | | | | | Reserved LOCKKEY Write any other valu TIMERn_CNT, TIMI unlock these registe | Reserved To ensure ventions LOCKKEY 0x0 Write any other value than the unlock TIMERn_CNT, TIMERn_CCx_CTRL unlock these registers. Value Mode | Reserved To ensure compatibility was ventions LOCKKEY 0x0 W Write any other value than the unlock code to lock TIMERn_CNT, TIMERn_CCx_CTRL, TIMERn_CCx unlock these registers. Value Mode | | | | | | | ### 19.5.12 TIMER\_EN - module en | Offset | Bit Position | | | | | | | | | | | | | | | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x030 | 33 4 5 6 6 7 7 8 8 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 0 | | | | | | | | | | | | | | | Reset | | 0x0 | | | | | | | | | | | | | | | Access | | S. | | | | | | | | | | | | | | | Name | | EN | | | | | | | | | | | | | | | Bit | Name | Reset Access | | Description | | | | | | | | | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 0 | EN | 0x0 | RW | Timer Module Enable | | | | | | | | | | | | 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 | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|-----|-----|-----|----|-------|----------|---------|----|--------|------|------|----|----|----|---|----|---|-----|--------|---|---|----------|----------|---|------|-------------| | 0x060 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | 0x0 | 0x0 | 0×0 | Š | OXO | | • | | | ' | | | | | • | • | ' | 000 | | | 2 | SX . | | | | | | Access | | | | | | | | RW | W. | W. | 2 | <u>}</u> | | | | | | | | | | | | | ₩<br>M | | | <u> </u> | <u> </u> | | | | | Name | | | | | | | | | | | ICFWL | FILT | PRSCONF | | IIVOEL | | | | | | | | | | | | | COIST | | | ПООМ | Σ<br>Ο<br>Ο | | Bit | Name | Reset | Access | Description | |-------|-----------------------|-----------------------|-----------------|---------------------------------------------------------------------------------------------------------------| | 31:22 | Reserved | To ensure<br>ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 21 | ICFWL | 0x0 | RW | Input Capture FIFO watermark level | | | | | | /LFULL interrupt and DMA requests. ICFWLFULL will be set and see FIFO entries is less than or equal to ICFWL. | | 20 | FILT | 0x0 | RW | Digital Filter | | | Enable digital filter | ·. | | | | | Value | Mode | | Description | | | 0 | DISABLE | | Digital Filter Disabled | | | 1 | ENABLE | | Digital Filter Enabled | | 19 | PRSCONF | 0x0 | RW | PRS Configuration | | | Select PRS pulse | or level for PRS or | utput. | | | | 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 | Input Selection | | | Select Compare/C | apture channel inp | out. | | | | Value | Mode | | Description | | | 0 | PIN | | TIMERnCCx pin is selected | | | 1 | PRSSYNO | C | Synchornous PRS selected | | | 2 | PRSASYN | NCLEVEL | Asynchronous Level PRS selected | | | 3 | PRSASYN | NCPULSE | Asynchronous Pulse PRS selected | | 16:5 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 4 | COIST | 0x0 | RW | Compare Output Initial State | | Bit | Name | Reset | Access | Description | |-----|-------------------|-----------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | high when the co | unter is disabled. V | hen counting | I mode. When this bit is set in Compare or PWM mode, the output is set resumes, this value will represent the initial value for the output. If the counter is disabled. | | 3:2 | Reserved | To ensure<br>ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | MODE | 0x0 | RW | CC Channel Mode | | | These bits select | the mode for Comp | oare/Capture | channel. | | | Value | Mode | | Description | | | 0 | OFF | | Compare/Capture channel turned off | | | 1 | INPUTCA | PTURE | Input Capture | | | 2 | OUTPUT | COMPARE | Output Compare | | | 3 | PWM | | Pulse-Width Modulation | | | | | | | # 19.5.14 TIMER\_CCx\_CTRL - CC Channel Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|-----------|--------|----|----------|----|----|----|----|----|----|----|------|------|----|----|----------------|------------|----------|---|----------|---|---|----------|---|---|--------|---|---| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | | | 2 | 3 | Š | e<br>X | | | | | ' | • | | | | • | Š | e<br>X | 2 | 2 | Š | e<br>X | | • | <u>'</u> | | ' | 0x0 | | | | Access | | | | | 2 | 2 | 2 | <u>}</u> | | | | | | | | | | | 2 | ≥<br>Y | 7 | <u> </u> | 2 | <b>≩</b> | | | | | | RW | | | | Name | | | | | ICEVICEDI | -<br>> | | ם<br>ב | | | | | | | | | | | 0 | 40100<br>40100 | V C II C C | | | Z Z Z | | | | | | OUTINV | | | | | | _ | | | |-------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 31:28 | Reserved | To ensure o | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con | | 27:26 | ICEVCTRL | 0x0 | RW | Input Capture Event Control | | | These bits control vevery capture. | when a Compare/C | Capture PRS ou | tput pulse and interrupt flag is set. DMA request however is set on | | | Value | Mode | | Description | | | 0 | EVERYEDO | GE | PRS output pulse and interrupt flag set on every capture | | | 1 | EVERYSEC | CONDEDGE | 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 | Input Capture Edge Select | | 25:24 | | | | Input Capture Edge Select ggers on. The output is used for input capture and external clock | | 25:24 | These bits control v | | | | | 25:24 | These bits control vinput. | which edges the ed | | gers on. The output is used for input capture and external clock | | 25:24 | These bits control vinput. | which edges the ed | | ggers on. The output is used for input capture and external clock Description | | 25:24 | These bits control vinput. Value | which edges the ed<br>Mode<br>RISING | | ggers on. The output is used for input capture and external clock Description Rising edges detected | | 25:24 | These bits control vinput. Value 0 | Mode RISING FALLING | | pgers on. The output is used for input capture and external clock Description Rising edges detected Falling edges detected | | 25:24 | These bits control vinput. Value 0 1 | Mode RISING FALLING BOTH NONE | dge detector trig | Description Rising edges detected Falling edges detected Both edges detected No edge detection, signal is left as it is | | | These bits control vinput. Value 0 1 2 3 | Mode RISING FALLING BOTH NONE To ensure of | dge detector trig | Description Rising edges detected Falling edges detected Both edges detected No edge detection, signal is left as it is | | 23:14 | These bits control vinput. Value 0 1 2 3 Reserved | Mode RISING FALLING BOTH NONE To ensure oventions 0x0 | dge detector trig | Description Rising edges detected Falling edges detected Both edges detected No edge detection, signal is left as it is th future devices, always write bits to 0. More information in 1.2 Con | | 23:14 | These bits control vinput. Value 0 1 2 3 Reserved CUFOA | Mode RISING FALLING BOTH NONE To ensure oventions 0x0 | dge detector trig | Description Rising edges detected Falling edges detected Both edges detected No edge detection, signal is left as it is th future devices, always write bits to 0. More information in 1.2 Con | | 23:14 | These bits control vinput. Value 0 1 2 3 Reserved CUFOA Select output action | Mode RISING FALLING BOTH NONE To ensure oventions 0x0 n on counter under | dge detector trig | Description Rising edges detected Falling edges detected Both edges detected No edge detection, signal is left as it is th future devices, always write bits to 0. More information in 1.2 Con Counter Underflow Output Action | | 23:14 | These bits control vinput. Value 0 1 2 3 Reserved CUFOA Select output action Value | Mode RISING FALLING BOTH NONE To ensure of ventions 0x0 n on counter under | dge detector trig | Description Rising edges detected Falling edges detected Both edges detected No edge detection, signal is left as it is th future devices, always write bits to 0. More information in 1.2 Con Counter Underflow Output Action Description | | 23:14 | These bits control vinput. Value 0 1 2 3 Reserved CUFOA Select output action Value 0 | Mode RISING FALLING BOTH NONE To ensure oventions 0x0 n on counter under | dge detector trig | Description Rising edges detected Falling edges detected Both edges detected No edge detection, signal is left as it is th future devices, always write bits to 0. More information in 1.2 Con Counter Underflow Output Action Description No action on counter underflow | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|--------------------|--------------------|------------------------------------------------------------------------| | 11:10 | COFOA | 0x0 | RW | Counter Overflow Output Action | | | Select output action on | counter overfl | ow. | | | | 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 | СМОА | 0x0 | RW | Compare Match Output Action | | | Select output action on | compare mate | ch. | | | | 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 | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 2 | OUTINV | 0x0 | RW | Output Invert | | | Setting this bit inverts th | e output from | the CC channel | (Output compare or PWM mode). | | 1:0 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | # 19.5.15 TIMER\_CCx\_OC - OC Channel Value Register | Offset | | Bit Position | | | | | | | | | | | | | |--------|----|---------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--| | 0x068 | 31 | 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | | | | | | | | | | | | | | Reset | | 8 | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | Name | | 00 | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------|---------------|--------|----------------------| | 31:0 | OC | 0x0 | RW | Output Compare Value | | | This fields holds the outp | out compare v | alue | | ### 19.5.16 TIMER\_CCx\_OCB - OC Channel Value Buffer Register | Offset | Bit Position | | | | | | | | | | | | | | |--------|----------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x070 | 30 30 37 4 5 6 7 8 9 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | | | Reset | 0×0 | | | | | | | | | | | | | | | Access | R | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------------------------|-------|--------|-----------------------------------------------------------| | 31:0 | OCB | 0x0 | RW | Output Compare Value Buffer | | | This field holds the Outp TIMERn_CCx_OCB con | | | sh will be written to TIMERn_CCx_OC on an update event if | ### 19.5.17 TIMER\_CCx\_ICF - IC Channel Value Register | Offset | | Bit Position | | | | | | | | | | | | | |--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--| | 0x074 | 31 | 30 4 4 5 6 6 6 7 7 8 8 8 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | | | | | | | | | | | | | | Reset | | 8 | | | | | | | | | | | | | | Access | | (i) | | | | | | | | | | | | | | Name | | <u>5</u> | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------|-----------------|----------------|---------------------------------------------------------------------| | 31:0 | ICF | 0x0 | R(r) | Input Capture FIFO | | | This FIFO holds capture FIFO. | ed values in ir | put capture mo | de. Reading this register will pop the oldest unread value from the | # 19.5.18 TIMER\_CCx\_ICOF - IC Channel Value Overflow Register | Offset | Bit Position | | | | | | | | | | | | | |--------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--| | 0x078 | 0 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | | | | | | | | | | | | | | Reset | OXO OX | | | | | | | | | | | | | | Access | <u>د</u> | | | | | | | | | | | | | | Name | ICOF | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|------|-------|--------|--------------------------------------------------------------------------------------------------| | 31:0 | ICOF | 0x0 | R | Input Capture FIFO Overflow | | | | | | apture value. If the input capture FIFO is full and a new capture caputre value is over-written. | # 19.5.19 TIMER\_DTCFG - DTI Configuration Register | Offset | Bit Position | | | | | | | | | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----|---|---|---|---|---|---|---|-------|------| | 0x0E0 | 33 34 35 36 37 38 39 30 31 32 33 34 35 36 37 38 39 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <td>1 0</td> <td>6</td> <td>8</td> <td>7</td> <td>9</td> <td>2</td> <td>4</td> <td>က</td> <td>2</td> <td>_</td> <td>0</td> | 1 0 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 000 | 0x0 | | | • | | | • | | 0×0 | 0x0 | | Access | | A S | RW | | | | | | | | W. | RW | | Name | | DTPRSEN<br>DTFATS | AR | | | | | | | | DTDAS | DTEN | | Bit | Name | Reset | Access | Description | |-------|-----------------------|----------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | 31:12 | Reserved | To ensur<br>ventions | re compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 11 | DTPRSEN | 0x0 | RW | DTI PRS Source Enable | | | Enable/disable PRS a | as DTI input. | | | | 10 | DTFATS | 0x0 | RW | DTI Fault Action on Timer Stop | | | | o set,DTAR h | | ate as programmed in DTFA field of TIMERn_DTFC register. Howev-<br>iority allows channel0 to output the incoming PRS input while the other | | 9 | DTAR | 0x0 | RW | DTI Always Run | | | | source is PRS | | channel 0 to keep running even when the timer is stopped. This is the undivided peripheral clock is always used regardless of the pro- | | 8:2 | Reserved | To ensur<br>ventions | re compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1 | DTDAS | 0x0 | RW | DTI Automatic Start-up Functionality | | | Configure DTI restart | on debugger | exit. | | | | Value | Mode | | Description | | | 0 | NORES1 | TART | No DTI restart on debugger exit | | | 1 | RESTAR | RT . | DTI restart on debugger exit | | 0 | DTEN | 0x0 | RW | DTI Enable | | | Enable/disable DTI. | | | | # 19.5.20 TIMER\_DTTIMECFG - DTI Time Configuration Register | Offset | | Bit Po | sition | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------------------------------|---------------------| | 0x0E4 | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>26<br>27<br>27<br>27<br>28<br>28<br>29<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | 20<br>20<br>19<br>18<br>17<br>16 | 15 14 17 11 10 10 10 10 10 10 10 10 10 10 10 10 | 0 8 1 0 1 4 8 7 1 0 | | Reset | | 0×0 | 0х0 | 0×0 | | Access | | RW | RW | RW<br>W | | Name | | DTFALLT | DTRISET | DTPRESC | | Bit | Name | Reset | Access | Description | |-------|------------------------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:22 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 21:16 | DTFALLT | 0x0 | RW | DTI Fall-time | | | Set time span for the fall | ing edge. The | fall time is DTF | FALLT+1 prescaled peripheral clock cycles | | 15:10 | DTRISET | 0x0 | RW | DTI Rise-time | | | Set time span for the risi | ng edge. The | rise time is DTF | RISET+1 prescaled peripheral clock cycles | | 9:0 | DTPRESC | 0x0 | RW | DTI Prescaler Setting | | | These bits select the pre the DTI logic. | scaling factor | for DTI. The se | elected timer clock will be divided by DTPRESC+1 before clocking | # 19.5.21 TIMER\_DTFCFG - DTI Fault Configuration Register | Offset | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|-----------|-------------|----------|-----------|-----------|----|----|----|----|----|----|-------------|----------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x0E8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | 000 | 0×0 | 0x0 | 000 | 0x0 | | | | | | • | 5 | 8 | | | | | | | | | • | | • | | • | | | | | Access | | | | ₩<br>M | R<br>M | RW | ₽ | RW | | | | | | | 2 | <b>≩</b> | | | | | | | | | | | | | | | | | | Name | | | | DTEM23FEN | DTLOCKUPFEN | DTDBGFEN | DTPRS1FEN | DTPRS0FEN | | | | | | | Š<br>L<br>H | Ā | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|---------------|--------------------|----------------------------------------------------------------------| | 31:29 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 28 | DTEM23FEN | 0x0 | RW | DTI EM23 Fault Enable | | | Set this bit to 1 to enable | EM2 or EM3 | entry as a fault | source | | 27 | DTLOCKUPFEN | 0x0 | RW | DTI Lockup Fault Enable | | | Set this bit to 1 to enable | core lockup a | as a fault source | | | 26 | DTDBGFEN | 0x0 | RW | DTI Debugger Fault Enable | | | Set this bit to 1 to enable | debugger as | a fault source | | | 25 | DTPRS1FEN | 0x0 | RW | DTI PRS 1 Fault Enable | | | Set this bit to 1 to enable | PRS source | 1 as a fault sour | ce | | 24 | DTPRS0FEN | 0x0 | RW | DTI PRS 0 Fault Enable | | | Set this bit to 1 to enable | PRS source | 0 as a fault sour | ce | | 23:18 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 17:16 | DTFA | 0x0 | RW | DTI Fault Action | | | 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 | To ensure c | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | # 19.5.22 TIMER\_DTCTRL - DTI Control Register | Offset | Bit Position | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------| | 0x0EC | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>_</th> <th>0</th> | _ | 0 | | Reset | | 0X | 0x0 | | Access | | A. | RW | | Name | | DTIPOL | DTCINV | | Bit | Name | Reset | Access | Description | |------|-----------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | DTIPOL | 0x0 | RW | DTI Inactive Polarity | | | Set inactive polarity of ou | ıtputs | | | | 0 | DTCINV | 0x0 | RW | DTI Complementary Output Invert. | | | DTI Complementary Out | put Invert. | | | # 19.5.23 TIMER\_DTOGEN - DTI Output Generation Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|---|---|---|-------------|-------------|-------------|-----------|-----------|-----------| | 0x0F0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | ' | | ' | | | | ' | | ' | | | <u>'</u> | | ' | | ' | | | • | | | • | 000 | 000 | 0x0 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | W. | ZW<br>W | W<br>M | RW | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | DTOGCDTI2EN | DTOGCDT11EN | DTOGCDT10EN | DTOGCC2EN | DTOGCC1EN | DTOGCCOEN | | Bit | Name | Reset | Access | Description | |------|---------------------------|--------------|--------------------|----------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 5 | DTOGCDTI2EN | 0x0 | RW | DTI CDTIn Output Generation Enable | | | This bit enables/disables | output gener | ation for the CD | TI output from the DTI. | | 4 | DTOGCDTI1EN | 0x0 | RW | DTI CDTIn Output Generation Enable | | | This bit enables/disables | output gener | ation for the CD | TI output from the DTI. | | 3 | DTOGCDTI0EN | 0x0 | RW | DTI CDTIn Output Generation Enable | | | This bit enables/disables | output gener | ation for the CD | TI output from the DTI. | | 2 | DTOGCC2EN | 0x0 | RW | DTI CCn Output Generation Enable | | | This bit enables/disables | output gener | ation for the CC | output from the DTI. | | 1 | DTOGCC1EN | 0x0 | RW | DTI CCn Output Generation Enable | | | This bit enables/disables | output gener | ation for the CC | output from the DTI. | | 0 | DTOGCC0EN | 0x0 | RW | DTI CCn Output Generation Enable | | | This bit enables/disables | output gener | ation for the CC | output from the DTI. | # 19.5.24 TIMER\_DTFAULT - DTI Fault Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---------|-----------|----------|---------|----------| | 0x0F4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | • | | | | | • | | | | • | • | • | • | • | • | | • | | | | | | | • | • | 000 | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | œ | 22 | <u>~</u> | œ | <b>~</b> | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | DTEM23F | DTLOCKUPF | DTDBGF | DTPRS1F | DTPRS0F | | | | _ | | | | | | | | | | | |------|--------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|--|--|--|--|--|--|--|--| | Bit | Name | Reset | Access | Description | | | | | | | | | | 31:5 | Reserved | To ensure o | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 (ventions | | | | | | | | | | | 4 | DTEM23F | 0x0 | R | DTI EM23 Entry Fault | | | | | | | | | | | This bit is set to 1 if EM2 be used to clear fault bit | | y has occurred a | and DTEM23FEN is set to 1. The TIMER0_DTFAULTC register can | | | | | | | | | | 3 | DTLOCKUPF | 0x0 | R | DTI Lockup Fault | | | | | | | | | | | This bit is set to 1 if a cocan be used to clear fau | | t has occurred a | and DTLOCKUPFEN is set to 1. The TIMER0_DTFAULTC register | | | | | | | | | | 2 | DTDBGF | 0x0 | R | DTI Debugger Fault | | | | | | | | | | | This bit is set to 1 if a deused to clear fault bits. | ebugger fault h | nas occurred and | d DTDBGFEN is set to 1. The TIMER0_DTFAULTC register can be | | | | | | | | | | 1 | DTPRS1F | 0x0 | R | DTI PRS 1 Fault | | | | | | | | | | | This bit is set to 1 if a Plused to clear fault bits. | RS 1 fault has | occurred and D | TPRS1FEN is set to 1. The TIMER0_DTFAULTC register can be | | | | | | | | | | 0 | DTPRS0F | 0x0 | R | DTI PRS 0 Fault | | | | | | | | | | | This bit is set to 1 if a Plused to clear fault bits. | RS 0 fault has | occurred and D | TPRS0FEN is set to 1. The TIMER0_DTFAULTC register can be | | | | | | | | | # 19.5.25 TIMER\_DTFAULTC - DTI Fault Clear Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|------|------|----|----|----|---|----|---|---|---|---|---|----------|------------|---------|----------|----------| | 0x0F8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | ' | | ' | | | | • | | ' | <u>'</u> | | | | ' | | • | | ' | • | ' | | ' | • | 0x0 | 0×0 | 000 | 0X0 | 000 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | > | > | > | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | DTEM23FC | DTLOCKUPFC | DTDBGFC | DTPRS1FC | DTPRS0FC | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|--------------------------|--------------------|----------------------------------------------------------------------------------------------------------|--------------------------|--|--|--|--|--|--|--|--|--| | 31:5 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Conventions | | | | | | | | | | | | 4 | DTEM23FC | 0x0 | 0x0 W DTI EM23 Fault Clear | | | | | | | | | | | | | Write 1 to this bit to c | lear EM23 entr | y fault. | | | | | | | | | | | | 3 | DTLOCKUPFC | 0x0 | W | DTI Lockup Fault Clear | | | | | | | | | | | | Write 1 to this bit to c | lear core lockup | o fault. | | | | | | | | | | | | 2 | DTDBGFC | 0x0 | W | DTI Debugger Fault Clear | | | | | | | | | | | | Write 1 to this bit to c | lear debugger f | ault. | | | | | | | | | | | | 1 | DTPRS1FC | 0x0 | W | DTI PRS1 Fault Clear | | | | | | | | | | | | Write 1 to this bit to c | lear PRS 1 faul | t. | | | | | | | | | | | | 0 | DTPRS0FC | 0x0 | W | DTI PRS0 Fault Clear | | | | | | | | | | | | Write 1 to this bit to c | lear PRS 0 faul | t | | | | | | | | | | | # 19.5.26 TIMER\_DTLOCK - DTI Configuration Lock Register | Offset | Bit Posit | ition | |--------|----------------------------------------------------------------------------------|-------------------------------| | 0x0FC | 31<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30 | 2 4 8 7 0 0 8 7 0 0 4 8 7 0 0 | | Reset | | 0×0 | | Access | | > | | Name | | DTILOCKKEY | | Bit | Name | Reset | Access | Description | |-------|------------|----------------------|-----------------|-------------------------------------------------------------------------------------------------| | 31:16 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con | | 15:0 | DTILOCKKEY | 0x0 | W | DTI Lock Key | | | | | | TIMER_ROUTE, TIMER_DTCTRL, TIMER_DTCFG, TIMER_DTTI-the unlock code to unlock the DTI registers. | | | Value | Mode | | Description | | | 52864 | UNLOCK | , | Write to unlock TIMER DTI registers | #### 20. PDM - PDM Interface #### **Quick Facts** #### What? The PDM Module accepts a PDM bitstream input and provides PCM output samples. #### Why? Peripherals with PDM digital output signals reduce system cost and provide low-cost isolation. #### How? The PDM module uses a Programmable-Order CIC decimation filter to reduce the high-speed single bit input to a lower speed multi-bit wide PCM sample. #### 20.1 Introduction The PDM module provides a decimation filter for Pulse Density Modulation (PDM) microphones, isolated Sigma-Delta ADCs, and other PDM or Sigma-Delta bit stream peripherals. The decimation filter consists of a Cascaded Integrator Comb (CIC) filter. The output width of the comb filter is selectable, supporting 16, 24, or 32 bits. The comb filter has a fixed M value of 1. #### 20.2 Features - · Cascaded Integrator Comb Filter - · Programmable Filter Order - 2, 3, 4, or 5 - · Programmable Down Sample Rate - · Power of 2 Rate - · Integer Rate - · Selectable Output Width - · 16-bit output data - · 24-bit output data - · 32-bit output data - Selectable Data Alignment (16-bit or 24-bit mode) - · Left Aligned Data - · Right Aligned Data - · 32-bit raw Mode Data Directly from Integrator - · Programmable Gain - · Supports Integer Down Sample Rates - · Supports dynamic gain changes - · 6 dB steps - · Supports Multiple Channels - · 1 or 2 channels - · Supports Stereo Input Data - · Data FIFO - · Programmable Data Valid Level - · 16-bit packed mode - DMA support - · DMA request on Data Valid - · Interrupts - · Data Valid - · Overflow - · PRS Output on Down Sample Rate clock - Clock Prescaler - · Applications - · Sigma-Delta Modulators - · Isolated Sigma Delta Modulators - · PDM Microphones - · Digital Sensors #### 20.3 Functional Description #### 20.3.1 Overview An overview of PDM is shown in Figure 20.1 PDM Overview on page 539. Figure 20.1. PDM Overview #### 20.3.2 PDM Clock Generation The module generates a PDM output clock using an integer divider prescaler to divide down the module HFCLK\_PDM. See 8. CMU - Clock Management Unit for details on generation of the HFCLK\_PDM. The PDM module includes a 10-bit integer prescaler. The PDM clock is divided by PRESC plus 1. The PRESC field is located in the PDMn CFG1 register. For optimum performance, PDM signal sources require an accurate, jitter-free clock. #### 20.3.3 Filter Order The decimation filter order is programmable from 2 to 5. The selected filter order must be at least one order higher than the sigma delta modulator. Isolated ADCs typically have a second order sigma delta modulator and require a 3rd order filter. PDM microphones typically have a fourth order modulator and require a 5th order filter. The filter also supports 1st order and 3rd order sigma delta modulators. The filter order is programmed in the FORDER field of the PDMn\_CFG0 register. The filter order must be programmed before enabling the module and should not be modified while the module is running. #### 20.3.4 Down Sample Rate The Down Sample Rate of the decimation filter is programmable. The decimation filter supports both power of 2 (2x) and integer down sampling rates. The advantage of using a power of two down sampling rate is that gain compensation requires only shifting the results and the full scale value will use all available bits. The benefit of using non-power of two down sampling rates is that this allows finer adjustment of the output word rate. The down sample rate is programmed into the DSR field of the PDMn\_CTRL register and can be changed dynamically while the filter is running. The changed DSR setting will be loaded to the dsr counter when the dsr counter rolls over to zero. The decimation filter includes gain compensation which will shift the final results so that a full scale output is achieved for fully modulated input. When filter output option is 16-bit or 24-bit then program the shift value in gain field of CTRL register. Gain = $32 - (1 + \text{ceiling}((\log 10(G)/\log 10(2)), 1)$ . Where $G = (DSR \land N)$ . The GAIN field is in the PDMn\_CTRL register and can be changed dynamically while the filter is running. The value of the GAIN field can vary dynamically from 0 to a maximum value of the integer part of the LOG2 of the down sample rate. The maximum down sample rate is limited by the internal width of the integrator. The maximum value depends on the filter order. N Max DSR 3 1290 4 215 5 73 Table 20.1. Maximum DSR vs Filter Order #### 20.3.5 Multi Channel Operation The PDM module has 2 channels. All channels use a common clock and filter settings. The channels are synchronized such that all channels down sample and produce output data on the same filter clock cycle. The module supports clock output mode only. There is only one clock output for all channels. The number of active channels is selectable - 1 or 2 channels. In normal mode, there is one clock output and one data input for each channel. The two channel stereo mode samples DAT0 on both rising and falling edges of the clock, to produce data output for CH0 and CH1. CH0 uses the rising edge data, and CH1 uses the falling edge data. In normal mode, data is normally clocked on the rising edge of the CLK signal. There is an option to invert the data polarity which will clock data on the falling edge of the clock signal. This may be useful for some sigma delta modulators that have insufficient hold time on the rising clock edge. #### 20.3.6 Output Options The output width of the comb filter is selectable, supporting 16, 24, or 32 bits. When 32-bit data is selected, all 32-bits will be significant. There are options for right or left justified 16-bit or 24-bit data. There is also an option for raw 32-bit data directly from the integrator. This option supports a software comb filter. #### 20.3.7 FIFO The PDM module has a 32-bit by four entry FIFO. The FIFO has the capacity to store up to eight 16-bit samples, four 32-bit samples, or four 24-bit samples. Each sample is normally stored as a 32-bit word, unless the DATAFORMAT field is set to DOUBLE16 in the PDMn\_CFG0 register. The PDM module stores data in the FIFO starting with CH0. The DMA or software should read out all samples for all enabled channels starting with CH0. The FIFO has a programmable Data Valid Level interrupt, FIFO full interrupt, and FIFO overflow interrupt. If the DATAFORMAT field is set to DOUBLE16, then 16-bit data from two channels are packed into a single 32-bit word and written into the FIFO. If NUMCH bitfield is 0 (i.e. only one channel, CH0) and the DATAFORMAT field is set to DOUBLE16, then the UPPER16BIT are zeros and LOWER16BIT data has CH0 16-bit data. ## 20.3.8 DMA Support The module will generate a DMA request when the number of samples in the FIFO is equal to the level set by the FIFODVL field in the PDMn CFG0 register. # 20.3.9 PRS Support The module has a PRS sync output which generates a PRS output pulse on the onset of the down sample rate clock. This PRS signal may be used to trigger an ADC conversion, routed to a timer/counter, PCNT, or to a GPIO pin. # 20.3.10 PDM Energy Modes - The PDM interface functions in EM0/EM1 mode. - All the PDM registers are retained in EM2/EM3; after waking from EM2/EM3 the system can resume using the PDM peripheral without reconfiguring it. - The PDM interrupt can be used as as wakeup source from EM1. - The following are steps the software must perform for EM2/EM3 entry and exit: - · Read any converted PCM samples which are available in the FIFO. - Issue the Filter STOP command by configuring PDMn CMD register. This will gate off the clock to the external device. - Poll until the ACT bit in the STATUS register is low. ACT indicates the filter status to software. - · Issue a WFI command to enter EM2/EM3. - Upon EM2/EM3 exit, clear the filter by issuing CLEAR command in PDMn CMD register. - Flush the FIFO by issuing FIFOFL command in PDMn CMD register. - · To restart, issue the Filter START command by configuring PDMn\_CMD register. ## 20.3.11 Debug Mode When CPU is halted in debug mode, the PDM will continue to run and DMA will capture the data from the FIFO. ## 20.3.12 Pin Configurations A common GPIO pin is used as the clock output for up to 2 DATA ports. Three route locations are available via DBUS and the DBUS connections are detailed in the device data sheet. Pin locations can be selected using the GPIO\_PDM\_CLKROUTE and GPIO\_PDM\_DATXROUTE registers. The clock output is enabled using the GPIO\_PDM\_ROUTEEN register. The slew rate for the CLK pin should be set to its maximum (fastest) setting. All pins should be selected from the same DBUS (DBUSAB or DBUSCD). Optimal performance is achieved when all pins are routed adjacent to each other on the same GPIO port (PA, PB, PC, or PD). ## 20.3.13 Programmer's Model - The PDM configuration registers are considered to be static and can only be updated when the filter is not running. Only DSR/Gain can be changed dynamically. - Stop the filter before changing the prescale value. Stopping the filter will gate off the clock to external devices. Before re-starting the filter, issue a Filter CLEAR command "PDMn\_CMD.CLEAR" and issue a FIFO Flush command "PDMn\_CMD.FIFOFL". The Filter CLEAR command acts as soft reset to the Filter and the Flush command as soft reset to the FIFO pointers. - When there is an Overflow error condition, without Stopping the filter, issue a FIFO Flush command. When a FLUSH command is issued, poll for FLUSHFLBUSY, don't read STATUS bits when FLUSHFLBUSY is high. Before issuing FLUSH command clear any pending DMA requests. • The APB clock and PDM Core clock are asynchronous to each other, so when a FIFOFL command is issued, the FIFOFLBUSY bit in SYNCBUSY should be polled. For START/STOP/CLEAR commands, the SYNCBUSY bit should be polled. Similarly when the DSR/GAIN fields in CTRL register are configured, poll for SYNCBUSY bit in the SYNCBUSY register. - The START command is common for all channels of the filter. When NUMCH is set to 1, i.e. when two channels are configured, both channel filter outputs are available at a time and hardware will take 6 cycles to write into FIFO, so there is a limitation on the minimum DSR setting. - If the DATAFORMAT selected in PDMn CFG0 is 32-bit/24-bit/16-bit, then Minimum DSR > (NUMCH + 3). Example: If NUMCH is 1 (two channels), then Minimum DSR should be 4. • If the DATAFORMAT selected in PDMn\_CFG0 is DOUBLE16, then Minimum DSR > ((NUMCH + 1)/2 + 2). Example: If NUMCH is 1 (two channels) and the DATAFORMAT is DOUBLE16, then Minimum DSR should be 3. # 20.3.13.1 Configuration example 1 Sample program for configuring PDM · Enable APB clocks in CMU, configure PDM clock in CMU ``` /* Configure GPIO clock, LDMA clock */ CMU->CLKEN0 = CMU->CLKEN0 | CMU_CLKEN0_GPIO | CMU_CLKEN0_LDMA; /* Enable PCLK of PDM peripheral */ CMU->CLKEN0 = (CMU->CLKEN0 | CMU_CLKEN0_PDM); /* If required choose PER clock prescale value */ CMU->SYSCLKCTRL = (prescale_value << _CMU_SYSCLKCTRL_PCLKPRESC_SHIFT);</pre> ``` Select PDM clock (from EM01GRPBCLK) ``` CMU->EM01GRPBCLK = CMU_EM01GRPBCLK_CLKSEL_HFRCODPLL; ``` Configure GPIOs using GPIO\_PDM\_ROUTEEN/CLKROUTE/DAT0ROUTE/DAT1ROUTE registers Set CLK to PUSHPULL mode and configure SLEWRATE to 7 Set DAT\* PIN to Input mode • Based on selected clock source, configure the "PRESCALE" value of PDM ``` while(PDM->SYNCBUSY !=0); PDM->CFG1 = (prescale_val << _PDM_CFG1_PRESC_SHIFT);</pre> ``` · Configure PDM In this example PDM is configured to single channel, data capture polarity of channel is set 0, filter output to 32-bit, FIFO data valid level to max (3), DSR to 64 and Gain to 0, Filter order set to 5 ``` PDM->CFG0 = (0 << _PDM_CFG0_NUMCH_SHIFT | 1 << _PDM_CFG0_CHOCLKPOL_SHIFT | 3 << _PDM_CFG0_DATAFORMAT_SHIFT | 3 << _PDM_CFG0_FORDER_SHIFT);</pre> ``` Configure DSR/Gain, in this example DSR is set to decimal 64, since 32-bit output no need to shift, so Gain is set to 0 ``` while(PDM->SYNCBUSY !=0); PDM->CTRL = ((0 << _PDM_CTRL_GAIN_SHIFT) | (64 << _PDM_CTRL_DSR_SHIFT));</pre> ``` - · Configure PDM interrupts - Enable PDM module PDM->EN = PDM\_EN\_EN - · Configure LDMA to capture the Data - · Start the Filter ``` while(PDM->SYNCBUSY !=0); PDM->CMD = PDM_CMD_START; ``` In ISR routine, If there is overflow or underflow is set, without stopping the filter issue the FLUSH command. ``` while(PDM->SYNCBUSY !=0); PDM->CMD = PDM_CMD_FIFOFL; ``` After the desired number of samples are collected, if PDM need to be stopped then # Stop PDM filter ``` while(PDM->SYNCBUSY !=0); PDM->CMD = PDM_CMD_STOP; ``` #### CLEAR PDM filter ``` while(PDM->SYNCBUSY !=0); PDM->CMD = PDM_CMD_CLEAR; ``` ### FLUSH PDM FIFO ``` while(PDM->SYNCBUSY !=0); PDM->CMD = PDM_CMD_FIFOFL; ``` Disable PDM module # 20.4 Applications ## 20.4.1 PDM Microphones Micro-Electrical Mechanical (MEMS) microphones offer lower cost, smaller packages, and better reliability than electret microphones. These microphones are available with analog or digital PDM outputs. The PDM version does not require an expensive audio quality ADC and offer a lower overall system cost. This PDM module works with most MEMS microphones with a PDM digital output. Internal to the PDM microphone, an analog signal drives a sigma delta modulator and outputs a Pulse Density Modulated bit stream. The MCU provides a clock to the microphone and the microphone provides a signal back. Some PDM microphones support stereo using both edges of the clock. This eliminates one of the wires, which is important for some products when the wiring and/or connector cost are significant. It also frees up on additional GPIO pin on the MCU. Note that it is also possible to support stereo using one clock and two signal wires, one for right and one for left, this just uses more pins and more wire connects. A high quality audio codec might use a 256x oversampling ratio with a 12.288 MHz clock for 48 kHz audio. The PDM microphones have a limited bandwidth for the oversampling clock. Most MEMS PDM microphones have a 1-3 MHz range. It is common to use exactly 3.072 MHz for 48 kHz audio. Because of the limited oversampling clock range, the CIC filter for PDM microphones must have a lower oversampling ratio and a higher order than other applications. Most PDM microphones use a 4th order sigma delta modulator and require a 5th order decimation filter. The 5th order filter will provide a 16 bit ENOB with a 48 kHz sample rate and 1.536 MHz clock rate (32x OSR). | | | F <sub>clk</sub> (MHz) | | | | | | | | | | | | | |-----|-------------------------|-------------------------|-------------------------|-------------------------|-------|---------|--|--|--|--|--|--|--|--| | | 3.072 | 2.8224 | 1.536 | 1.024 | LINOD | s order | | | | | | | | | | OSR | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | 4 | 5 | | | | | | | | | | 16 | 192 | 176.4 | 96 | 64 | 10.7 | 13.3 | | | | | | | | | | 32 | 96 | 88.2 | 48 | 32 | 14.2 | 17.8 | | | | | | | | | | 64 | 48 | 44.1 | 24 | 16 | 17.7 | 22.3 | | | | | | | | | | 128 | 24 | 22.05 | 12 | 8 | 21.2 | - | | | | | | | | | ## 20.4.2 Isolated Sigma Delta Modulators The PDM module also supports isolated sigma delta modulators with a clock in and sigma delta output, such as the Silicon Labs Si8940. The desired sample frequency depends on the chip limits of the isolated sigma delta converter, and also the application. Most isolated sigma delta modulators have a limit of 10 or 20 MHz. For industrial motor control, the common PWM and sample frequencies are 16 kHz, 12 kHz, and 8 kHz. Electric metering applications are required to measure the harmonics up to the 50th harmonic, and the sample rate must be at least twice this frequency. So the sample frequency must be at least 5 kHz for 50 Hz, or 6 kHz for 60 Hz. The table below summarizes the typical sampling frequencies. A third order filter is generally sufficient for most isolated sigma delta applications. Most available sigma delta modulators are second order. There is no need to use higher than third order to achieve a high ENOB using a low clock rate, as with the PDM microphones. However, there is a need for higher decimation ratios to achieve the desired low sample frequencies. A max DSR of 256 will support near 24-bit performance with an output word rate of 10 to 20 kHz. Most available isolated sigma delta modulators are limited to an ENOB of only 14 bits. So using a higher OSR will not necessarily result in a higher ENOB or signal to noise ration. However, using a higher OSR will result in a lower output word rate. | | | | F <sub>clk</sub> ( | MHz) | | | | <u> </u> | | |------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|------|----------|-------| | | Chip | Limits | Motor ( | Control | Mete | ering | ENO | B vs o | order | | | 20 | 10 | 16.384 | 12.288 | 12.288 | 10.24 | | | | | OSR | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | F <sub>samp</sub> (kHz) | 3 | 4 | 5 | | 16 | 1250. | 625. | 1024 | 768 | 768 | 640 | 8.2 | 10.7 | 13.3 | | 32 | 625. | 312.5 | 512 | 384 | 384 | 320 | 10.7 | 14.2 | 17.8 | | 64 | 312.5 | 156.25 | 256 | 192 | 192 | 160 | 13.2 | 17.7 | 22.3 | | 128 | 156.25 | 78.125 | 128 | 96 | 96 | 80 | 15.7 | 21.2 | | | 256 | 78.125 | 39.063 | 64 | 48 | 48 | 40 | 18.2 | | | | 512 | 39.063 | 19.531 | 32 | 24 | 24 | 20 | 20.7 | | | | 1024 | 19.531 | 9.766 | 16 | 12 | 12 | 10 | 23.2 | | | # 20.5 PDM Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|-------------------|-------------|----------------------------------| | 0x000 | PDM_IPVERSION | R | IP Version ID | | 0x004 | PDM_EN | RW ENABLE | PDM Module enable Register | | 0x008 | PDM_CTRL | RW SYNC | PDM Core Control Register | | 0x00C | PDM_CMD | W SYNC | PDM Core Command Register | | 0x010 | PDM_STATUS | RH | PDM Status register | | 0x014 | PDM_CFG0 | RW CONFIG | PDM Core Configuration Register0 | | 0x018 | PDM_CFG1 | RW CONFIG | PDM Core Configuration Register1 | | 0x020 | PDM_RXDATA | R(r)H | PDM Received Data Register | | 0x040 | PDM_IF | RWH INTFLAG | Interrupt Flag Register | | 0x044 | PDM_IEN | RW | Interrupt Flag Register | | 0x060 | PDM_SYNCBUSY | RH | Synchronization Busy Register | | 0x1000 | PDM_IPVERSION_SET | R | IP Version ID | | 0x1004 | PDM_EN_SET | RW ENABLE | PDM Module enable Register | | 0x1008 | PDM_CTRL_SET | RW SYNC | PDM Core Control Register | | 0x100C | PDM_CMD_SET | W SYNC | PDM Core Command Register | | 0x1010 | PDM_STATUS_SET | RH | PDM Status register | | 0x1014 | PDM_CFG0_SET | RW CONFIG | PDM Core Configuration Register0 | | 0x1018 | PDM_CFG1_SET | RW CONFIG | PDM Core Configuration Register1 | | 0x1020 | PDM_RXDATA_SET | R(r)H | PDM Received Data Register | | 0x1040 | PDM_IF_SET | RWH INTFLAG | Interrupt Flag Register | | 0x1044 | PDM_IEN_SET | RW | Interrupt Flag Register | | 0x1060 | PDM_SYNCBUSY_SET | RH | Synchronization Busy Register | | 0x2000 | PDM_IPVERSION_CLR | R | IP Version ID | | 0x2004 | PDM_EN_CLR | RW ENABLE | PDM Module enable Register | | 0x2008 | PDM_CTRL_CLR | RW SYNC | PDM Core Control Register | | 0x200C | PDM_CMD_CLR | W SYNC | PDM Core Command Register | | 0x2010 | PDM_STATUS_CLR | RH | PDM Status register | | 0x2014 | PDM_CFG0_CLR | RW CONFIG | PDM Core Configuration Register0 | | 0x2018 | PDM_CFG1_CLR | RW CONFIG | PDM Core Configuration Register1 | | 0x2020 | PDM_RXDATA_CLR | R(r)H | PDM Received Data Register | | 0x2040 | PDM_IF_CLR | RWH INTFLAG | Interrupt Flag Register | | 0x2044 | PDM_IEN_CLR | RW | Interrupt Flag Register | | 0x2060 | PDM_SYNCBUSY_CLR | RH | Synchronization Busy Register | | 0x3000 | PDM_IPVERSION_TGL | R | IP Version ID | | 0x3004 | PDM_EN_TGL | RW ENABLE | PDM Module enable Register | | Offset | Name | Туре | Description | |--------|------------------|-------------|----------------------------------| | 0x3008 | PDM_CTRL_TGL | RW SYNC | PDM Core Control Register | | 0x300C | PDM_CMD_TGL | W SYNC | PDM Core Command Register | | 0x3010 | PDM_STATUS_TGL | RH | PDM Status register | | 0x3014 | PDM_CFG0_TGL | RW CONFIG | PDM Core Configuration Register0 | | 0x3018 | PDM_CFG1_TGL | RW CONFIG | PDM Core Configuration Register1 | | 0x3020 | PDM_RXDATA_TGL | R(r)H | PDM Received Data Register | | 0x3040 | PDM_IF_TGL | RWH INTFLAG | Interrupt Flag Register | | 0x3044 | PDM_IEN_TGL | RW | Interrupt Flag Register | | 0x3060 | PDM_SYNCBUSY_TGL | RH | Synchronization Busy Register | # 20.6 PDM Register Description # 20.6.1 PDM\_IPVERSION - IP Version ID | Offset | Bit Position | | | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--| | 0x000 | 30<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | | | | | | | | | | | | | | Reset | 0X0 | | | | | | | | | | | | | | Access | <u>~</u> | | | | | | | | | | | | | | Name | IPVERSION | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------|--------|-------------| | 31:0 | IPVERSION | 0x0 | R | IP VERSION | | | Indicates the version of | IP | | | # 20.6.2 PDM\_EN - PDM Module enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|-----| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | • | | • | | | | | | | | | | | | • | | | | | | | | • | • | • | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | EN | | 31:1 Reserved To ensure compatibility with future devices, always write bits ventions 0 EN 0x0 RW PDM enable | | |---------------------------------------------------------------------------------------------------------------|------------------------------------| | 0 EN 0x0 RW PDM enable | to 0. More information in 1.2 Con- | | | | | when set to 1, module is enabled | | | Value Mode Description | | | 0 DISABLE Disable module | | | 1 ENABLE Enable module | | # 20.6.3 PDM\_CTRL - PDM Core Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|-----|----|----|---|----|---|---|---|---|---|---|---|------|---|---| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | • | | • | | • | | | • | | • | | | | | | > | 2 | | | | | | | | | | | 0x0 | | | | Access | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | | | | | | | ₩ | | | | Name | | | | | | | | | | | | | | | | | | 000 | 2 | | | | | | | | | | | GAIN | | | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensur ventions | | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:8 | DSR | 0x0 | RW | Down sampling rate of Decimation filter | | | Down sampling rate | e, it can be an in | teger or powe | r of 2 . | | 7:5 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 4:0 | GAIN | 0x0 | RW | Selects Gain factor of DCF | | | Selects Gain factor | of DCF . | | | # 20.6.4 PDM\_CMD - PDM Core Command Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|--------|------|----|----|----|---|----|---|-------|---|---|---|------|---|---|---|-------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | • | | | | | | • | | | | | • | • | | 000 | | • | | | | | | 0X0 | | | • | 0X0 | | | • | 0x0 | | Access | | | | | | | | | | | | | | | | > | | | | | | | | > | | | | > | | | | > | | Name | | | | | | | | | | | | | | | | FIFOFL | | | | | | | | CLEAR | | | | STOP | | | | START | | Bit | Name | Reset | Access | Description | |-------|---------------------|-----------------------|-----------------|---------------------------------------------------------------------------| | 31:17 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 16 | FIFOFL | 0x0 | W | FIFO Flush | | | one hot for selecti | vely clearing the fil | ter. | | | 15:9 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 8 | CLEAR | 0x0 | W | Clear DCF | | | one hot for selecti | vely clearing the fil | ter. | | | 7:5 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 4 | STOP | 0x0 | W | Stop DCF | | | one hot for selecti | vely stoping the filt | er. | | | 3:1 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 0 | START | 0x0 | W | Start DCF | | | | | | | # 20.6.5 PDM\_STATUS - PDM Status register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|----------|---|---|---|-------|------|---|---|---|-----| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | • | | | • | | | | • | | • | • | • | | | | | | | 0x0 | • | | • | 0X | 0x0 | | • | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | <u>~</u> | | | | œ | œ | | | | ~ | | Name | | | | | | | | | | | | | | | | | | | | | | | FIFOCNT | | | | EMPTY | FULL | | | | ACT | | D:4 | Nome | Dooot | A | Description | |-------|----------------------|----------------------|-----------------|---------------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 31:11 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 10:8 | FIFOCNT | 0x0 | R | FIFO CNT | | | Indicates number of | valid data word | s in the PDM | FIFO. | | 7:6 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 5 | EMPTY | 0x1 | R | FIFO EMPTY Status | | | Indicates PDM FIFO | is Empty. | | | | 4 | FULL | 0x0 | R | FIFO FULL Status | | | Indicates PDM FIFO | is Full. | | | | 3:1 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 0 | ACT | 0x0 | R | PDM is active | | | Indicates PDM is rur | nning. | | | # 20.6.6 PDM\_CFG0 - PDM Core Configuration Register0 | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|-----------|-----------|----|----|----|----|----|----|----|----------------|------|----|-------|---------|---|----|------------|---|---|---|---|--------|---|---|--------| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | - 0 | | Reset | | | | | | • | 000 | 0x0 | | | | | | | | 000 | | | Ç | Š | | | 0×0 | • | | | • | 0x0 | | | 0x0 | | Access | | | | | | | ₩<br>N | RW | | | | | | | | ₩<br>M | | | 2 | ≥<br>Y | | | ΑW | | | | | ₩<br>W | | | RW | | Name | | | | | | | CH1CLKPOL | CH0CLKPOL | | | | | | | | STEREOMODECH01 | | | NA CL | FIFODVL | | | DATAFORMAT | | | | | NUMCH | | | FORDER | | Bit | Name | Reset A | ccess | Description | |-------|------------------------|---------------------------|------------------|----------------------------------------------------------------------| | 31:26 | Reserved | To ensure com<br>ventions | npatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 25 | CH1CLKPOL | 0x0 R | W | CH1 CLK Polarity | | | Configure CH1 CLK Pol | arity. | | | | | Value | Mode | | Description | | | 0 | NORMAL | | Input data clocked on rising clock edge. | | | 1 | INVERT | | Input data clocked on falling clock edge. | | 24 | CH0CLKPOL | 0x0 R' | W | CH0 CLK Polarity | | | Configure CH0 CLK Pol | arity. | | | | | Value | Mode | | Description | | | 0 | NORMAL | | Input data clocked on rising clock edge. | | | 1 | INVERT | | Input data clocked on falling clock edge. | | 23:17 | Reserved | To ensure com | npatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 16 | STEREOMODECH01 | 0x0 R | W | Stereo mode CH01 | | | Stereo mode Configurat | tion for Channel p | air CH0 and | CH1. | | | Value | Mode | | Description | | | 0 | DISABLE | | No Stereo mode. | | | 1 | CH01ENABLE | | CH0 and CH1 in Stereo mode. | | 15:14 | Reserved | To ensure com | patibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 13:12 | FIFODVL | 0x0 R' | W | Data Valid level in FIFO | | | Configure FIFO Data va | ılid level, water-ma | ark. | | | | Value | Mode | | Description | | | 0 | ONE | | Atleast one word. | | Bit | Name | Reset | Access | Description | |------|--------------------------|--------------|--------------------|----------------------------------------------------------------------| | | 1 | TWO | | Two words. | | | 2 | THREE | | Three words. | | | 3 | FOUR | | Four words. | | 11 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 10:8 | DATAFORMAT | 0x0 | RW | Filter output format | | | Configure Filter data ou | tput format. | | | | | Value | Mode | | Description | | | 0 | RIGHT16 | | Right aligned 16-bit, left bits are sign extended. | | | 1 | DOUBLE16 | | Pack two 16-bit samples into one 32-bit word. | | | 2 | RIGHT24 | | Right aligned 24bit, left bits are sign extended. | | | 3 | FULL32BIT | | 32 bit data. | | | 4 | LEFT16 | | Left aligned 16-bit, right bits are zeros. | | | 5 | LEFT24 | | Left aligned 24-bit, right bits are zeros. | | | 6 | RAW32BIT | | RAW 32 bit data from Integrator. | | 7:5 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | NUMCH | 0x0 | RW | Number of Channels | | | Number of Channels. | | | | | | Value | Mode | | Description | | | 0 | ONE | | One channel. | | | 1 | TWO | | Two channels. | | 3:2 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | FORDER | 0x0 | RW | Filter order | | | Configure order of the F | ilter. | | | | | Value | Mode | | Description | | | 0 | SECOND | | Second order filter. | | | 1 | THIRD | | Third order filter. | | | 2 | FOURTH | | Fourth order filter. | | | 3 | FIFTH | | Fifth order filter. | # 20.6.7 PDM\_CFG1 - PDM Core Configuration Register1 | Offset | | Bit Position | | |--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------| | 0x018 | 30 30 29 27 27 26 | 25 26 27 28 29 20 20 20 20 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>0 8 7 0 7 4 8 7 1 0</th> | 0 8 7 0 7 4 8 7 1 0 | | Reset | | 0×0 | 0×0 | | Access | | Z X | AW W | | Name | | DLYMUXSEL | PRESC | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:26 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 25:24 | DLYMUXSEL | 0x0 | RW | Data delay buffer mux selection | | | mux selection for delay | buffer on dat | ta path | | | 23:10 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 9:0 | PRESC | 0x0 | RW | Prescalar Setting for PDM sample | | | Generate Decimation fi | Iter clock | | | # 20.6.8 PDM\_RXDATA - PDM Received Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----------|----|----|----|----|----|----|----|----|----|----|----|---|----|------------------|-----------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 000 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | )X<br>OX | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | \<br>\<br>\<br>\ | 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|--------|-------------------| | 31:0 | RXDATA | 0x0 | R(r) | PDM received data | | | Use this register to acce | ss data from l | FIFO. | | # 20.6.9 PDM\_IF - Interrupt Flag Register | Offset | Bit Position | | | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------------| | 0x040 | 33 34 35 36 37 38 39 30 30 30 30 30 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>က</th> <th>7</th> <th>- 0</th> | က | 7 | - 0 | | Reset | | 0x0 | 0x0 | 000 | | Access | | Z. | > | R<br>W<br>W | | Name | | UF | OF | DA DA | | Bit | Name | Reset | Access | Description | |------|-----------------------------|------------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 3 | UF | 0x0 | RW | FIFO Undeflow Interrupt Flag | | | Set when the FIFO Unde | erflow condition | n. | | | 2 | OF | 0x0 | RW | FIFO Overflow Interrupt Flag | | | Set when the FIFO Over | flow condition | l <b>.</b> | | | 1 | DVL | 0x0 | RW | Data Valid Level Interrupt Flag | | | Set when the FIFO read | nes to waterm | ark level. | | | 0 | DV | 0x0 | RW | Data Valid Interrupt Flag | | | This interrupt is set after | valid data ava | ailable in FIFO. | | # 20.6.10 PDM\_IEN - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|--------|-----|-----|--------| | 0x044 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | | | • | | | • | ' | | • | • | | | ' | | | | | | | | | | • | 0X0 | 0×0 | 0×0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | W<br>M | RW | RW | R<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ъ | OF | DVL | 20 | | Bit | Name | Reset | Access | Description | | | | | |------|-----------------------------------------------|--------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------|--|--|--|--| | 31:4 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Conventions | | | | | | | 3 | UF | 0x0 | RW | FIFO Undeflow Interrupt Enable | | | | | | | Set when the FIFO Un | derflow conditi | on. | | | | | | | 2 | OF | 0x0 | RW | FIFO Overflow Interrupt Enable | | | | | | | Set when the FIFO Ov | erflow conditio | n. | | | | | | | 1 | DVL | 0x0 | RW | Data Valid Level Interrupt Enable | | | | | | | Set when the FIFO reaches to watermark level. | | | | | | | | | 0 | DV | 0x0 | RW | Data Valid Interrupt Enable | | | | | | | This interrupt is set after | er valid data a | vailable in FIFO. | | | | | | # 20.6.11 PDM\_SYNCBUSY - Synchronization Busy Register | Offset | Bit Position | | | | | | | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|--|--|--|--|--| | 0x060 | 33 4 4 6 6 6 7 8 8 8 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 2 7 | 0 | | | | | | | Reset | | 0x0 | 0x0 | | | | | | | Access | | <u>د</u> | <u>~</u> | | | | | | | Name | | FIFOFLBUSY | SYNCBUSY | | | | | | | Bit | Name | Reset | Access | Description | | | | |------|----------------------|--------------------|----------------------------------------------------------------------------------------------------------|----------------------|--|--|--| | 31:4 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Coventions | | | | | | 3 | FIFOFLBUSY | 0x0 | R | FIFO Flush Sync busy | | | | | | Indicates FIFO Flush | n sync busy. | | | | | | | 2:1 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Conventions | | | | | | 0 | SYNCBUSY | 0x0 | R | sync busy | | | | | | Indicates START sy | nc busy. | | | | | | # 21. 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. # 21.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. #### 21.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<sub>USARTn</sub>) - · Max bit-rate - SPI master mode, peripheral clock rate/2 - SPI slave mode, peripheral clock rate/8 - 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 - · Master and slave mode - · 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 # 21.3 Functional Description An overview of the USART module is shown in Figure 21.1 USART Overview on page 558. This section describes all posible USART features. Please refer to the Device Datasheet to see what features a specific USART instance supports. Figure 21.1. USART Overview # 21.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 bus master, and both the master and slave sample and transmit data according to this clock. Both master and slave 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 21.1 USART Asynchronous vs. Synchronous Mode on page 559. Full duplex and half duplex communication is supported in both asynchronous and synchronous mode. Table 21.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 21.2 USART Pin Usage on page 559 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 21.3.2.14 Local Loopback and 21.3.3.3 Master Mode respectively. Table 21.2. USART Pin Usage | SYNC | LOOPBK | MASTER | Pin functionality | | | | | | |------|--------|--------|-------------------|-----------------|-----------|---------------------|--|--| | | LOUPBR | | U(S)n_TX (MOSI) | U(S)n_RX (MISO) | USn_CLK | USn_CS | | | | 0 | 0 | х | Data out | Data in | - | [Driver enable] | | | | 0 | 1 | х | Data out/in | - | - | [Driver enable] | | | | 1 | 0 | 0 | Data in | Data out | Clock in | Slave select | | | | 1 | 0 | 1 | Data out | Data in | Clock out | [Auto slave select] | | | | 1 | 1 | 0 | Data out/in | - | Clock in | Slave select | | | | 1 | 1 | 1 | Data out/in | - | Clock out | [Auto slave select] | | | # 21.3.2 Asynchronous Operation ### 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 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 21.2 USART Asynchronous Frame Format on page 560. Figure 21.2. USART Asynchronous Frame Format The number of data bits in a frame is set by DATABITS in USARTn\_FRAME, see Table 21.3 USART Data Bits on page 560, and the number of stop-bits is set by STOPBITS in USARTn\_FRAME, see Table 21.4 USART Stop Bits on page 560. 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 21.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 21.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. # 21.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 21.5 USART Parity Bits on page 561. 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 21.5. USART Parity Bits | PARITY BITS [1:0] | Description | |-------------------|-------------------------| | 00 | No parity bit (Default) | | 01 | Reserved | | 10 | Even parity | | 11 | Odd parity | #### 21.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 21.3 USART Baud Rate on page 562. br = f<sub>PCLK</sub>/(oversample x (1 + USARTn\_CLKDIV/256)) ## Figure 21.3. USART Baud Rate where $f_{PCLK}$ is the peripheral clock (PCLK<sub>USARTn</sub>) frequency and oversample is the oversampling rate as defined by OVS in USARTn CTRL, see Table 21.6 USART Oversampling on page 562. Table 21.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 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 brdesired, the clock divider USARTn\_CLKDIV can be calculated by using Figure 21.4 USART Desired Baud Rate on page 562: USARTn\_CLKDIV = 256 x (f<sub>PCLK</sub>/(oversample x brdesired) - 1) ### Figure 21.4. USART Desired Baud Rate Table 21.7 USART Baud Rates @ 4MHz Peripheral Clock with 20 bit CLKDIV on page 562 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 21.7. USART Baud Rates @ 4MHz Peripheral Clock with 20 bit CLKDIV | Desired baud | USAR | Γn_OVS =00 | | USARTn_OVS =01 | | | |---------------|-----------------------------------------|---------------------------|---------|-----------------------------------------|---------------------------|---------| | rate [baud/s] | 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 % | | 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] | USART | Tn_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 | ### 21.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. ### 21.3.2.5 Data Transmission Asynchronous data transmission is initiated by writing data to the transmit buffer using one of the methods described in 21.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. ## 21.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 21.5 USART Transmit Buffer Operation on page 564 shows the basics of the transmit buffer when DATABITS in USARTn\_FRAME is configured to less than 10 bits. Figure 21.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. #### 21.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. # 21.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. ### 21.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\_RXDOUBLEX 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\_RXDOUBLEX 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 21.6 USART Receive Buffer Operation on page 566. Figure 21.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. ## 21.3.2.10 Blocking Incoming Data When using hardware frame recognition, as detailed in 21.3.2.20 Multi-Processor Mode and 21.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 21.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. ## 21.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 21.7 USART Sampling of Start and Data Bits on page 568. 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 21.7 USART Sampling of Start and Data Bits on page 568. 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 21.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 21.8 USART Sampling of Stop Bits when Number of Stop Bits are 1 or More on page 569. 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 21.8 USART Sampling of Stop Bits when Number of Stop Bits are 1 or More on page 569, 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 21.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. # 21.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. #### 21.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. ## 21.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 21.9 USART Local Loopback on page 570. 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 21.9. USART Local Loopback ## 21.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. # 21.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 bus master, which first transmits a request to one of the bus slaves, 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 slave. The timer, 21.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, 21.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. ## 21.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, 21.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 21.10 USART Half Duplex Communication with External Driver on page 571 shows an example configuration where USn\_CS is used to automatically enable and disable an external driver. Figure 21.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/slave select when in synchronous mode (e.g. SPI). # 21.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 TXSTDE-LAY and CSSETUP delay in USARTn\_TIMING. For enabling the receiver either use RXENAT in USARTn\_TXDATAX or RXATXnEN in USARTn\_TRIGCTRL. ## 21.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 21.11 USART Transmission of Large Frames on page 572. The first element in the transmit buffer, i.e. element 0 in Figure 21.11 USART Transmission of Large Frames on page 572 is the first element written to the FIFO, or the least significant byte when writing two bytes at a time using USARTn TXDOUBLE. Figure 21.11. USART Transmission of Large Frames As shown in Figure 21.11 USART Transmission of Large Frames on page 572, 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 21.12. USART Transmission of Large Frames, MSBF Figure 21.12 USART Transmission of Large Frames, MSBF on page 572 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 21.13 USART Reception of Large Frames on page 573. 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 21.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. ## 21.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 slave 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. ### 21.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. ### 21.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 21.14 USART ISO 7816 Data Frame Without Error on page 574. 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 21.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 21.15 USART ISO 7816 Data Frame With Error on page 574. 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 21.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 21.16 USART SmartCard Stop Bit Sampling on page 575. 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 SKIPPERRF 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 21.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. ## 21.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. ## 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 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. #### 21.3.3.2 Clock Generation The bit-rate in synchronous mode is given by Figure 21.17 USART Synchronous Mode Bit Rate on page 576. 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 + USARTn_CLKDIV/256))$$ Figure 21.17. USART Synchronous Mode Bit Rate Given a desired baud rate brdesired, the clock divider USARTn\_CLKDIV can be calculated using Figure 21.18 USART Synchronous Mode Clock Division Factor on page 576 $$USARTn_CLKDIV = 256 \times (f_{PCLK}/(2 \times brdesired) - 1)$$ Figure 21.18. USART Synchronous Mode Clock Division Factor When the USART operates in master mode, the highest possible bit rate is half the peripheral clock rate. When operating in slave mode however, the highest bit rate is an eighth of the peripheral clock: - Master mode: br<sub>max</sub> = f<sub>PCLK</sub>/2 - Slave mode: br<sub>max</sub> = f<sub>PCLK</sub>/8 On every clock edge data on the data lines, MOSI and MISO, is either set up or sampled. When CLKPHA in USARTn\_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 USARTn\_CTRL, which also defines the idle state of the clock. This results in four different modes which are summarized in Table 21.8 USART SPI Modes on page 576. Figure 21.19 USART SPI Timing on page 576 shows the resulting timing of data set-up and sampling relative to the bus clock. Table 21.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 21.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 slave 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 RXDA-TAV 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. #### 21.3.3.3 Master Mode When in master mode, the USART is in full control of the data flow on the synchronous bus. When operating in full duplex mode, the slave cannot transmit data to the master without the master transmitting to the slave. The master 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 master 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. ### 21.3.3.4 Operation of USn\_CS Pin When operating in master mode, 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 slave 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 deas-serted, 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 master 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 slave mode. ### 21.3.3.5 AUTOTX A synchronous master is required to transmit data to a slave in order to receive data from the slave. In some cases, only a few words are transmitted and a lot of data is then received from the slave. 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. #### 21.3.3.6 Slave Mode When the USART is in slave mode, data transmission is not controlled by the USART, but by an external master. The USART is therefore not able to initiate a transmission, and has no control over the number of bytes written to the master. The output and input to the USART are also swapped when in slave mode, making the receiver take its input from USn\_TX (MOSI) and the transmitter drive USn\_RX (MISO). To transmit data when in slave mode, the slave must load data into the transmit buffer and enable the transmitter. The data will remain in the USART until the master starts a transmission by pulling the USn\_CS input of the slave low and transmitting data. For every frame the master transmits to the slave, a frame is transferred from the slave to the master. After a transmission, MISO remains in the same state as the last bit transmitted. This also applies if the master transmits to the slave and the slave TX buffer is empty. If the transmitter is enabled in synchronous slave mode and the master starts transmission of a frame, the underflow interrupt flag TXUF in USARTn\_IF will be set if no data is available for transmission to the master. If the slave needs to control its own chip select signal, this can be achieved by clearing CSPEN in the GPIO\_USARTn\_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. ### 21.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 21.3.2.15 Asynchronous Half Duplex Communication. The main difference is that in this mode, the master must generate the bus clock even when it is not transmitting data, i.e. it must provide the slave with a clock to receive data. To generate the bus clock, the master should transmit data with the transmitter tristated, i.e. TXTRI in USARTn\_STATUS set, when receiving data. If 2 bytes are expected from the slave, then transmit 2 bytes with the transmitter tristated, and the slave uses the generated bus clock to transmit data to the master. TXTRI can be set by setting the TXTRIEN command bit in USARTn\_CMD. **Note:** When operating as SPI slave in half duplex mode, TX has to be tristated (not disabled) during data reception if the slave is to transmit data in the current transfer. #### 21.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 master mode, this is automatically driven by the USART, and in slave mode, the word clock is expected from an external master. ### 21.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. ### 21.3.3.10 Major Modes The USART supports a set of different I2S formats as shown in Table 21.9 USART I2S Modes on page 579, 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 bee seen in figures Figure 21.22 USART Left-justified I2S waveform on page 580 and Figure 21.23 USART Right-justified I2S waveform on page 580. 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 21.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 21.20 USART Standard I2S waveform on page 579 and Figure 21.21 USART Standard I2S waveform (reduced accuracy) on page 579. 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 21.20. USART Standard I2S waveform Figure 21.21. USART Standard I2S waveform (reduced accuracy) A left-justified stream is shown in Figure 21.22 USART Left-justified I2S waveform on page 580. 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 21.22. USART Left-justified I2S waveform A right-justified stream is shown in Figure 21.23 USART Right-justified I2S waveform on page 580. The left and right justified streams are equal when the data-size is equal to the word-width. Figure 21.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 21.24 USART Mono I2S waveform on page 580. Figure 21.24. USART Mono I2S waveform ### 21.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 RXFULL-RIGHT 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 master and slave mode the USART always starts transmitting on the LEFT channel after being enabled. In master 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. ### 21.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\_DBUSUSARTn\_ROUTEEN, GPIO\_DBUSUSARTn\_RTSROUTEx and GPIO\_DBUSUSARTn\_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\_CTLX 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. ### 21.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. ### 21.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 ### 21.3.7 PRS RX Input The USART can be configured to receive clock directly from a PRS channel by setting RXPRSEN in USARTn\_CTRLX. The PRS channel used is selected using PRSSEL in PRS USARTn RX. ### 21.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 slave mode and can together with RX PRS input be used to input data from PRS. ### 21.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\_TXDOUBLE and USARTn\_TXDOUBLEX, 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. ### 21.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 21.25 USART Timer Block Diagram on page 584. Figure 21.25. USART Timer Block Diagram The following sections will go into more details on programming the various usage cases. Table 21.10. USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn | Application | TSTARTn | TSTOPn | TCMPVALn | Other | |------------------------|---------------------------|----------------|--------------------|--------------------------------------------------------------------------------------------------| | Response Timeout | TSTART0 = TXEOF | TSTOP0 = RXACT | TCMPVAL0<br>= 0x08 | TCMP0 in USARTn_IEN | | Receiver Timeout | TSTART1 = RXEOF | TSTOP1 = RXACT | TCMPVAL1<br>= 0x08 | TCMP1 in USARTn_IEN | | Large Receiver Timeout | TSTART1 =<br>RXEOF, TCMP1 | TSTOP1 = RXACT | TCMPVAL1<br>= 0xFF | TCMP1 in USARTn_IEN; TIME-<br>RRESTARTED in USARTn_STA-<br>TUS; RESTART1EN in<br>USARTn_TIMECMP1 | | Application | TSTARTn | TSTOPn | TCMPVALn | Other | |--------------------------------------------------|----------------------------------------------|---------------------------------------|-------------------------------------------|-------------------------------------------------------------------------------------| | Break Detect | TSTART1 = RXACT | TSTOP1 =<br>RXACTN | TCMPVAL1<br>= 0x0C | TCMP1 in USARTn_IEN | | TX delayed start of transmission and CS setup | TSTART0 = DISA-<br>BLE, TSTART1 =<br>DISABLE | TSTOP0 = TCMP0,<br>TSTOP1 = TCMP1 | TCMPVAL0<br>= 0x04,<br>TCMPVAL1<br>= 0x02 | TXDELAY = TCMP0, CSSETUP = TCMP1 in USARTn_TIMING; AUTOCS in USARTn_CTRL | | TX inter-character spacing | TSTART2 = DISA-<br>BLE | TSTOP2 = TCMP2 | TCMPVAL2<br>= 0x03 | ICS = TCMP2 in USARTn_TIMING;<br>AUTOCS in USARTn_CTRL | | TX Chip Select End Delay | TSTART1 = DISA-<br>BLE | TSTOP1 = TCMP1 | TCMPVAL1<br>= 0x04 | CSHOLD = TCMP1 in USARTn_TIMING; AUTOCS in USARTn_CTRL | | Response Delay | TSTART1 = RXEOF | TSTOP1 = TCMP1 | TCMPVAL1<br>= 0x08 | TXARX1EN in USARTn_TRIGCTRL | | Combined TX and RX Example | TSTART1 =<br>RXEOF, TSTART0<br>= TXEOF | TSTOP1 = TCMP1,<br>TSTOP0 = TCMP0 | TCMPVAL1<br>= 0x1C,<br>TCMPVAL0<br>= 0x10 | TXARX1EN, RXATX0EN in USARTn_TRIGCTRL; CSSETUP = 0x7, CSHOLD = 0x3 in USARTn_TIMING | | Combined Delayed TX and Receiver Timeout Example | TSTART0 =<br>TCMPVAL0,<br>TSTART1 = RXEOF | TSTOP0 =<br>RXACTN, TSTOP1<br>= RXACT | TCMPVAL0<br>= 0x20,<br>TCMPVAL1<br>= 0x0C | TXARX0EN in USARTn_TRIGCTRL; TCMP0 in USARTn_IEN | Table 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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. ## 21.3.10.1 Response Timeout Response Timeout is when a UART master sends a frame and expects the slave to respond within a certain number of baud-times. Refer to Table 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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 21.26. USART Response Timeout ### 21.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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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 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 21.27. USART RX Timeout ### 21.3.10.3 Break Detect LIN bus and half-duplex UARTs 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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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 21.28. USART Break Detection ### 21.3.10.4 TX Start Delay Some applications may require a delay before the start of transmission. This example in Figure 21.29 USART TXSEQ Timing on page 587 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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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 21.29. USART TXSEQ Timing ### 21.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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 for details on setting up this example. For this example in Figure 21.29 USART TXSEQ Timing on page 587 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. ### 21.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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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 21.29 USART TXSEQ Timing on page 587. ## 21.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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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 21.30. USART Response Delay #### 21.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 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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 for details on setting up this example. ### 21.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 21.10 USART Application Settings for USARTn\_TIMING and USARTn\_TIMECMPn on page 584 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 transitter 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. ### 21.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. ### 21.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. ### 21.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 21.31 USART Example RZI Signal for a given Asynchronous USART Frame on page 589. Figure 21.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 modula- 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 21.11 USART IrDA Pulse Widths on page 589. | 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 | Table 21.11. USART IrDA Pulse Widths 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. # 21.4 USART Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | 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_RXDATAX | 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_RXDATAXP | RH | RX Buffer Data Extended Peek Register | | 0x034 | USART_RXDOUBLEXP | RH | RX Buffer Double Data Extended Peek R | | 0x038 | USART_TXDATAX | 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 | Used to generate interrupts and vario | | 0x064 | USART_TIMECMP1 | RW | Used to generate interrupts and vario | | 0x068 | USART_TIMECMP2 | RW | Used to generate interrupts and vario | | 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 | Туре | Description | |--------|----------------------|-------------|-----------------------------------------| | 0x1020 | USART_RXDATAX_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_TXDATAX_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 | Used to generate interrupts and vario | | 0x1064 | USART_TIMECMP1_SET | RW | Used to generate interrupts and vario | | 0x1068 | USART_TIMECMP2_SET | RW | Used to generate interrupts and vario | | 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_RXDATAX_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_TXDATAX_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 | Туре | 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 | Used to generate interrupts and vario | | 0x2064 | USART_TIMECMP1_CLR | RW | Used to generate interrupts and vario | | 0x2068 | USART_TIMECMP2_CLR | RW | Used to generate interrupts and vario | | 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_RXDATAX_TGL | RH | RX Buffer Data Extended Register | | 0x3024 | USART_RXDATA_TGL | RH | RX Buffer Data Register | | 0x3028 | USART_RXDOUBLEX_TGL | RH | RX Buffer Double Data Extended Register | | 0x302C | USART_RXDOUBLE_TGL | RH | RX FIFO Double Data Register | | 0x3030 | USART_RXDATAXP_TGL | RH | RX Buffer Data Extended Peek Register | | 0x3034 | USART_RXDOUBLEXP_TGL | RH | RX Buffer Double Data Extended Peek R | | 0x3038 | USART_TXDATAX_TGL | W | TX Buffer Data Extended Register | | 0x303C | USART_TXDATA_TGL | W | TX Buffer Data Register | | 0x3040 | USART_TXDOUBLEX_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 | Used to generate interrupts and vario | | 0x3064 | USART_TIMECMP1_TGL | RW | Used to generate interrupts and vario | | 0x3068 | USART_TIMECMP2_TGL | RW | Used to generate interrupts and vario | # 21.5 USART Register Description # 21.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 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 000 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | <u>د</u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | וייטויסם ביימו | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IPVERSION | | | The read only IPVERSIO modules with different va | - | | this module. There may be minor software changes required for | # 21.5.2 USART\_EN - USART Enable | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|----|---|----|----|---|----|---|---|---|---|---|---|---|---|---|--------| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | • | • | | | • | | | | | | | | | | • | | • | | | | | | | | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z | | Bit | Name | Reset | Access | Description | |------|----------|--------------------------------------------------------------------------------------------|--------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | USART Enable | | | | d write to CONFIG type registers before setting the ENABLE bit. er setting the ENABLE bit. | | | # 21.5.3 USART\_CTRL - Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----------|---------|-------------|----------|----|----|----------|---------|--------|-------------|--------|-------------|-----------|-------------|---------|--------|-------------|-------|--------|-------|-------------|------|--------|--------|---|----|----------|------|-----|--------|--------|------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | 000 | 000 | 0X0 | | • | 0X0 | 0×0 | 000 | 0×0 | 0X0 | 0×0 | 0X0 | 000 | 000 | 0X0 | 0x0 | 000 | 0×0 | 000 | 0×0 | 0X0 | 0×0 | 0X0 | | 2 | Š | 0X0 | 0X0 | 0x0 | 0x0 | 0x0 | | Access | ₩<br>M | RW<br>W | R<br>N<br>N | Z. | | | Z. | RW<br>W | ₹ | R<br>M<br>M | ∑ | R<br>N<br>N | Z. | R<br>N<br>N | ₩<br>M | Z. | R<br>N<br>N | ₹ | R<br>W | ₹ | R<br>M<br>M | Z. | RW | Z. | | 2 | <u>}</u> | R. | Z. | ₩<br>M | RW | RW | | Name | SMSDELAY | MVDIS | AUTOTX | BYTESWAP | | | SSSEARLY | ERRSTX | ERRSRX | ERRSDMA | BIT8DV | SKIPPERRF | SCRETRANS | SCMODE | AUTOTRI | AUTOCS | CSINV | 1XINV | RXINV | TXBIL | CSMA | MSBF | CLKPHA | CLKPOL | | ų, | n<br>0 | MPAB | MPM | CCEN | LOOPBK | SYNC | | Bit | Name | Reset | Access | Description | | | | | | | | |-------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31 | SMSDELAY | 0x0 | RW | Synchronous Master Sample Delay | | | | | | | | | | Delay Synchronous Master sample point to the next setup edge to improve timing and allow communication at hi speeds | | | | | | | | | | | | 30 | MVDIS | 0x0 | RW | Majority Vote Disable | | | | | | | | | | Disable majority vote for 16x, 8x and 6x oversampling modes. | | | | | | | | | | | | 29 | AUTOTX | 0x0 | RW | Always Transmit When RX Not Full | | | | | | | | | | Transmits as long a | Transmits as long as RX is not full. If TX is empty, underflows are generated. | | | | | | | | | | | 28 | BYTESWAP | 0x0 | RW | Byteswap In Double Accesses | | | | | | | | | | 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 | To ensur | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 25 | SSSEARLY | 0x0 | RW | Synchronous Slave Setup Early | | | | | | | | | | Setup data on sam | ple edge in sync | hronous slave n | node to improve MOSI setup time | | | | | | | | | 24 | ERRSTX | 0x0 | RW | Disable TX On Error | | | | | | | | | | When set, the trans | smitter is disable | d on framing an | d 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 | Disable RX On Error | | | | | | | | | | When set, the recei | iver is disabled o | on framing and p | 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 | Halt DMA On Error | | | | | | | | | When set, DMA reque | ests will be clea | red on framing a | 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 | Bit 8 Default Value | | | | | | | | | The default value of the fied, the 9th bit is set to | | | ed, and an 8-bit write operation is done, leaving the 9th bit unspeci- | | | | | | | | 20 | SKIPPERRF | 0x0 | RW | Skip Parity Error Frames | | | | | | | | | When set, the receive | r discards fram | es with parity er | rors (asynchronous mode only). The PERR interrupt flag is still set. | | | | | | | | 19 | SCRETRANS | 0x0 | RW | SmartCard Retransmit | | | | | | | | | When in SmartCard menabled. | node, a NACK'e | ed frame will be | kept in the shift register and retransmitted if the transmitter is still | | | | | | | | 18 | SCMODE | 0x0 | RW | SmartCard Mode | | | | | | | | | Use this bit to enable | or disable Sma | | | | | | | | | | 17 | AUTOTRI | 0x0 | RW | Automatic TX Tristate | | | | | | | | | When enabled, TXTR transmission starts. | l is set by hard | ware whenever | the transmitter is idle, and TXTRI is cleared by hardware when | | | | | | | | | 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 | Automatic Chip Select | | | | | | | | | When enabled, the ou<br>when transmission en | | S will be activat | ed one baud-period before transmission starts, and deactivated | | | | | | | | 15 | CSINV | 0x0 | RW | Chip Select Invert | | | | | | | | | Default value is active low. This affects both the selection of external slaves, as well as the selection of the microcontroller as a slave. | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | 0 | DISABLE | | Chip select is active low | | | | | | | | | 1 | ENABLE | | Chip select is active high | | | | | | | | 14 | TXINV | 0x0 | RW | Transmitter output Invert | | | | | | | | | | | | y 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$ | | | | | | | | | Name | Reset Ac | cess | Description | | | | | | | | |----|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 13 | RXINV | 0x0 RV | ٧ | Receiver Input Invert | | | | | | | | | | 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 RV | V | TX Buffer Interrupt Level | | | | | | | | | | Determines the in | nterrupt and status level o | of the trans | smit buffer. | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 0 | EMPTY | | TXBL and the TXBL interrupt flag are set when the transmit buf-<br>fer becomes empty. TXBL is cleared when the buffer becomes<br>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 RV | ٧ | Action On Slave-Select In Master Mode | | | | | | | | | | This register dete master mode. | ermines the action to be p | erformed | when slave-select is configured as an input and driven low while in | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | | | | | | | | | | | 0 | NOACTION | | No action taken | | | | | | | | | | 0 | NOACTION<br>GOTOSLAVEM | IODE | No action taken Go to slave mode | | | | | | | | | 10 | | | | | | | | | | | | | 10 | 1<br>MSBF | GOTOSLAVEM<br>0x0 RV | V | Go to slave mode | | | | | | | | | 10 | 1<br>MSBF | GOTOSLAVEM<br>0x0 RV | V | Go to slave mode Most Significant Bit First | | | | | | | | | 10 | MSBF Decides whether | GOTOSLAVEM 0x0 RV data is sent with the leas | V | Go to slave mode Most Significant Bit First nt bit first, or the most significant bit first. | | | | | | | | | 10 | MSBF Decides whether Value | GOTOSLAVEM 0x0 RV data is sent with the leas Mode | V | Go to slave mode Most Significant Bit First Int bit first, or the most significant bit first. Description | | | | | | | | | 10 | 1 MSBF Decides whether Value 0 | GOTOSLAVEM 0x0 RV data is sent with the leas Mode DISABLE | V<br>st significa | Go to slave mode Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first | | | | | | | | | | 1 MSBF Decides whether Value 0 1 CLKPHA | GOTOSLAVEM 0x0 RV data is sent with the leas Mode DISABLE ENABLE 0x0 RV | V<br>et significa | Go to slave mode Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first Data is sent with the most significant bit first | | | | | | | | | | 1 MSBF Decides whether Value 0 1 CLKPHA | GOTOSLAVEM 0x0 RV data is sent with the leas Mode DISABLE ENABLE 0x0 RV | V<br>et significa | Go to slave mode Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first Data is sent with the most significant bit first Clock Edge For Setup/Sample | | | | | | | | | | MSBF Decides whether Value 0 1 CLKPHA Determines where | GOTOSLAVEM 0x0 RV data is sent with the leas Mode DISABLE ENABLE 0x0 RV e data is set-up and sam | V<br>et significa | Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first Data is sent with the most significant bit first Clock Edge For Setup/Sample rding to the bus clock when in synchronous mode. | | | | | | | | | | MSBF Decides whether Value 0 1 CLKPHA Determines where Value | GOTOSLAVEM 0x0 RV data is sent with the leas Mode DISABLE ENABLE 0x0 RV e data is set-up and samp | V st significa V pled acco | Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first Data is sent with the most significant bit first Clock Edge For Setup/Sample Inding to the bus clock when in synchronous mode. Description Data is sampled on the leading edge and set-up on the trailing | | | | | | | | | | MSBF Decides whether Value 0 1 CLKPHA Determines where Value 0 | GOTOSLAVEM 0x0 RV data is sent with the lease Mode DISABLE ENABLE 0x0 RV e data is set-up and samp Mode SAMPLELEADI | V st significa V pled acco | Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first Data is sent with the most significant bit first Clock Edge For Setup/Sample Inding to the bus clock when in synchronous mode. Description Data is sampled on the leading edge and set-up on the trailing edge of the bus clock in synchronous mode Data is set-up on the leading edge and sampled on the trailing | | | | | | | | | 9 | MSBF Decides whether Value 0 1 CLKPHA Determines where Value 0 1 | GOTOSLAVEM 0x0 RV data is sent with the leas Mode DISABLE ENABLE 0x0 RV e data is set-up and samp Mode SAMPLELEADI SAMPLETRAIL | V st significa V pled acco | Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first Data is sent with the most significant bit first Clock Edge For Setup/Sample Inding to the bus clock when in synchronous mode. Description Data is sampled on the leading edge and set-up on the trailing edge of the bus clock in synchronous mode Data is set-up on the leading edge and sampled on the trailing edge of the bus clock in synchronous mode Clock Polarity | | | | | | | | | 9 | MSBF Decides whether Value 0 1 CLKPHA Determines where Value 0 1 | GOTOSLAVEM 0x0 RV data is sent with the lease Mode DISABLE ENABLE 0x0 RV e data is set-up and samp Mode SAMPLELEADI SAMPLETRAIL | V st significa V pled acco | Most Significant Bit First Int bit first, or the most significant bit first. Description Data is sent with the least significant bit first Data is sent with the most significant bit first Clock Edge For Setup/Sample Inding to the bus clock when in synchronous mode. Description Data is sampled on the leading edge and set-up on the trailing edge of the bus clock in synchronous mode Data is set-up on the leading edge and sampled on the trailing edge of the bus clock in synchronous mode Clock Polarity | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |-----|--------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | | 1 | IDLEHIGH | | The bus clock used in synchronous mode has a high base value | | | | | | | | | | 7 | Reserved | To ensure ventions | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con | | | | | | | | | | 6:5 | ovs | 0x0 | RW | Oversampling | | | | | | | | | | | Sets the number of clo<br>gives better performan | • | a UART bit-period | d. More clock cycles gives better robustness, while less clock cycles | | | | | | | | | | | 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 | Multi-Processor Address-Bit | | | | | | | | | | | Defines the value of the the frame as a multi-p | | | An incoming frame with its 9th bit equal to the value of this bit marks | | | | | | | | | | 3 | MPM | 0x0 | RW | Multi-Processor Mode | | | | | | | | | | | 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 | Collision Check Enable | | | | | | | | | | | Enables collision chec | king on data w | hen 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 | Loopback Enable | | | | | | | | | | | Allows the receiver to | be connected | directly to the US | ART 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 | USART Synchronous Mode | | | | | | | | | | | Determines whether the | ne USART is o | perating in async | hronous or synchronous mode. | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | | r · · | | | | | | | | | | Bit | Name | Reset Acces | s Description | |-----|------|-------------|-----------------------------------------| | | 0 | DISABLE | The USART operates in asynchronous mode | | | 1 | ENABLE | The USART operates in synchronous mode | # 21.5.4 USART\_FRAME - USART Frame Format Register | Offset | Bit Position | | | | | | | | | | | | | |--------|----------------------------------------------------------------|--------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x00C | 33 3 3 4 5 2 6 2 8 8 8 7 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 | | | | | | | | | | | | | | Reset | | 000 000 | | | | | | | | | | | | | Access | | W W W | | | | | | | | | | | | | Name | | STOPBITS PARITY DATABITS | | | | | | | | | | | | | Bit | it Name Reset Acces | | Access | Description | | | | | | |-------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31:14 | Reserved | To ensure<br>ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 13:12 | STOPBITS | 0x1 | RW | Stop-Bit Mode | | | | | | | | Determines the nu | ımber of stop-bits ı | used. | | | | | | | | | 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 | ONEANDA | AHALF | 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 | | | | | | | | | | To ensure compatibility with future devices, always write bits to 0. More information in ventions | | | | | | | | 11:10 | Reserved | | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | Reserved PARITY | | RW | vith future devices, always write bits to 0. More information in 1.2 Con-<br>Parity-Bit Mode | | | | | | | 9:8 | PARITY | ventions<br>0x0 | RW | | | | | | | | | PARITY Determines wheth | ventions<br>0x0 | RW | Parity-Bit Mode | | | | | | | | PARITY Determines wheth nous mode. | ventions 0x0 er parity bits are e | RW | Parity-Bit Mode sether even or odd parity should be used. Only available in asynchro- | | | | | | | | PARITY Determines wheth nous mode. Value | ventions 0x0 er parity bits are e | RW | Parity-Bit Mode sether even or odd parity should be used. Only available in asynchro- Description | | | | | | | | PARITY Determines wheth nous mode. Value | ox0 er parity bits are e Mode NONE | RW | Parity-Bit Mode whether even or odd parity should be used. Only available in asynchro- Description Parity bits are not used Even parity are used. Parity bits are automatically generated | | | | | | | | PARITY Determines wheth nous mode. Value 0 2 | wentions 0x0 er parity bits are e Mode NONE EVEN ODD | RW<br>nabled, and wh | Parity-Bit Mode Tether even or odd parity should be used. Only available in asynchro- Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. | | | | | | | 9:8 | PARITY Determines wheth nous mode. Value 0 2 | wentions 0x0 er parity bits are e Mode NONE EVEN ODD | RW<br>nabled, and wh | Parity-Bit Mode Tether even or odd parity should be used. Only available in asynchro- Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. | | | | | | | 9:8 | PARITY Determines wheth nous mode. Value 0 2 3 Reserved | wentions 0x0 er parity bits are e Mode NONE EVEN ODD To ensure ventions 0x5 | RW nabled, and wh | Parity-Bit Mode wether even or odd parity should be used. Only available in asynchro- Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. With future devices, always write bits to 0. More information in 1.2 Con- Data-Bit Mode | | | | | | | 9:8 | PARITY Determines wheth nous mode. Value 0 2 3 Reserved DATABITS | wentions 0x0 er parity bits are e Mode NONE EVEN ODD To ensure ventions 0x5 | RW nabled, and wh | Parity-Bit Mode wether even or odd parity should be used. Only available in asynchro- Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. With future devices, always write bits to 0. More information in 1.2 Con- Data-Bit Mode | | | | | | | 9:8 | PARITY Determines wheth nous mode. Value 0 2 3 Reserved DATABITS This register sets to | wentions 0x0 er parity bits are e Mode NONE EVEN ODD To ensure ventions 0x5 the number of data | RW nabled, and wh | Parity-Bit Mode The sether even or odd parity should be used. Only available in asynchro- Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. With future devices, always write bits to 0. More information in 1.2 Con- Data-Bit Mode RT frame. | | | | | | | 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 | # 21.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 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | • | | • | | • | | | | | | • | • | | 000 | 0×0 | 000 | 000 | 000 | 0x0 | 0x0 | 0X0 | 0x0 | | • | | | | Access | | | | | | | | | | | | | | | | | | | | 8 | RW<br>W | S. | ₩<br>M | S. | S. | S. | Z. | ₩<br>M | | | | | | Name | | | | | | | | | | | | | | | | | | | | RXATX2EN | RXATX1EN | RXATX0EN | TXARX2EN | TXARX1EN | TXARX0EN | AUTOTXTEN | TXTEN | RXTEN | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|----------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:13 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Conventions | | | | | | | | | | | 12 | RXATX2EN | 0x0 | RW | Enable Receive Trigger after TX end of f | | | | | | | | | | | When set, a TX end of f | ame will trigger the receiver after a TCMPVAL2 baud-time delay | | | | | | | | | | | | 11 | RXATX1EN | 0x0 | RW | Enable Receive Trigger after TX end of f | | | | | | | | | | | When set, a TX end of frame will trigger the receiver after a TCMPVAL1 baud-time delay | | | | | | | | | | | | | 10 | RXATX0EN | 0x0 | RW | Enable Receive Trigger after TX end of f | | | | | | | | | | | When set, a TX end of frame will trigger the receiver after a TCMPVAL0 baud-time delay | | | | | | | | | | | | | 9 | TXARX2EN | 0x0 | RW | Enable Transmit Trigger after RX End of | | | | | | | | | | | When set, an RX end of | frame will trig | ger the transmit | ter after TCMP2VAL bit times to force a minimum response delay | | | | | | | | | | 8 | TXARX1EN | 0x0 | RW | Enable Transmit Trigger after RX End of | | | | | | | | | | | When set, an RX end of | frame will trig | ger the transmit | ter after TCMP1VAL bit times to force a minimum response delay | | | | | | | | | | 7 | TXARX0EN | 0x0 | RW | Enable Transmit Trigger after RX End of | | | | | | | | | | | When set, an RX end of | frame will trig | ger the transmit | ter after TCMP0VAL bit times to force a minimum response delay | | | | | | | | | | 6 | AUTOTXTEN | 0x0 | RW | AUTOTX Trigger Enable | | | | | | | | | | | When set, AUTOTX is e | nabled as lon | g as the PRS ch | nannel selected by TSEL has a high value | | | | | | | | | | 5 | TXTEN | 0x0 | RW | Transmit Trigger Enable | | | | | | | | | | | When set, the PRS cha | nnel selected | by TSEL sets TX | KEN, enabling the transmitter on positive trigger edges. | | | | | | | | | | 4 | RXTEN | 0x0 | RW | Receive Trigger Enable | | | | | | | | | | | When set, the PRS cha | nnel selected | by TSEL sets R | XEN, enabling the receiver on positive trigger edges. | | | | | | | | | | 3:0 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | # 21.5.6 USART\_CMD - Command Register | Offset | Bit Position | | |--------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x014 | 33<br>30<br>30<br>22<br>22<br>22<br>22<br>22<br>22<br>22<br>22<br>21<br>19<br>10<br>11<br>11<br>11<br>11<br>12 | 0 0 8 7 0 0 4 6 7 7 0 | | Reset | | 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 | | Access | | 3 3 3 3 3 3 3 3 3 3 3 3 | | Name | | CLEARRX CLEARTX TXTRIDIS TXTRIEN RXBLOCKEN MASTEREN MASTEREN TXDIS TXEN TXEN RXDIS RXEN | | Bit | Name | Reset | Access | Description | | | | | | |-------|---------------------------------------------|--------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31:12 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 11 | CLEARRX | 0x0 | W | Clear RX | | | | | | | | Set to clear receive b | uffer and the R | X shift register. | | | | | | | | 10 | CLEARTX | 0x0 | W | Clear TX | | | | | | | | Set to clear transmit | buffer and the 1 | X shift register. | | | | | | | | 9 | TXTRIDIS | 0x0 | W | Transmitter Tristate Disable | | | | | | | | Disables tristating of | the transmitter | output. | | | | | | | | 8 | TXTRIEN | 0x0 | W | Transmitter Tristate Enable | | | | | | | | Tristates the transmit | ter output. | | | | | | | | | 7 | RXBLOCKDIS | 0x0 | W | Receiver Block Disable | | | | | | | | Set to clear RXBLOC | CK, resulting in a | all incoming frame | s being loaded into the receive buffer. | | | | | | | 6 | RXBLOCKEN | 0x0 | W | Receiver Block Enable | | | | | | | | Set to set RXBLOCK | , resulting in all | incoming frames | being discarded. | | | | | | | 5 | MASTERDIS | 0x0 | W | Master Disable | | | | | | | | Set to disable master | mode, clearing | g the MASTER sta | tus bit and putting the USART in slave mode. | | | | | | | 4 | MASTEREN | 0x0 | W | Master Enable | | | | | | | | | | | is bit. Master mode should not be enabled while TXENS is set to 1. No before TXEN, or enable them both in the same write operation. | | | | | | | 3 | TXDIS | 0x0 | W | Transmitter Disable | | | | | | | | Set to disable transm | ission. | | | | | | | | | 2 | TXEN | 0x0 | W | Transmitter Enable | | | | | | | | Set to enable data tra | ansmission. | | | | | | | | | 1 | RXDIS | 0x0 | W | Receiver Disable | | | | | | | | Set to disable data reded. | eception. If a fra | me is under recep | otion when the receiver is disabled, the incoming frame is discar- | | | | | | | 0 | RXEN | 0x0 | W | Receiver Enable | | | | | | | | Set to activate data reception on U(S)n_RX. | | | | | | | | | # 21.5.7 USART\_STATUS - USART Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----------|------|------|----------------|--------|-------------|--------------|-----------|-----------|--------|---------|------|-----|-------|---------|--------|-------|-------| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | Reset | | | | • | | | • | • | | | | • | • | | 2 | 3 | | 0×0 | 0×1 | 000 | 0x0 | 000 | 0x0 | 0×0 | 0x0 | 0x1 | 0×0 | 0x0 | 0x0 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | ۵ | ۷ | | 2 | ~ | 2 | 2 | 22 | 22 | 22 | 2 | 2 | 2 | 22 | 22 | 22 | 22 | 2 | | Name | | | | | | | | | | | | | | | TXBLIECNT | | | TIMERRESTARTED | TXIDLE | RXFULLRIGHT | RXDATAVRIGHT | TXBSRIGHT | TXBDRIGHT | RXFULL | RXDATAV | TXBL | TXC | TXTRI | RXBLOCK | MASTER | TXENS | RXENS | | Bit | Name | Reset | Access | Description | |-------|----------------------------------------------|---------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:18 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 17:16 | TXBUFCNT | 0x0 | R | TX Buffer Count | | | Count of TX buffer en TX shifter register. | try 0, entry 1, | and TX shift reg | gister. For large frames, the count is only of TX buffer entry 0 and the | | 15 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 14 | TIMERRESTARTED | 0x0 | R | The USART Timer restarted itself | | | event in the sequence there is a TCMP intern | of multiple To<br>rupt and TIME | CMP events. An<br>RRESTARTED | vent, a TIMERRESTARTED value of 0x0 indicates the first TCMP by non TCMP timer start events will clear TIMERRESTARTED. When is 0x0, an interrupt service routine can set a TCMP event counter of the sequence. | | 13 | TXIDLE | 0x1 | R | TX Idle | | | Set when TX idle | | | | | 12 | RXFULLRIGHT | 0x0 | R | RX Full of Right Data | | | When set, the entire F | RX buffer conta | ains right data. | Only used in I2S mode | | 11 | RXDATAVRIGHT | 0x0 | R | RX Data Right | | | When set, reading RX | (DATA or RXD | ATAX gives rig | ht data. Else left data is read. Only used in I2S mode | | 10 | TXBSRIGHT | 0x0 | R | TX Buffer Expects Single Right Data | | | When set, the TX buff | er expects at | least a single riç | ght data. Else it expects left data. Only used in I2S mode | | 9 | TXBDRIGHT | 0x0 | R | TX Buffer Expects Double Right Data | | | When set, the TX buff mode | er expects do | uble right data. | Else it may expect a single right data or left data. Only used in I2S | | 8 | RXFULL | 0x0 | R | RX FIFO Full | | | Set when the RXFIFC one more frame in the | | | eive buffer is no longer full. When this bit is set, there is still room for | | 7 | RXDATAV | 0x0 | R | RX Data Valid | | | Set when data is avail | lable in the red | ceive buffer. Cle | eared when the receive buffer is empty. | | | | | | | | Bit | Name | Reset | Access | Description | |-----|----------------------------------------------|--------------------|--------------------|--------------------------------------------------------------------------------------| | | | of the transmit bu | uffer. If TXBIL is | s 0x0, TXBL is set whenever the transmit buffer is completely empty. | | 5 | TXC | 0x0 | R | TX Complete | | | Set when a transm when data is written | | | ore data is available in the transmit buffer and shift register. Cleared | | 4 | TXTRI | 0x0 | R | Transmitter Tristated | | | Set when the trans | | , and cleared w | hen transmitter output is enabled. If AUTOTRI in USARTn_CTRL is | | 3 | RXBLOCK | 0x0 | R | Block Incoming Data | | | When set, the rece<br>set at the instant the | | | An incoming frame will not be loaded into the receive buffer if this bit is eceived. | | 2 | MASTER | 0x0 | R | SPI Master Mode | | | Set when the USA mand. | .RT operates as a | master. Set us | sing the MASTEREN command and clear using the MASTERDIS com- | | 1 | TXENS | 0x0 | R | Transmitter Enable Status | | | Set when the trans | smitter is enabled | | | | 0 | RXENS | 0x0 | R | Receiver Enable Status | | | Set when the rece | iver is enabled. | | | | | | | | | # 21.5.8 USART\_CLKDIV - Clock Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|--------|---|----|---|---|---|---|---|---|---|---|---|---| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | | ' | | ' | | ' | | | | • | | | | | • | | | ç | e<br>X | | ' | | | | ' | | | | | | | | Access | R | | | | | | | | | | | | | | | | | | Š | ≥<br>Y | | | | | | | | | | | | | | Name | AUTOBAUDEN | | | | | | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------------|--------------------|------------------|---------------------------------------------------------------------------| | 31 | AUTOBAUDEN | 0x0 | RW | AUTOBAUD detection enable | | | Detects the baud rate | based on rece | iving a 0x55 fra | ame (0x00 for IrDA). This is used in Asynchronous mode. | | 30:23 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 22:3 | DIV | 0x0 | RW | Fractional Clock Divider | | | Specifies the fractional field. | al clock divider | for the USART | . Setting AUTOBAUDEN in USARTn_CLKDIV will overwrite the DIV | | 2:0 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | # 21.5.9 USART\_RXDATAX - RX Buffer Data Extended Register | Offset | Bit Position | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 0x020 | 33 4 4 5 6 4 8 8 8 8 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 0 4 6 7 - 0 | | Reset | 000 000 | 0×0 | | Access | ss α α | <u> </u> | | Name | FERR RA R | RXDATA | | Bit | Name | Reset | Access | Description | |-------|---------------------------|------------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 15 | FERR | 0x0 | R | Data Framing Error | | | Set if data in buffer has | a framing erro | r. Can be the re | sult of a break condition. | | 14 | PERR | 0x0 | R | Data Parity Error | | | Set if data in buffer has | a parity error ( | asynchronous r | node only). | | 13:9 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | RXDATA | 0x0 | R | RX Data | | | Use this register to acce | ss data read f | rom the USAR1 | . Buffer is cleared on read access. | # 21.5.10 USART\_RXDATA - RX Buffer Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|----------|---|---|---| | 0x024 | 31 | 30 | 53 | 78 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | OX<br>OX | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ſ | צ | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | į | KXDAIA | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | RXDATA | 0x0 | R | RX Data | | | Use this register to accest this register. | ss data read f | rom USART. Bu | uffer is cleared on read access. Only the 8 LSB can be read using | # 21.5.11 USART\_RXDOUBLEX - RX Buffer Double Data Extended Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|-----------------------------------------|-------|----|----|----|----|----|----|----|----|----|---------|----|----|----|------|-------|-------|----|----|---|----|---|---|---|---|---|---------|---|---|---|---| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | 2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | FERR1 | PERR1 | | | | | | | | | | RXDATA1 | | | | | FERR0 | PERR0 | | | | | | | | | | RXDATA0 | | | | | | D:4 | N | B 1 | | Post Co. | |-------|----------------------|----------------------|-----------------|---------------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 31 | FERR1 | 0x0 | R | Data Framing Error 1 | | | Set if data in buffe | er has a framing er | ror. Can be the | result of a break condition. | | 30 | PERR1 | 0x0 | R | Data Parity Error 1 | | | Set if data in buffe | er has a parity erro | r (asynchronou | is mode only). | | 29:25 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 24:16 | RXDATA1 | 0x0 | R | RX Data 1 | | | Second frame rea | d from buffer. | | | | 15 | FERR0 | 0x0 | R | Data Framing Error 0 | | | Set if data in buffe | er has a framing en | ror. Can be the | e result of a break condition. | | 14 | PERR0 | 0x0 | R | Data Parity Error 0 | | | Set if data in buffe | er has a parity erro | r (asynchronou | is mode only). | | 13:9 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | RXDATA0 | 0x0 | R | RX Data 0 | | | First frame read fr | om buffer. | | | | | | | | | # 21.5.12 USART\_RXDOUBLE - RX FIFO Double Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|--------|--------|----|---|---|---|---|---|--------|--------|---|---|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | 2 | S<br>S | | | | | | | 2 | 3 | | | | | | Access | | | | | | | | | | | | | | | | | | | | ב | צ | | | | | | | Δ | ۷ | | | | | Name | | | | | | | | | | | | | | | | | | | | , | KADATA | | | | | | | OXTACX | פואטאו | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 15:8 | RXDATA1 | 0x0 | R | RX Data 1 | | | Second frame read from | buffer. | | | | 7:0 | RXDATA0 | 0x0 | R | RX Data 0 | | | First frame read from bu | ffer. | | | # 21.5.13 USART\_RXDATAXP - RX Buffer Data Extended Peek Register | Offset | | | | | | | | | | | | | | | Ві | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|-------|----|----|----|----|---|---|---|---|---|----------|---|---|---|---| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | | | | | | | | | | | 0x0 | 0x0 | | | | | | | | | • | 0x0 | | | | | | Access | | | | | | | | | | | | | | | | | ~ | 22 | | | | | | | | | | <u>~</u> | | | | | | Name | | | | | | | | | | | | | | | | | FERRP | PERRP | | | | | | | | | | RXDATAP | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|------------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 15 | FERRP | 0x0 | R | Data Framing Error Peek | | | Set if data in buffer has | a framing erro | r. Can be the re | sult of a break condition. | | 14 | PERRP | 0x0 | R | Data Parity Error Peek | | | Set if data in buffer has | a parity error ( | asynchronous r | mode only). | | 13:9 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | RXDATAP | 0x0 | R | RX Data Peek | | | Use this register to acce | ss data read f | rom the USAR1 | <del>.</del> | # 21.5.14 USART\_RXDOUBLEXP - RX Buffer Double Data Extended Peek R... | Offset | | | | | | | | | | | | | | | В | it Po | siti | on | | | | | | | | | | | | | | | |--------|--------|--------|----|----|----|----|----|----|----|----|----|----------|----|----|----|-------|--------|--------|----|----|---|----|---|---|---|---|---|----------|---|---|---|---| | 0x034 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | 0X0 | 000 | | | | | ' | | | | | 0×0 | • | | | • | 0x0 | 0×0 | | ' | | • | | | | | | 000 | | ' | | | | Access | 2 | œ | | | | | | | | | | <u>~</u> | | | | | œ | 22 | | | | | | | | | | ď | | | | | | Name | FERRP1 | PERRP1 | | | | | | | | | | RXDATAP1 | | | | | FERRP0 | PERRP0 | | | | | | | | | | RXDATAP0 | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31 | FERRP1 | 0x0 | R | Data Framing Error 1 Peek | | | Set if data in buffer | has a framing er | ror. Can be the | e result of a break condition. | | 30 | PERRP1 | 0x0 | R | Data Parity Error 1 Peek | | | Set if data in buffer | has a parity erro | r (asynchronou | us mode only). | | 29:25 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 24:16 | RXDATAP1 | 0x0 | R | RX Data 1 Peek | | | Second frame read | from FIFO. | | | | 15 | FERRP0 | 0x0 | R | Data Framing Error 0 Peek | | | Set if data in buffer | has a framing er | ror. Can be the | e result of a break condition. | | 14 | PERRP0 | 0x0 | R | Data Parity Error 0 Peek | | | Set if data in buffer | has a parity erro | r (asynchronou | us mode only). | | 13:9 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | RXDATAP0 | 0x0 | R | RX Data 0 Peek | | | First frame read from | m FIFO. | | | # 21.5.15 USART\_TXDATAX - TX Buffer Data Extended Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|--------|---------|---------|---------|--------|----|---|----|---|---|---|---------|---|---|---|---| | 0x038 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | ' | | | | | | | | | • | | • | 000 | 0×0 | 0x0 | 000 | 0x0 | | | | | | • | 0×0 | • | ' | | | | Access | | | | | | | | | | | | | | | | | > | > | > | > | > | | | | | | | ≥ | | | | | | Name | | | | | | | | | | | | | | | | | RXENAT | TXDISAT | TXBREAK | TXTRIAT | UBRXAT | | | | | | | TXDATAX | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------|-----------------------|--------------------|---------------------------------------------------------------------------| | 31:16 | Reserved | To ensure<br>ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 15 | RXENAT | 0x0 | W | Enable RX After Transmission | | | Set to enable rece | ption after transm | ission. | | | 14 | TXDISAT | 0x0 | W | Clear TXEN After Transmission | | | Set to disable tran | smitter and releas | e data bus dire | ectly after transmission. | | 13 | TXBREAK | 0x0 | W | Transmit Data As Break | | | Set to send data a the value of TXDA | | ent will see a fra | aming error or a break condition depending on its configuration and | | 12 | TXTRIAT | 0x0 | W | Set TXTRI After Transmission | | | Set to tristate trans | smitter by setting | TXTRI after tra | nsmission. | | 11 | UBRXAT | 0x0 | W | Unblock RX After Transmission | | | Set to clear RXBL | OCK after transmi | ssion, unblocki | ing the receiver. | | 10:9 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | TXDATAX | 0x0 | W | TX Data | | | Use this register to | write data to the | USART. If TXE | EN is set, a transfer will be initiated at the first opportunity. | # 21.5.16 USART\_TXDATA - TX Buffer Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|----|---|---|---| | 0x03C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | • | | | | | | | | | • | • | | | | | | | | | | | • | 2 | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | \$ | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | \ | Υ | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------------|--------------------|------------------|--------------------------------------------------------------------------| | 31:8 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | TXDATA | 0x0 | W | TX Data | | | This frame will be adde cleared. | ed to TX buffer | r. Only 8 LSB ca | an be written using this register. 9th bit and control bits will be | # 21.5.17 USART\_TXDOUBLEX - TX Buffer Double Data Extended Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|---------|----------|----------|----------|---------|----|----|----|----|----|----|---------|----|----|----|------|---------|----------|----------|----------|---------|----|---|---|---|---|---|---------|---|---|---|---| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | 000 | 0x0 | 000 | 0×0 | 000 | | | | | | | 0×0 | | | | | 0×0 | 0×0 | 0x0 | 000 | 0x0 | | | | | | | 0×0 | | | | | | Access | > | > | > | > | > | | | | | | | ≥ | | | | | > | > | > | > | > | | | | | | | > | | | | | | Name | RXENAT1 | TXDISAT1 | TXBREAK1 | TXTRIAT1 | UBRXAT1 | | | | | | | TXDATA1 | | | | | RXENAT0 | TXDISAT0 | TXBREAK0 | TXTRIAT0 | UBRXAT0 | | | | | | | TXDATA0 | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------------------------|--------------------|--------------------|---------------------------------------------------------------------------| | 31 | RXENAT1 | 0x0 | W | Enable RX After Transmission | | 01 | Set to enable recep | | | | | 30 | TXDISAT1 | 0x0 | W | Clear TXEN After Transmission | | 30 | _ | | | | | | | | | ctly after transmission. | | 29 | TXBREAK1 | 0x0 | W | Transmit Data As Break | | | Set to send data as the value of USART | | ent will see a fra | ıming error or a break condition depending on its configuration and | | 28 | TXTRIAT1 | 0x0 | W | Set TXTRI After Transmission | | | Set to tristate transr | mitter by setting | TXTRI after trar | nsmission. | | 27 | UBRXAT1 | 0x0 | W | Unblock RX After Transmission | | | Set clear RXBLOCk | K after transmiss | ion, unblocking | the receiver. | | 26:25 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 24:16 | TXDATA1 | 0x0 | W | TX Data | | | Second frame to wr | ite to FIFO. | | | | 15 | RXENAT0 | 0x0 | W | Enable RX After Transmission | | | Set to enable recep | tion after transm | ission. | | | 14 | TXDISAT0 | 0x0 | W | Clear TXEN After Transmission | | | Set to disable trans | mitter and releas | se data bus dire | ctly after transmission. | | 13 | TXBREAK0 | 0x0 | W | Transmit Data As Break | | | Set to send data as the value of TXDAT | | ent will see a fra | nming error or a break condition depending on its configuration and | | 12 | TXTRIAT0 | 0x0 | W | Set TXTRI After Transmission | | | Set to tristate transr | mitter by setting | TXTRI after trar | nsmission. | | 11 | UBRXAT0 | 0x0 | W | Unblock RX After Transmission | | | Set clear RXBLOCk | K after transmiss | ion, unblocking | the receiver. | | 10:9 | Reserved | To ensure | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | TXDATA0 | 0x0 | W | TX Data | | | First frame to write | to buffer. | | | | | | | | | # 21.5.18 USART\_TXDOUBLE - TX Buffer Double Data Register | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|-----------|----------|----|---|---|---|---|---|-----------|----------|---|---|---| | 0x044 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | | | • | | • | | | | • | | • | | | • | Š | e e | | • | | | | | > | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | } | > | | | | | Name | | | | | | | | | | | | | | | | | | | | - × - × - | <u> </u> | | | | | | | 0 V T V C | 2 | | | | | | | | | | | | | | | | | | | | | | | | | } | ₹ | | | | | | | } | <u> </u> | | | | | Bit | Name | Reset | Access | Description | | |-------|----------------------------------|--------------------|----------------------------------------------------------------------------------------------------------|-------------|--| | 31:16 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 Conventions | | | | 15:8 | TXDATA1 | 0x0 | W | TX Data | | | | Second frame to write to buffer. | | | | | | 7:0 | TXDATA0 | 0x0 | W | TX Data | | | | First frame to write to buffer. | | | | | # 21.5.19 USART\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------------|-------|--------|--------|-----|------|---------|------|------|------|--------|------|--------|---------|------|-----| | 0x048 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | ' | | | | | | • | | • | • | ' | 0X0 | 000 | 000 | 0x0 | 0X0 | 0x0 | 0X0 | 000 | 0X0 | 0X0 | 0X0 | 000 | 0X0 | 0X0 | 0×0 | 0×1 | 0x0 | | Access | | | | | | | | | | | | | | | | R. | R<br>M<br>M | Z. | ₽ | \<br>N | RW | W. | RW<br>W | W. | S. | Z. | R<br>W | RW | ₩<br>M | RW | Z. | RW | | Name | | | | | | | | | | | | | | | | TCMP2 | TCMP1 | TCMP0 | TXIDLE | CCF | SSM | MPAF | FERR | PERR | TXUF | TXOF | RXUF | RXOF | RXFULL | RXDATAV | TXBL | TXC | | Bit | Name | Reset | Access | Description | |-------|-------------------------------------------|---------------------|--------------------|--------------------------------------------------------------------------| | 31:17 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Cor | | 16 | TCMP2 | 0x0 | RW | Timer comparator 2 Interrupt Flag | | | Set when the timer re | eaches the com | parator 2 value | , TCMP2. | | 15 | TCMP1 | 0x0 | RW | Timer comparator 1 Interrupt Flag | | | Set when the timer re | eaches the com | parator 1 value | , TCMP1. | | 14 | TCMP0 | 0x0 | RW | Timer comparator 0 Interrupt Flag | | | Set when the Timer I | reaches the con | nparator 0 value | e, TCMP0. | | 13 | TXIDLE | 0x0 | RW | TX Idle Interrupt Flag | | | Set when TX goes id | lle. At this point, | transmission h | nas ended | | 12 | CCF | 0x0 | RW | Collision Check Fail Interrupt Flag | | | Set when a collision | check notices a | n error in the tra | ansmitted data. | | 11 | SSM | 0x0 | RW | Slave-Select In Master Mode Interrupt FI | | | Set when the device | is selected as a | a slave when in | master mode. | | 10 | MPAF | 0x0 | RW | Multi-Processor Address Frame Interrupt | | | Set when a multi-pro | cessor address | frame is detect | ted. | | 9 | FERR | 0x0 | RW | Framing Error Interrupt Flag | | | Set when a frame wi | th a framing erro | or is received w | hile RXBLOCK is cleared. | | 8 | PERR | 0x0 | RW | Parity Error Interrupt Flag | | | Set when a frame wi | th a parity error | (asynchronous | mode only) is received while RXBLOCK is cleared. | | 7 | TXUF | 0x0 | RW | TX Underflow Interrupt Flag | | | Set when operating a sion of a new frame. | as a synchronou | us slave, no dat | a is available in the transmit buffer when the master starts transmis- | | 6 | TXOF | 0x0 | RW | TX Overflow Interrupt Flag | | | Set when a write is d | lone to the trans | smit buffer while | e it is full. The data already in the transmit buffer is preserved. | | 5 | RXUF | 0x0 | RW | RX Underflow Interrupt Flag | | | Set when trying to re | ad from the rec | eive buffer whe | n it is empty. | | 4 | RXOF | 0x0 | RW | RX Overflow Interrupt Flag | | | Set when data is inco | oming while the | receive shift re | gister is full. The data previously in the shift register is lost. | | Bit | Name | Reset | Access | Description | |-----|--------------------------------------------|----------------------|-------------------|------------------------------------------------------------------| | 3 | RXFULL | 0x0 | RW | RX Buffer Full Interrupt Flag | | | Set when the rece | ive buffer become | es full. | | | 2 | RXDATAV | 0x0 | RW | RX Data Valid Interrupt Flag | | | Set when data bed | comes available ir | the receive b | uffer. | | 1 | TXBL | 0x1 | RW | TX Buffer Level Interrupt Flag | | | Set when buffer be<br>specified buffer lev | | ouffer level is s | et to 0x0, or when the number of empty TX buffer elements equals | | 0 | TXC | 0x0 | RW | TX Complete Interrupt Flag | | | This interrupt is se | et after a transmiss | sion when both | n the TX buffer and shift register are empty. | ## 21.5.20 USART\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------------|-------|--------|--------|-----|------|------|------|------|------|--------|------|--------|---------|------|-----| | 0x04C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | ' | | • | | | | • | | ' | • | ' | 0X0 | 000 | 000 | 0x0 | 0X0 | 0x0 | 0X0 | 000 | 0X0 | 0X0 | 0X0 | 000 | 0X0 | 0X0 | 0×0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | R. | R<br>M<br>M | Z. | ₽ | \<br>N | RW | W. | RW | W. | S. | Z. | R<br>W | RW | ₩<br>M | RW | Z. | RW | | Name | | | | | | | | | | | | | | | | TCMP2 | TCMP1 | TCMP0 | TXIDLE | CCF | SSM | MPAF | FERR | PERR | TXUF | TXOF | RXUF | RXOF | RXFULL | RXDATAV | TXBL | TXC | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------|-----------------------|--------------------|--------------------------------------------------------------------------| | 31:17 | Reserved | To ensure<br>ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con | | 16 | TCMP2 | 0x0 | RW | Timer comparator 2 Interrupt Enable | | | Set when the time | er reaches the com | parator 2 value | , TCMP2. | | 15 | TCMP1 | 0x0 | RW | Timer comparator 1 Interrupt Enable | | | Set when the time | er reaches the com | parator 1 value | , TCMP1. | | 14 | TCMP0 | 0x0 | RW | Timer comparator 0 Interrupt Enable | | | Set when the Time | er reaches the cor | nparator 0 value | e, TCMP0. | | 13 | TXIDLE | 0x0 | RW | TX Idle Interrupt Enable | | | Set when TX goes | s idle. At this point | , transmission h | as ended | | 12 | CCF | 0x0 | RW | Collision Check Fail Interrupt Enable | | | Set when a collision | on check notices a | n error in the tra | ansmitted data. | | 11 | SSM | 0x0 | RW | Slave-Select In Master Mode Interrupt Fl | | | Set when the devi | ice is selected as a | a slave when in | master mode. | | 10 | MPAF | 0x0 | RW | Multi-Processor Address Frame Interrupt | | | Set when a multi- | processor address | frame is detect | ted. | | 9 | FERR | 0x0 | RW | Framing Error Interrupt Enable | | | Set when a frame | with a framing err | or is received w | hile RXBLOCK is cleared. | | 8 | PERR | 0x0 | RW | Parity Error Interrupt Enable | | | Set when a frame | with a parity error | (asynchronous | mode only) is received while RXBLOCK is cleared. | | 7 | TXUF | 0x0 | RW | TX Underflow Interrupt Enable | | | Set when operatir sion of a new fram | | us slave, no dat | a is available in the transmit buffer when the master starts transmis- | | 6 | TXOF | 0x0 | RW | TX Overflow Interrupt Enable | | | Set when a write i | s done to the trans | smit buffer while | e it is full. The data already in the transmit buffer is preserved. | | 5 | RXUF | 0x0 | RW | RX Underflow Interrupt Enable | | | Set when trying to | read from the rec | eive buffer whe | n it is empty. | | 4 | RXOF | 0x0 | RW | RX Overflow Interrupt Enable | | | Set when data is i | ncoming while the | receive shift re | gister is full. The data previously in the shift register is lost. | | Bit | Name | Reset | Access | Description | |-----|--------------------------------------------|----------------------|------------------|------------------------------------------------------------------| | 3 | RXFULL | 0x0 | RW | RX Buffer Full Interrupt Enable | | | Set when the rece | ive buffer become | es full. | | | 2 | RXDATAV | 0x0 | RW | RX Data Valid Interrupt Enable | | | Set when data bed | comes available ir | the receive b | uffer. | | 1 | TXBL | 0x0 | RW | TX Buffer Level Interrupt Enable | | | Set when buffer be<br>specified buffer lev | , , | uffer level is s | et to 0x0, or when the number of empty TX buffer elements equals | | 0 | TXC | 0x0 | RW | TX Complete Interrupt Enable | | | This interrupt is se | et after a transmiss | sion when both | n the TX buffer and shift register are empty. | # 21.5.21 USART\_IRCTRL - IrDA Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|---|---|---|---|---|---|---|--------|----------|----------|------| | 0x050 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | • | | | | | | • | • | | | • | • | • | | | • | | | • | • | • | • | | 0x0 | 2 | 2 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | NA<br>NA | 2 | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | IRFILT | Wdal | <u> </u> | IREN | | Bit | Name | Reset | Access | Description | |------|----------------------|-----------------------|-----------------|------------------------------------------------------------------------------------------------| | 31:4 | Reserved | To ensure<br>ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 3 | IRFILT | 0x0 | RW | IrDA RX Filter | | | Set to enable filter | r on IrDA demodula | ator. | | | | 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 | IrDA TX Pulse Width | | | Configure the puls | se width generated | by the IrDA mo | odulator 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 | Enable IrDA Module | | | Enable IrDA modu | ule and rout USAR | Γ signals throu | gh it. | # 21.5.22 USART\_I2SCTRL - I2S Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----|------|------|----|----|----|---|----|--------|---|---|---|---|---------|----------|---------|--------|---------| | 0x054 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | | | | | | | | | | | | | | | | | 000 | | | | | 000 | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | RW | | | | | RW<br>W | ₩<br>M | ₩<br>M | ₩<br>M | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | FORMAT | | | | | DELAY | DMASPLIT | JUSTIFY | MONO | N<br>EN | | Bit | Name | Reset | Access | Description | |-------|----------------------------------------|-----------------------|--------------------|---------------------------------------------------------------------------| | 31:11 | Reserved | | | vith future devices, always write bits to 0. More information in 1.2 Con- | | 10:8 | FORMAT | 0x0 | RW | I2S Word Format | | | Configure the data- | -width used interna | ally for I2S data | 3 | | | 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 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con | | 4 | DELAY | 0x0 | RW | Delay on I2S data | | | Set to add a one-cy standard I2S forma | | n a transition o | n the word-clock and the start of the I2S word. Should be set for | | 3 | DMASPLIT | 0x0 | RW | Separate DMA Request For Left/Right Data | | | When set DMA req | uests for right-cha | nnel data are p | out on the TXBLRIGHT and RXDATAVRIGHT DMA requests. | | 2 | JUSTIFY | 0x0 | RW | Justification of I2S Data | | | Determines whether | er the I2S data is le | eft or right justi | fied | | | Value | Mode | | Description | | | 0 | LEFT | | Data is left-justified | | | 1 | RIGHT | | Data is right-justified | | 1 | MONO | 0x0 | RW | Stero or Mono | | | Switch between ste | ereo and mono mo | de. Set for mo | no | | 0 | EN | 0x0 | RW | Enable I2S Mode | | Bit | Name | Reset | Access | Description | |-----|--------------------------|-------|--------|-------------| | | Set the U(S)ART in I2S m | node. | | | ## 21.5.23 USART\_TIMING - Timing Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|--------|----|----|----|-----|----|----|----|---------|----|----|----|---------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x058 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | 0x0 | | | | 0X0 | | | | 0X0 | | | | 0×0 | | | • | | | | • | | | • | | • | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | CSHOLD | | | | ICS | | | | CSSETUP | | | | TXDELAY | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------|--------------------|---------------|---------------------------------------------------------------------------| | 31 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 30:28 | CSHOLD | 0x0 | RW | Chip Select Hold | 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 | To ensure compations | tibility with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 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. Inter-character spacing | Value | Mode | Description | |-------|-------|----------------------------------------------------------------------------| | 0 | ZERO | There is no space between charcters | | 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 | 26:24 **ICS** 0x0 RW | 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 | To ensure o | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con | | 22:20 | CSSETUP | 0x0 | RW | Chip Select Setup | | | | | | e transmission. When using USART_TIMECMPn, normally set prevent unwanted interrupts. | | | 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 | To ensure o | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con | | 18:16 | TXDELAY | 0x0 | RW | TX frame start delay | | | | imes to delay the sta<br>op general timer and | | ansmission. When using USART_TIMECMPn, normally set TSTART wanted interrupts. | | | 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 | To ensure o | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con | ## 21.5.24 USART\_CTRLX - Control Register Extended | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----------|----|----|----|---|----|---|---|---------|---|---|---|--------|-------|--------|---------| | 0x05C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | | | | | • | | | • | | • | • | 000 | | | | | | • | • | 0X0 | | • | | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | ₩<br>N | | | | | | | | Z<br>N | | | | W. | W. | ₩<br>N | RW | | Name | | | | | | | | | | | | | | | | | CLKPRSEN | | | | | | | | RXPRSEN | | | | RTSINV | CTSEN | CTSINV | DBGHALT | | Bit | Name | Reset | Access | Description | | | | | | |-------|---------------------|---------------------|--------------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31:16 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 15 | CLKPRSEN | 0x0 | RW | PRS CLK Enable | | | | | | | | When set, the PRS c | hannel selected | as input to CLK. | | | | | | | | 14:8 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 7 | RXPRSEN | 0x0 | RW | PRS RX Enable | | | | | | | | When set, the PRS c | hannel selected | as input to RX. | | | | | | | | 6:4 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 3 | RTSINV | 0x0 | RW | RTS Pin Inversion | | | | | | | | When set, the RTS p | in polarity is inve | erted. | | | | | | | | | 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 | CTS Function enabled | | | | | | | | | | | link partner asserts CTS. Any data in the TX shift register will bad into the TX shift register | | | | | | | | Value | Mode | | Description | | | | | | | | 0 | DISABLE | | Ingore CTS | | | | | | | | 1 | ENABLE | | Stop transmitting when CTS is negated | | | | | | | 1 | CTSINV | 0x0 | RW | CTS Pin Inversion | | | | | | | | When set, the CTS p | in polarity is inve | erted. | | | | | | | | | 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 | Debug halt | | | | | | | 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. | ## 21.5.25 USART\_TIMECMP0 - Used to generate interrupts and vario... | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|-----------|----|----|-------|----|----|----|--------|------|-------|----|----|----|---|----|---|---|---|---|---|--------|----------|---|-----| | 0x060 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | | • | 0x0 | | | 000 | | | | 000 | | | | • | • | | • | | • | | | • | 2 | OXO | | | | Access | | | | | | | | W<br>M | | | ₩ | | | | RW | | | | | | | | | | | | | 2 | <u>}</u> | | | | Name | | | | | | | | RESTARTEN | | | TSTOP | | | | TSTART | | | | | | | | | | | | | TOMBIA | | | | | Bit | Name | Reset | Access | Description | | | | | | | |-------|---------------------|--------------------------|-----------------|-------------------------------------------------------------------------------------|--|--|--|--|--|--| | 31:25 | Reserved | To ensure co<br>ventions | mpatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 24 | RESTARTEN | 0x0 | RW | Restart Timer on TCMP0 | | | | | | | | | Each TCMP0 event | will reset and restar | rt the timer | | | | | | | | | | Value | Mode | | Description | | | | | | | | | 0 | DISABLE | | Disable the timer restarting on TCMP0 | | | | | | | | | 1 | ENABLE | | Enable the timer restarting on TCMP0 | | | | | | | | 23 | Reserved | To ensure co | mpatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 22:20 | TSTOP | 0x0 | RW | Source used to disable comparator 0 | | | | | | | | | Select the source w | hich disables compa | arator 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 going Active (default: low) | | | | | | | | | 3 | RXACTN | | Comparator 0 is disabled on RX going Inactive | | | | | | | | 19 | Reserved | To ensure co | mpatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 18:16 | TSTART | 0x0 | RW | Timer start source | | | | | | | | | Source used to star | t 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 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 | To ensur | | with future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | TCMPVAL | 0x0 | RW | Timer comparator 0. | | | | | • | TCMP0 event and sets the TCMP0 flag. This event can also be used to 000 represents 256 baud times. | ## 21.5.26 USART\_TIMECMP1 - Used to generate interrupts and vario... | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|-----------|----|----|--------|----|----|----|--------|------|-------|----|----|----|---|----|---|---|---|---|---|---|---------|---|---|--------| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | _<br>o | | Reset | | | • | • | • | | • | 0x0 | | | 000 | | | | 000 | | | • | | • | | | • | • | | • | • | 2 | 2 | | · | | | Access | | | | | | | | R<br>W | | | R<br>M | | | | ₩<br>M | | | | | | | | | | | | | 2 | 2 | | | | | Name | | | | | | | | RESTARTEN | | | TSTOP | | | | TSTART | | | | | | | | | | | | | | - Civil | | | | | Bit | Name | Reset | Access | Description | | | | | | | |-------|---------------------|--------------------|------------------|-------------------------------------------------------------------------------------|--|--|--|--|--|--| | 31:25 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 24 | RESTARTEN | 0x0 | RW | Restart Timer on TCMP1 | | | | | | | | | Each TCMP1 event | will reset and res | tart the timer | | | | | | | | | | Value | Mode | | Description | | | | | | | | | 0 | DISABLE | | Disable the timer restarting on TCMP1 | | | | | | | | | 1 | ENABLE | | Enable the timer restarting on TCMP1 | | | | | | | | 23 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 22:20 | TSTOP | 0x0 | RW | Source used to disable comparator 1 | | | | | | | | | Select the source w | hich disables com | parator 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 going Active (default: low) | | | | | | | | | 3 | RXACTN | | Comparator 1 is disabled on RX going Inactive | | | | | | | | 19 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 18:16 | TSTART | 0x0 | RW | Timer start source | | | | | | | | | Source used to star | t comparator 1 an | d 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 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 | To ensur | , , | with future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | TCMPVAL | 0x0 | RW | Timer comparator 1. | | | | | | TCMP1 event and sets the TCMP1 flag. This event can also be used to c00 represents 256 baud times. | ## 21.5.27 USART\_TIMECMP2 - Used to generate interrupts and vario... | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|-----|----|----|----|----|-----|----|-----------|----|----|--------|----|----|----|--------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|--------| | 0x068 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | _<br>o | | Reset | 0×0 | | | | | 0%0 | | | | | | 2 | 2 | | · | | | | | | | | | | | | | | | | | | | Access | | | | | | | | R<br>W | | | R<br>M | | | | RW | | | | | | | | | | | | | 2 | 2 | | | | | Name | | | | | | | | RESTARTEN | | | TSTOP | | | | TSTART | | | | | | | | | | | | | | | | | _ | | Bit | Name | Reset Ac | cess Description | |-------|---------------------|---------------------------|-------------------------------------------------------------------------------------| | 31:25 | Reserved | To ensure comp | atibility with future devices, always write bits to 0. More information in 1.2 Con- | | 24 | RESTARTEN | 0x0 RV | Restart Timer on TCMP2 | | | Each TCMP2 event | will reset and restart th | e timer | | | Value | Mode | Description | | | 0 | DISABLE | Disable the timer restarting on TCMP2 | | | 1 | ENABLE | Enable the timer restarting on TCMP2 | | 23 | Reserved | To ensure comp | atibility with future devices, always write bits to 0. More information in 1.2 Con- | | 22:20 | TSTOP | 0x0 RV | Source used to disable comparator 2 | | | Select the source w | hich disables compara | or 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 going Active (default: low) | | | 3 | RXACTN | Comparator 2 is disabled on RX going Inactive | | 19 | Reserved | To ensure comp | atibility with future devices, always write bits to 0. More information in 1.2 Con- | | 18:16 | TSTART | 0x0 RV | / Timer start source | | | Source used to star | t comparator 2 and tim | er | | | 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 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 | To ensur | | with future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | TCMPVAL | 0x0 | RW | Timer comparator 2. | | | | | • | TCMP2 event and sets the TCMP2 flag. This event can also be used to coo represents 256 baud times. | ## 22. EUART - Enhanced Universal Asynchronous Receiver/Transmitter #### **Quick Facts** #### What? The EUART handles high-speed UART and IrDA communication. ## Why? Serial communication is frequently used in embedded systems and the EUART allows efficient communication with a wide range of external devices. ### How? The EUART has a wide selection of operating modes, frame formats and baud rates. The multiprocessor mode allows the EUART 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. Lower-frequency operation in EM2 is supported on select I/O ports. ## 22.1 Introduction The Enhanced Universal Asynchronous serial Receiver and Transmitter (EUART) is a very flexible serial I/O module. It supports full duplex asynchronous UART communication. It can also interface with IrDA devices. #### 22.2 Features - · Asynchronous (UART) communication - · Full duplex and half duplex - · Separate TX/RX enable - · Separate receive / transmit four-deep FIFOs, with additional separate shift registers - · Programmable baud rate, generated as a fractional division from the peripheral clock - · Max bit-rate - HF EM0/1 operation: peripheral clock rate/16, 8, 6, or 4 - LF EM2 operation: 9600 baud from 32.768 kHz oscillator source - · Majority vote baud-reception - · False start-bit detection - Break generation/detection - · Multi-processor mode - · Data can be transmitted LSB first or MSB first - Configurable number of data bits, 4-9 (plus the parity bit, if enabled) - · HW parity bit generation and check - · Configurable number of stop bits: - HF EM0/1 operation: 0.5, 1, 1.5, 2 - LF EM2 operation: 1, 2 - · HW collision detection - · IrDA support - · HF EM0/1 operation: IrDA modulator - · LF EM2 operation: Pulse extender, RX-only - · Separate interrupt vectors for receive and transmit interrupts - · Loopback mode - · Half duplex communication - · Communication debugging - PRS RX input - · Hardware Flow Control - Automatic Baud Rate Detection operating as HF EM0/1 ### 22.3 Functional Description An overview of the EUART module is shown in Figure 22.1 EUART Overview on page 631. This section describes all posible EUART features. Please refer to the Device Datasheet to see what features a specific EUART instance supports. Figure 22.1. EUART Overview ## 22.3.1 Modes of Operation The EUART may operate as either a high-speed peripheral running from a high-frequency clock source (HF mode, available in EM0 an EM1), or as a low-energy peripheral operating from a low-frequency clock source (LF mode, available in EM0, EM1, or EM2). The EUART operates in HF mode when the EUARTCLK clock selected in CMU\_UARTCLKCTRL\_CLKSEL is EM01GRPACLK. The EUART operates in LF mode when the selected clock is EM23GRPACLK. 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. #### 22.3.2 Frame Format The frame format used by the EUART 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 9 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 22.2 EUART Asynchronous Frame Format on page 632. Figure 22.2. EUART Asynchronous Frame Format The number of data bits in a frame is set by DATABITS in EUARTn\_FRAMECFG, see Table 22.1 EUART Data Bits on page 632, and the number of stop-bits is set by STOPBITS in EUARTn\_FRAMECFG, see Table 22.2 EUART Stop Bits on page 632. Whether or not a parity bit should be included, and whether it should be even or odd is defined by PARITY, also in EUARTn\_FRAMECFG. For reliable communication, all parties of a transfer must agree on the frame format being used prior to the start of the transfer. Table 22.1. EUART Data Bits | EUARTn_FRAMECFG_DATABITS [3:0] | Number of Data bits | |--------------------------------|---------------------| | 0001 | 4 | | 0010 | 5 | | 0011 | 6 | | 0100 | 7 | | 0101 | 8 (Default) | | 0110 | 9 | Table 22.2. EUART Stop Bits | EUARTn_FRAMECFG_STOPBITS [1:0] | Number of Stop bits | |--------------------------------|---------------------| | 00 | 0.5 (HFCLK ONLY) | | 01 | 1 (Default) | | 10 | 1.5 (HFCLK ONLY) | | 11 | 2 | The order in which the data bits are transmitted and received is defined by MSBF in EUARTn\_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 EUARTn\_CFG0, and the format expected by the receiver can be inverted by setting RXINV in EUARTn\_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. ## 22.3.3 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 22.3 EUART Parity Bits on page 633. 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 22.3. EUART Parity Bits | EUARTn_FRAMECFG_PARITY [1:0] | Description | |------------------------------|-------------------------| | 00 | No parity bit (Default) | | 01 | Reserved | | 10 | Even parity | | 11 | Odd parity | #### 22.3.4 Clock Generation The EUART clock defines the transmission and reception data rate. The baud rate (bit-rate) is given by Figure 22.3 EUART Baud Rate on page 634. $br = f_{EUARTn}/(oversample x (1 + EUARTn_CLKDIV/256))$ ## Figure 22.3. EUART Baud Rate where f<sub>EUARTn</sub> is the peripheral clock frequency and oversample is the oversampling rate as defined by OVS in EUARTn\_CFG0, see Table 22.4 EUART Oversampling on page 634. Table 22.4. EUART Oversampling | EUARTn_CFG0_OVS [2:0] | oversample | |-----------------------|---------------------------------| | 000 | 16 (HF mode only) | | 001 | 8 (HF mode only) | | 010 | 6 (HF mode only) | | 011 | 4 (HF mode only) | | 100 | 1 (OVS disabled - LF mode only) | Note: In LF mode, with oversampling disabled, the baud rate must be less than 1/3 the LF clock frequency. The EUART has a fractional clock divider to allow the EUART clock to be controlled more accurately than what is possible with a standard integral divider. The clock divider used in the EUART 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 EUARTn\_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 *brdesired*, the clock divider EUARTn\_CLKDIV can be calculated by using Figure 22.4 EUART Desired Baud Rate on page 634: EUARTn CLKDIV = 256 x (f<sub>EUARTn</sub>/(oversample x brdesired) - 1) #### Figure 22.4. EUART Desired Baud Rate Table 22.5 EUART Baud Rates in HF mode @ 4MHz Peripheral Clock with 20 bit CLKDIV on page 634 shows a set of desired baud rates and how accurately the EUART is able to generate these baud rates when running at a 4 MHz peripheral clock in HF mode, using 16x or 8x oversampling. Table 22.5. EUART Baud Rates in HF mode @ 4MHz Peripheral Clock with 20 bit CLKDIV | Desired baud | EUAR | Tn_OVS =00 | | EUARTn_OVS =01 | | | | | |---------------|-----------------------------------------|---------------------------|---------|-----------------------------------------|---------------------------|---------|--|--| | rate [baud/s] | EUARTn_CLKDIV/256<br>(to 32nd position) | Actual baud rate [baud/s] | Error % | EUARTn_CLKDIV/256<br>(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 | | | | Desired baud rate [baud/s] | EUAR | Tn_OVS =00 | | EUARTn_OVS =01 | | | | | |----------------------------|-----------------------------------------|---------------------------|---------|-----------------------------------------|---------------------------|---------|--|--| | | EUARTn_CLKDIV/256<br>(to 32nd position) | Actual baud rate [baud/s] | Error % | EUARTn_CLKDIV/256<br>(to 32nd position) | Actual baud rate [baud/s] | Error % | | | | 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 | | | Table 22.6 EUART Baud Rates in LF mode @ 32.768 kHz Peripheral Clock with 20 bit CLKDIV on page 635 shows a set of desired baud rates and how accurately the EUART is able to generate these baud rates when running from a 32.768 kHz peripheral clock in LF mode. Table 22.6. EUART Baud Rates in LF mode @ 32.768 kHz Peripheral Clock with 20 bit CLKDIV | Desired baud rate<br>[baud/s] | EUARTn_CLKDIV/256 (to 32nd position) | Actual baud rate [baud/s] | Error % | |-------------------------------|--------------------------------------|---------------------------|---------| | 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 | ## 22.3.5 Auto Baud Detection The EUART has an automatic baud detection feature, which is available when operating in HF mode. Setting AUTOBAUDEN in EUARTn\_CFG0 uses the first frame received to automatically set the baud rate provided that it contains 0x55 (IrDA uses 0x00). 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 EUARTn\_CLKDIV will be overwritten with the new value. The OVS in EUARTn\_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 detection is done over 8 baud times, only the upper 3 bits of the fractional part of the clock divider are populated. When autobaud detection has completed, the status bit EUARTn\_STATUS\_AUTOBAUDDONE and interrupt flag EUARTn\_IF\_AUTOBAUDDONE are set. #### 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 in LF mode. - For autobaud to work with IrDA, there should be odd parity or no parity in the received data frame. #### 22.3.6 Data Transmission Asynchronous data transmission is initiated by writing data to the transmit buffer using one of the methods described in 22.3.7 Transmit FIFO Operation. When the transmission shift register is empty and ready for new data, a frame from the transmit FIFO 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 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 EUARTn\_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 EUARTn\_STATUS. When the EUART transmitter is enabled and there is no data in the transmit shift register or transmit FIFO, the TXC flag in EUARTn\_STATUS and the TXC interrupt flag in EUARTn\_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. #### 22.3.7 Transmit FIFO Operation The transmit FIFO is a four entry FIFO buffer. A frame can be loaded into the FIFO by writing to EUARTn\_TXDATA. Using EUARTn\_TXDATA allows up to 9 bits to be written to the buffer, as well as a set of control bits for the transmission of the written frame. Every frame in the FIFO is stored with 9 data bits and the additional control bits. A frame is loaded from the FIFO into the shift register if the transmitter is enabled. Figure 22.5 EUART Transmit FIFO Operation on page 637 shows the basics of the transmit FIFO. Figure 22.5. EUART Transmit FIFO Operation In addition to the interrupt flag TXC in EUARTn\_IF and status flag TXC in EUARTn\_STATUS, which are set when the transmission is complete, TXFL in EUARTn\_STATUS and the TXFL interrupt flag in EUARTn\_IF are used to indicate the level of the transmit FIFO. The TXFIW field in EUARTn\_CFG1 controls the level at which the TXFL flags are set. For example, if TXFIW is set to ONEFRAME, TXFL will be set when the FIFO has space for at least one frame. The TXFCNT field in EUARTn\_STATUS indicates the number of entries present in the TX FIFO. If the FIFO is empty, the TXIDLE bit in EUARTn\_STATUS will be set to indicate that the transmitter is idle. The transmit FIFO can be cleared by setting CLEARTX in EUARTn\_CMD. Since this is an asynchronous FIFO, software must first issue the CLEARTX command and then wait on the CLEARTXBUSY status flag until it goes low. The EUART must be enabled (EUARTn\_EN should be set) for the flush command to work. The EUART should not be transmitting when the 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, and will complete transmission. 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. When writing more frames to the transmit buffer than there is free space for, the TXOF interrupt flag in EUARTn\_IF will be set, indicating an overflow. The data already in the transmit buffer is preserved in this case, and no data is written. The FIFO status fields TXFL and TXFCNT are dependent on hardware conditions, and persist even if the EUART is disabled (EU-ARTn\_EN is 0). TXFL will be automatically cleared by hardware if the underlying condition is not met, and TXFCNT always represents the number of words present in the FIFO. Writing to the TX FIFO when the EUART is disabled is allowed. **Note:** In LF 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 EUARTn CFG1. #### 22.3.8 Frame Transmission Control The transmission control bits, which can be written using EUARTn\_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 UART frame are thus not supported by the EUART. Direct GPIO control 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. See 22.3.12 Blocking Incoming Data for more details. - 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 still attempt to send the additional data. Because the output is tristated, nothing will appear at the transmitter output during this time. 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 EUART CFG0. If AUTOTRI is set the TXTRI status flag will always read as 0. ## 22.3.9 Transmission Delay By configuring TXDELAY in EUARTn\_CFG1, the transmitter can be forced to wait a specified number of bit-periods before it transmits the first frame in the TX FIFO. 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. #### 22.3.10 Data Reception Data reception is enabled by setting RXEN bit in EUARTn\_CMD. When the receiver is enabled, it actively samples the input looking for a start bit of a new frame. When a start bit 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 FIFO, making the shift register ready for another frame of data, and the receiver starts looking for another start bit. If a frame is received when the receive FIFO is full, the received frame is discarded and the RXOF interrupt flag in EUARTn IF is set to indicate a receive FIFO overflow. The receiver can be disabled by setting the command bit RXDIS in EUARTn\_CMD. Any frame currently being received when the receiver is disabled is discarded. The RXENS bit in EUARTn\_STATUS indicates whether or not the receiver is enabled. #### 22.3.11 Receive FIFO Operation The receive FIFO is a four entry FIFO buffer. Data can be read from the receive FIFO via EUARTn\_RXDATA. EUARTn\_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 EUARTn\_RXDATA, the frame is pulled out of the FIFO, making room for a new frame. If an attempt is made to read the receive FIFO when it is empty, the RXUF interrupt flag in EUARTn\_IF is set to signal a receive buffer underflow. The data returned from a FIFO underflow read is undefined. Frames can be read from the receive FIFO without removing the data by using EUARTn\_RXDATAP. EUARTn\_RXDATAP gives access to the first frame in the FIFO, as well as the status bits. The data read from this register when the receive FIFO is empty is undefined. No underflow interrupt is generated by reading using this register, i.e. RXUF in EUARTn\_IF is never set as a result of reading from EUARTn\_RXDATAP. The basic operation of the receive FIFO is shown in Figure 22.6 EUART Receive FIFO Operation on page 639. Figure 22.6. EUART Receive FIFO Operation The 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 the 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 EUART is disabled (i.e., EUARTn\_EN is 0). It is possible to read from the receive FIFO while EUART 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. The receive FIFO has four associated interrupt flags in the IF register: 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 the CFG1 register. RXFULL is set when the receive FIFO is full. Both RXFL and RXFULL remain set as long as the underlying condition is true even if the EUART 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 (and this will happen even if EUART is disabled). Reading data from the FIFO or disabling the RXFL / RXFULL interrupts will block the respective interrupt after a software clear. RXOF is set when a new frame is received while the receive FIFO is full, indicating a receive FIFO overflow. The new frame is discarded. RXOF triggers every time an overflow event occurs. RXUF (receive FIFO underflow) is set when an attempt is made by software or DMA to read the receive FIFO when it is empty. The data read from the FIFO is undefined. RXUF triggers every time an underflow occurs even if the EUART is disabled. ### 22.3.12 Blocking Incoming Data When using hardware frame recognition, as detailed in 22.3.23 Multi-Processor Mode and 22.3.24 Collision Detection, it is necessary to be able to let the receiver sample incoming frames without pushing them into the receive FIFO. This is accomplished by blocking incoming data. Incoming data is blocked as long as RXBLOCK in EUARTn\_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 EUARTn\_STATUS or the RXFL interrupt flag in EUARTn\_IF of their arrival. For data to be loaded into the receive buffer, RXBLOCK must be cleared before a frame is fully received by the receiver. RXBLOCK is set by setting RXBLOCKEN in EUARTn\_CMD and disabled by setting RXBLOCKDIS also in EUARTn\_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 when operating in multi-processor mode. See 22.3.23 Multi-Processor Mode for more information. Frames received containing framing or parity errors will not result in the FERR and PERR interrupt flags in EUARTn\_IF being set while RXBLOCK in EUARTn STATUS is set. Hardware recognition is not applied to these erroneous frames, and they are silently discarded. ## 22.3.13 Data Sampling 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 EUARTn 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 22.7 EUART Sampling of Start and Data Bits on page 641. With OVS=0 in EUARTn\_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 22.7 EUART Sampling of Start and Data Bits on page 641. 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 mode, oversampling must be set to 4, 6, 8, or 16x. When operating in LF mode, oversampling must be disabled. Software can disable the majority vote behavior by setting MVDIS in EUARTn\_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 22.7. EUART 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 22.8 EUART Sampling of Stop Bits when Number of Stop Bits are 1 or More on page 642. When a stop bit has been detected, the EUART is ready for a new start bit. As seen in Figure 22.8 EUART Sampling of Stop Bits when Number of Stop Bits are 1 or More on page 642, 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 22.8. EUART 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 EUART to successfully identify the start bit. ## 22.3.14 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 EUARTn\_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 EUARTn RXDATA or EUARTn RXDATAXP registers. If ERRSTX in EUARTn\_CFG0 is set, the transmitter is disabled on received parity errors. If ERRSRX in EUARTn\_CFG0 is set, the receiver is disabled on received parity errors. ## 22.3.15 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 EU-ARTn IF is also set. Frames with framing errors are loaded into the receive FIFO like regular frames. FERR can be accessed by reading the frame from the receive buffer using the EUARTn\_RXDATAX or EUARTn\_RXDATAXP registers. If ERRSTX in EUARTn\_CFG0 is set, the transmitter is disabled on received framing errors. If ERRSRX in EUARTn\_CFG0 is set, the receiver is disabled on received framing errors. ## 22.3.16 Programmable Start Frame The EUART 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 EUART by transmitting a given frame. When SFUBRX in EUARTn\_CFG1 is set, an incoming frame matching the frame defined in EUARTn\_STARTFRAME will result in RXBLOCK in EUARTn\_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 EUARTn\_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 EUARTn\_IF being set, regardless of the value of SFUBRX in EUARTn\_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. EUARTn\_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 receiption, the received frame is not detected as a start frame. ### 22.3.17 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 EU-ARTn\_SIGFRAME is detected by the receiver, the SIGFIF interrupt flag in EUARTn\_IF is set. As with start frame detection, the interrupt will be set even if the receiver is blocked i.e. EUARTn\_STATUS\_RXBLOCK = 1. One use of the programmable signal frame is to signal the end of a multi-frame message transmitted to the EUART. 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 EUART 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, ULFRCO) is used as the EUARTn 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. ## 22.3.18 Local Loopback The EUART receiver samples RX by default, and the transmitter drives TX by default. This is not the only option however. When LOOPBK in EUARTn\_CFG0 is set, the receiver is connected to the TX pin as shown in Figure 22.9 EUART Local Loopback on page 643. This is useful for debugging, as the EUART can receive the data it transmits, but it is also used to allow the EUART 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 22.9. EUART Local Loopback ### 22.3.19 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. ### 22.3.20 Single Data-link In this setup, the EUART both receives and transmits data on the same pin. This is enabled by setting LOOPBK in EUARTn\_CFG0, which connects the receiver to the transmitter output. Because they are both connected to the same line, it is important that the EUART 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 EUARTn\_CMD, which tristates the transmitter. Before transmitting data, the command bit TXTRI-DIS, also in EUARTn\_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 EUARTn\_STATUS. If TXTRI is set when transmitting data, the data is shifted out of the shift register, but is not put out on the TX line. When operating a half duplex data bus, it is common to have a bus master, which first transmits a request to one of the bus slaves, then receives a reply. In this case, the frame transmission control bits, which can be set by writing to EUARTn\_TXDATA, can be used to make the EUART automatically disable transmission, tristate the transmitter and enable reception when the request has been transmitted, making it ready to receive a response from the slave. The transmission delay feature, detailed in 22.3.9 Transmission Delay, 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. 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, 22.3.25 Hardware Flow Control, for more details. Tristating the transmitter can also be performed automatically by the EUART by using AUTOTRI in EUARTn\_CFG0. When AUTOTRI is set, the EUART 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. ## 22.3.21 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 22.10 EUART Half Duplex Communication with External Driver on page 644 shows an example configuration using an external driver. Figure 22.10. EUART Half Duplex Communication with External Driver #### 22.3.22 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. #### 22.3.23 Multi-Processor Mode To simplify communication between multiple processors, the EUART 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 EUARTn\_CFG0 is identified as an address frame. When an address frame is detected, the MPAF interrupt flag in EUARTn\_IF is set, and the address frame is loaded into the receive register. This happens regardless of the value of RXBLOCK in EUARTn\_STATUS. Multi-processor mode is enabled by setting MPM in EUARTn\_CFG0, and the value of the 9th bit in address frames can be set in EU-ARTn\_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. When a slave 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. ## 22.3.23.1 EUART Multi-Processor Mode Example - 1. All slaves enable multi-processor mode and, enable and block the receiver. They will now not receive data unless it is an address frame. MPAB in EUARTn\_CFG0 is set to identify frames with the 9th bit equal to MPAB as address frames. - 2. The master sends a frame containing the address of a slave and with the 9th bit set to the value of MPAB. - 3. All slaves receive the address frame and get an interrupt. They can read the address from the receive FIFO. The selected slave unblocks the receiver to start receiving data from the master. - 4. The master sends data with the 9th bit set to the opposite value of MPAB. - 5. Only the slave with RX enabled and unblocked receives the data. When transmission is complete, the slave blocks the receiver and waits for a new address frame. #### 22.3.24 Collision Detection The EUART 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 EUARTn\_CFG0 or through an external connection, this feature can be used to detect whether data transmitted on the bus by the EUART did get corrupted by a simultaneous transmission by another device on the bus. For collision detection to be enabled, CCEN in EUARTn\_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 EUARTn\_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: Collision detection is only supported for baud rates up to 1 Mbps. #### 22.3.25 Hardware Flow Control Hardware flow control can be used to hold off the link partner's transmission until RX buffer space is available. Port and pin selection for RTS and CTS are configured in GPIO\_EUARTn\_RTSROUTE and GPIO\_EUARTn\_CTSROUTE. RTSPEN in GPIO\_EUARTn\_ROUTEEN enables the RTS pin as an output. RTS is an output signal which indicates that RX FIFO space is available to receive a frame. The link partner is being requested to send its data when RTS is asserted. RTS activation can be made dependent on how much space is available in the receive FIFO using RTXRXFW in EUARTn\_CFG1. For debug use set DBGHALT in EUARTn\_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 input signal that is used to halt transmission. The link partner controls CTS to indicate whether ot not there is space in its receive FIFO to accept new data. It will assert CTS when there is space available, and deassert CTS if there is no more room. If CTS deactivates in the middle of a frame, the frame currently being transmitted is completed before stopping. CTS operation needs to be enabled using EUARTn CFG1 CTSEN. The RTS and CTS signals are active low by default, but their polarity can be changed with RTSINV and CTSINV in EUARTn\_CFG1. ## 22.3.26 Debug Halt During debugging, the debug halt feature allows halting EUART reception by deactivating RTS when the core is halted and continuing frame reception by activating RTS when the core is released. EUART debug halt can be enabled by setting DBGHALT in EUSART CFG1 to '1'. The EUART receiver must be enabled for debug halting to function. When EUSART\_CFG1\_DBGHALT is not set or EUSART\_CFG1\_DBGHALT is set but the debugger has not halted the system, RTS is only dependent on the receive FIFO having space available to receive the specified number of frames given by EUSART\_CFG1\_RTSRXFW. When EUSART\_CFG1\_DBGHALT is set, RTS will remain deactivated as long as the debugger has halted the system. When the debugger releases the system temporarily while DBGHALT is set, RTS will be activated if the receive FIFO has space available to receive at least EUSART\_CFG1\_RTSRXFW frames, and no frame is being received. RTS will be deactivated again when the debugger halt is re-instated, and the receiver starts receiving a new frame or if the receive FIFO does not have space available to receive at least EUSART\_CFG1\_RTSRXFW frames. This behavior allows single stepping in the debugger to pulse the system halt signal for a cycle, and receive the next frame. As the incoming frame is always received until the receive FIFO is full regardless of the state of DBGHALT or whether the chip is halted, the link partner must honor the RTS signal and stop transmitting when RTS is deactivated, or the receive FIFO could overflow. All data in the transmit FIFO is sent out even when a debugger halt is active; therefore, DMA will need to be configured to stop sending EUART TX data during a debug halt. #### 22.3.27 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\_EUARTn\_TRIGGER. When a positive edge is detected on this signal, the receiver is enabled if RXTEN in EUARTn\_TRIGCTRL is set, and the transmitter is enabled if TXTEN in EUARTn\_TRIGCTRL is set. Only one signal input is supported by the EUART. ### 22.3.28 PRS RX Input The EUART can be configured to receive data directly from a PRS channel by setting RXPRSEN in EUARTn\_CFG1. The PRS channel used is selected using PRSSEL in PRS\_EUARTn\_RX. ## 22.3.29 DMA Support The EUART has full DMA support. The DMA controller can write to the transmit FIFO using the EUARTn\_TXDATA register, and it can read from the receive FIFO using the register EUARTn\_RXDATA. This enables single byte transfers, 9 bit data + control/status bits transfers both to and from the EUART. A request for the DMA controller to read from the EUART receive buffer can be triggered when the receive FIFO watermark is crossed, i.e. at least RXFIW frames of data are available in the FIFO. A write request for the DMA controller can be triggered when the transmit FIFO watermark is crossed, i.e. at least TXFIW frames in the transmit buffer are empty. In some cases, it may be sensible to temporarily stop DMA access to the EUART when an error such as a framing error has occurred. This is enabled by setting ERRSDMA in EUARTn CFG0. The EUART can also work with the DMA when operating in EM2 (in LF mode) so that the system does not have to wake up to EM0 or EM1 to consume data. This functionality is enabled by setting TXDMAWU or RXDMAWU in the EUARTn\_CFG1 register. The DMA will be triggered by the EUART when the TX or RX watermark conditions are met. DMA will then temporarily power up and pop/push all the elements of the corresponding FIFO, and then power off again without waking the CPU. ### 22.3.30 Interrupts The interrupts generated by the EUART 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 - SIG - AUTOBAUDDONE If EUART interrupts are enabled, an interrupt will be made if one or more of the interrupt flags in EUARTn\_IF and their corresponding bits in EUARTn IEN are set. In LE mode, all interrupts can serve to wake the system from EM2. #### 22.3.31 EM2 Operation (LF Mode Only) The EUART can operate in EM2 when running from an LF oscillator source (LF mode). Note that sending and receiving data in EM2 requires that the EUART 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 EUART to wait for an incoming UART frame, or even wait on the programmable start or signal frames while the system is consumiung 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 EUARTn\_CFG1, the system will not be able to go to EM2 before all related EUART DMA requests have been processed. This means that if RXDMAWU is set and the EUART receives a frame, the system will wait to go to EM2 before the frame has been read from the EUART. In order for the system to go to EM2 during the last byte transmission, TXDMAWU must be cleared in the DMA interrupt service routine. This is because TXFL will be high during the final byte transfer. ## 22.3.32 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 EUART module, and modulates it before it leaves the EUART. In the same way, the input signal is demodulated before it enters the actual EUART 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 EUART 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 22.11 EUART Example RZI Signal for a given Asynchronous UART Frame on page 648. Figure 22.11. EUART Example RZI Signal for a given Asynchronous UART Frame The IrDA module is enabled by setting IREN. The EUART transmitter output and receiver input is then routed through the IrDA modula- The width of the pulses generated by the IrDA modulator is set by configuring IRPW in EUARTn\_IRCTRL. Four pulse widths are available, each defined relative to the configured bit period as listed in Table 22.7 EUART IrDA Pulse Widths on page 648. | 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 | Table 22.7. EUART IrDA Pulse Widths By default, no filter is enabled in the IrDA demodulator. A filter can be enabled by setting IRFILT in EUARTn\_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 EUART 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 EUART CFG0 must be set. # 22.4 EUSART Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | 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_FRAMECFG | RW CONFIG | Frame Format Register | | 0x014 | EUSART_IRHFCFG | RW CONFIG | HF IrDA Mod Config Register | | 0x018 | EUSART_IRLFCFG | RW CONFIG | LF IrDA Pulse Config Register | | 0x01C | EUSART_TIMINGCFG | RW CONFIG | Timing Register | | 0x020 | EUSART_STARTFRAMECFG | RW CONFIG | Start Frame Register | | 0x024 | EUSART_SIGFRAMECFG | RW CONFIG | Signal Frame Register | | 0x028 | EUSART_CLKDIV | RWH LFSYNC | Clock Divider Register | | 0x02C | EUSART_TRIGCTRL | RW LFSYNC | Trigger Control Register | | 0x030 | EUSART_CMD | W LFSYNC | Command Register | | 0x034 | EUSART_RXDATA | RH | RX Data Register | | 0x038 | EUSART_RXDATAP | RH | RX Data Peek Register | | 0x03C | EUSART_TXDATA | W | TX Data Register | | 0x040 | EUSART_STATUS | RH | Status Register | | 0x044 | EUSART_IF | RWH INTFLAG | Interrupt Flag Register | | 0x048 | EUSART_IEN | RW | Interrupt Enable Register | | 0x04C | EUSART_SYNCBUSY | RH | Synchronization Busy 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_FRAMECFG_SET | RW CONFIG | Frame Format Register | | 0x1014 | EUSART_IRHFCFG_SET | RW CONFIG | HF IrDA Mod Config Register | | 0x1018 | EUSART_IRLFCFG_SET | RW CONFIG | LF IrDA Pulse Config Register | | 0x101C | EUSART_TIMINGCFG_SET | RW CONFIG | Timing Register | | 0x1020 | EUSART_STARTFRA-<br>MECFG_SET | RW CONFIG | Start Frame Register | | 0x1024 | EUSART_SIGFRAMECFG_SET | RW CONFIG | Signal Frame Register | | 0x1028 | EUSART_CLKDIV_SET | RWH LFSYNC | Clock Divider Register | | 0x102C | EUSART_TRIGCTRL_SET | RW LFSYNC | Trigger Control Register | | 0x1030 | EUSART_CMD_SET | W LFSYNC | Command Register | | 0x1034 | EUSART_RXDATA_SET | RH | RX Data Register | | Offset | Name | Туре | Description | |--------|-------------------------------|-------------|-------------------------------| | 0x1038 | EUSART_RXDATAP_SET | RH | RX Data Peek Register | | 0x103C | EUSART_TXDATA_SET | w | TX Data Register | | 0x1040 | EUSART_STATUS_SET | RH | Status Register | | 0x1044 | EUSART_IF_SET | RWH INTFLAG | Interrupt Flag Register | | 0x1048 | EUSART_IEN_SET | RW | Interrupt Enable Register | | 0x104C | EUSART_SYNCBUSY_SET | RH | Synchronization Busy 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_FRAMECFG_CLR | RW CONFIG | Frame Format Register | | 0x2014 | EUSART_IRHFCFG_CLR | RW CONFIG | HF IrDA Mod Config Register | | 0x2018 | EUSART_IRLFCFG_CLR | RW CONFIG | LF IrDA Pulse Config Register | | 0x201C | EUSART_TIMINGCFG_CLR | RW CONFIG | Timing Register | | 0x2020 | EUSART_STARTFRA-<br>MECFG_CLR | RW CONFIG | Start Frame Register | | 0x2024 | EUSART_SIGFRAMECFG_CLR | RW CONFIG | Signal Frame Register | | 0x2028 | EUSART_CLKDIV_CLR | RWH LFSYNC | Clock Divider Register | | 0x202C | EUSART_TRIGCTRL_CLR | RW LFSYNC | Trigger Control Register | | 0x2030 | EUSART_CMD_CLR | W LFSYNC | Command Register | | 0x2034 | EUSART_RXDATA_CLR | RH | RX Data Register | | 0x2038 | EUSART_RXDATAP_CLR | RH | RX Data Peek Register | | 0x203C | EUSART_TXDATA_CLR | W | TX Data Register | | 0x2040 | EUSART_STATUS_CLR | RH | Status Register | | 0x2044 | EUSART_IF_CLR | RWH INTFLAG | Interrupt Flag Register | | 0x2048 | EUSART_IEN_CLR | RW | Interrupt Enable Register | | 0x204C | EUSART_SYNCBUSY_CLR | RH | Synchronization Busy Register | | 0x3000 | EUSART_IPVERSION_TGL | R | IP version ID | | 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_FRAMECFG_TGL | RW CONFIG | Frame Format Register | | 0x3014 | EUSART_IRHFCFG_TGL | RW CONFIG | HF IrDA Mod Config Register | | 0x3018 | EUSART_IRLFCFG_TGL | RW CONFIG | LF IrDA Pulse Config Register | | 0x301C | EUSART_TIMINGCFG_TGL | RW CONFIG | Timing Register | | 0x3020 | EUSART_STARTFRA-<br>MECFG_TGL | RW CONFIG | Start Frame Register | | 0x3024 | EUSART_SIGFRAMECFG_TGL | RW CONFIG | Signal Frame Register | | Offset | Name | Туре | Description | |--------|---------------------|-------------|-------------------------------| | 0x3028 | EUSART_CLKDIV_TGL | RWH LFSYNC | Clock Divider Register | | 0x302C | EUSART_TRIGCTRL_TGL | RW LFSYNC | Trigger Control Register | | 0x3030 | EUSART_CMD_TGL | W LFSYNC | Command Register | | 0x3034 | EUSART_RXDATA_TGL | RH | RX Data Register | | 0x3038 | EUSART_RXDATAP_TGL | RH | RX Data Peek Register | | 0x303C | EUSART_TXDATA_TGL | W | TX Data Register | | 0x3040 | EUSART_STATUS_TGL | RH | Status Register | | 0x3044 | EUSART_IF_TGL | RWH INTFLAG | Interrupt Flag Register | | 0x3048 | EUSART_IEN_TGL | RW | Interrupt Enable Register | | 0x304C | EUSART_SYNCBUSY_TGL | RH | Synchronization Busy Register | # 22.5 EUSART Register Description # 22.5.1 EUSART\_IPVERSION - IP version ID | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | • | | | | | • | • | | | 2 | 2 | • | | | | | • | | • | • | | | • | | | | | Access | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | IDVEDOIN | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP version ID | | | The read only IPVERSIOn modules with different values | 0 | | this module. There may be minor software changes required for | # 22.5.2 EUSART\_EN - Enable Register | Offset | Bit Position | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | 0x004 | 33 34 35 36 37 38 38 48 49 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>0</th> | 0 | | Reset | | 0x0 | | Access | | RW | | Name | | EN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | Module enable | | | Set to enable the module | Э. | | | # 22.5.3 EUSART\_CFG0 - Configuration 0 Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------------|---------|----|----|----|----|----|--------|--------|---------|----|-----------|----|----|---------|------|------|-------|--------|----|---|------|---|---|---|-----|---|------|-----|--------|--------|---| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 000 | 0x0 | | | | | ' | 0x0 | 0×0 | 0x0 | | 0×0 | | • | 000 | | | 000 | 0X0 | | | 000 | | ' | | 0X0 | • | 0x0 | 0×0 | 0x0 | 0x0 | | | Access | W. | ZW<br>W | | | | | | RW | W. | RW | | RW | | | W. | | | Z. | ₩<br>M | | | W. | | | | R | | W. | W. | W<br>M | RW | | | Name | AUTOBAUDEN | MVDIS | | | | | | ERRSTX | ERRSRX | ERRSDMA | | SKIPPERRF | | | AUTOTRI | | | VNIXL | RXINV | | | MSBF | | | | OVS | | MPAB | MPM | CCEN | LOOPBK | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-------------------|---------------------------------------------------------------------------------------| | 31 | AUTOBAUDEN | 0x0 | RW | AUTOBAUD detection enable | | | Detects the baud rate | e based on rece | eiving a 0x55 fra | ame (0x00 for IrDA). | | 30 | MVDIS | 0x0 | RW | Majority Vote Disable | | | Disable majority vote | for 16x, 8x and | d 6x oversampli | ng modes. | | 29:25 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 24 | ERRSTX | 0x0 | RW | Disable TX On Error | | | When set, the transn | nitter is disabled | d on framing and | d parity errors 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 | Disable RX On Error | | | When set, the receiv | er is disabled o | n framing and p | parity errors. | | | 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 | Halt DMA Read On Error | | | When set, DMA read | I requests will b | e cleared on fra | aming and parity errors. | | | Value | Mode | | Description | | | 0 | DISABLE | | Framing and parity errors have no effect on DMA requests from the UART | | | 1 | ENABLE | | DMA requests from the UART are blocked while the PERR or FERR interrupt flags are set | | 21 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 20 | SKIPPERRF | 0x0 | RW | Skip Parity Error Frames | | | When set, the receiv | er discards fran | nes with parity e | errors. The PERR interrupt flag is still set. | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------------------|-----------------------|-------------------|---------------------------------------------------------------------------| | 19:18 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 17 | AUTOTRI | 0x0 | RW | Automatic TX Tristate | | | When enabled, TX transmission starts | - | ware wheneve | r the transmitter is idle, and TXTRI is cleared by hardware when | | | 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 | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 14 | TXINV | 0x0 | RW | Transmitter output Invert | | | The output from th | e EUART transmit | tter can optiona | ally 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 | Receiver Input Invert | | | Setting this bit will | invert the input to | the EUART red | ceiver. | | | 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 | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 10 | MSBF | 0x0 | RW | Most Significant Bit First | | | Decides whether of | data is sent with the | e least significa | ant 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 | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 7:5 | OVS | 0x0 | RW | Oversampling | | | Sets the number o cles gives better p | • | a EUART bit-pe | eriod. More clock cycles gives better robustness, while less clock cy- | | | Value | Mode | | Description | | | 0 | X16 | | 16X oversampling | | | 1 | X8 | | 8X oversampling | | | 2 | X6 | | 6X oversampling | | Bit | Name | Reset | Access | Description | |-----|-------------------------------------|--------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 3 | X4 | | 4X oversampling | | | 4 | DISABLE | | Disable oversampling (for LF operation) | | 4 | MPAB | 0x0 | RW | Multi-Processor Address-Bit | | | Defines the value the frame as a mu | | | t. An incoming frame with its 9th bit equal to the value of this bit marks | | 3 | MPM | 0x0 | RW | Multi-Processor Mode | | | Multi-processor m frame. | ode uses the 9th I | oit of the EUAR | T frames to tell whether the frame is an address frame or a data | | | 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 | Collision Check Enable | | | Enables collision of | checking on data v | 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 | Loopback Enable | | | Allows the receive | er to be connected | directly to the E | EUART transmitter for loopback and half duplex communication. | | | 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 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | # 22.5.4 EUSART\_CFG1 - Configuration 1 Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|-----------|----|----|---------------------------------------|-------|----|--------|--------------|---------|----|------|------|--------|---------|---------|-----|-----|--------|--------|----|---------|-------|--------|---------|-----|-----|-----| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | Ş | Š | | Š | )<br>X | | 2 | 0x0 | | | | | 0x0 | 0X0 | 0x0 | | | | ' | | 000 | 0x0 | 0×0 | 0x0 | | Access | | | | | | | | | W W W W W W W W W W W W W W W W W W W | | | | | | | | | | | | | | ₩<br>M | W<br>M | R. | RW<br>W | | | | | | | | Name | | | | | | MEXICO TO | 7 | | /VIII/ | KATIW | | TVEIM/ | ^<br> <br> - | RXPRSEN | | | | SFUBRX | RXDMAWU | TXDMAWU | | | | | | RTSINV | CTSEN | CTSINV | DBGHALT | | | | | Bit | Name | Reset | Access | Description | |-------|-------------------|----------------------|-----------------|-----------------------------------------------------------------------------------| | 31:24 | Reserved | To ensure o | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 23:22 | RTSRXFW | 0x0 | RW | Request-to-send RX FIFO Watermark | | | Set Request-to-se | nd watermark level | | | | | Value | Mode | | Description | | | 0 | ONEFRAM | E | RTS is set if there is space for at least one more frame in the RX FIFO. | | | 1 | TWOFRAM | ES | RTS is set if there is space for at least two more frames in the RX FIFO. | | | 2 | THREEFRA | AMES | RTS is set if there is space for at least three more frames in the RX FIFO. | | | 3 | FOURFRAM | MES | RTS is set if there is space for four more frames in the RX FIFO. | | 21 | Reserved | To ensure o | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 20:19 | RXFIW | 0x0 | RW | RX FIFO Interrupt Watermark | | | Determines the in | errupt and status le | vel of the Rec | eive FIFO. Also impacts RX DMA request. | | | Value | Mode | | Description | | | 0 | ONEFRAM | E | RXFL status flag and IF are set when the RX FIFO has at least one frame in it. | | | 1 | TWOFRAM | ES | RXFL status flag and IF are set when the RX FIFO has at least two frames in it. | | | 2 | THREEFRA | AMES | RXFL status flag and IF are set when the RX FIFO has at least three frames in it. | | | 3 | FOURFRAM | MES | RXFL status flag and IF are set when the RX FIFO has four frames in it. | | 18 | Reserved | To ensure o | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con | | 10 | | | D)A/ | TX FIFO Interrupt Watermark | | | TXFIW | 0x0 | RW | | | 17:16 | | | | smit FIFO. Also impacts TX DMA request. | | 1 2 3 RXPRSEN When set, the PRS channer Reserved SFUBRX Set to unblock RX on State RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV When set, the RTS pin po | To ensure coventions 0x0 art frame recep 0x0 am EM2 to EM 0x0 am EM2 to EM To ensure coventions 0x0 | ES MES MES RW as input to RX. compatibility with RW ption. RW It for DMA/ EU RW | Transmitter DMA Wakeup | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 RXPRSEN When set, the PRS channer Reserved SFUBRX Set to unblock RX on State RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | THREEFRA FOURFRAM 0x0 nel selected a To ensure coventions 0x0 art frame recep 0x0 am EM2 to EM 0x0 am EM2 to EM To ensure coventions 0x0 | RW as input to RX. ompatibility with RW ption. RW If for DMA/ EU, RW If for DMA/ EU, ompatibility with | at least two more frames. TXFL status flag and IF are set when the TX FIFO has space for at least three more frames. TXFL status flag and IF are set when the TX FIFO has space for at least four more frames. PRS RX Enable In future devices, always write bits to 0. More information in 1.2 Constant Frame Unblock Receiver Receiver DMA Wakeup ART RX interaction Transmitter DMA Wakeup ART TX interaction In future devices, always write bits to 0. More information in 1.2 Constant Frame Unblock Receiver | | RXPRSEN When set, the PRS channer Reserved SFUBRX Set to unblock RX on State RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | To ensure coventions 0x0 art frame recep 0x0 am EM2 to EM 0x0 am EM2 to EM To ensure coventions 0x0 | RW as input to RX. ompatibility with RW ption. RW If for DMA/ EU, RW If for DMA/ EU, ompatibility with | at least three more frames. TXFL status flag and IF are set when the TX FIFO has space for at least four more frames. PRS RX Enable In future devices, always write bits to 0. More information in 1.2 Con Start Frame Unblock Receiver Receiver DMA Wakeup ART RX interaction Transmitter DMA Wakeup ART TX interaction In future devices, always write bits to 0. More information in 1.2 Con In future devices, always write bits to 0. More information in 1.2 Con | | RXPRSEN When set, the PRS channer Reserved SFUBRX Set to unblock RX on State RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | 0x0 nel selected a To ensure coventions 0x0 art frame recep 0x0 am EM2 to EM 0x0 am EM2 to EM To ensure coventions 0x0 | RW as input to RX. ompatibility with RW ption. RW I1 for DMA/ EU RW I1 for DMA/ EU ompatibility with | PRS RX Enable In future devices, always write bits to 0. More information in 1.2 Con Start Frame Unblock Receiver Receiver DMA Wakeup ART RX interaction Transmitter DMA Wakeup ART TX interaction In future devices, always write bits to 0. More information in 1.2 Con | | When set, the PRS channed Reserved SFUBRX Set to unblock RX on State RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | To ensure coventions 0x0 art frame recep 0x0 am EM2 to EM 0x0 To ensure coventions 0x0 | RW ption. RW If for DMA/ EU, RW If for DMA/ EU, COMPatibility with | Start Frame Unblock Receiver Receiver DMA Wakeup ART RX interaction Transmitter DMA Wakeup ART TX interaction h future devices, always write bits to 0. More information in 1.2 Continuous formation format | | Reserved SFUBRX Set to unblock RX on Sta RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | To ensure coventions 0x0 art frame recep 0x0 am EM2 to EM 0x0 am EM2 to EM To ensure coventions 0x0 | ompatibility with RW ption. RW I1 for DMA/ EU RW I1 for DMA/ EU ompatibility with | Start Frame Unblock Receiver Receiver DMA Wakeup ART RX interaction Transmitter DMA Wakeup ART TX interaction h future devices, always write bits to 0. More information in 1.2 Con | | Reserved SFUBRX Set to unblock RX on Sta RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | To ensure coventions 0x0 art frame recep 0x0 am EM2 to EM 0x0 am EM2 to EM To ensure coventions 0x0 | ompatibility with RW ption. RW I1 for DMA/ EU RW I1 for DMA/ EU ompatibility with | Start Frame Unblock Receiver Receiver DMA Wakeup ART RX interaction Transmitter DMA Wakeup ART TX interaction h future devices, always write bits to 0. More information in 1.2 Con | | Set to unblock RX on Star RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | ox0 om EM2 to EM ox0 om EM2 to EM ox0 om EM2 to EM To ensure coventions ox0 | ption. RW I1 for DMA/ EU RW I1 for DMA/ EU ompatibility with | Receiver DMA Wakeup ART RX interaction Transmitter DMA Wakeup ART TX interaction In future devices, always write bits to 0. More information in 1.2 Con | | RXDMAWU Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | 0x0 om EM2 to EM 0x0 om EM2 to EM To ensure coventions 0x0 | RW I1 for DMA/ EU RW I1 for DMA/ EU ompatibility with | ART RX interaction Transmitter DMA Wakeup ART TX interaction In future devices, always write bits to 0. More information in 1.2 Con | | Set to enable wakeup from TXDMAWU Set to enable wakeup from Reserved RTSINV | om EM2 to EM 0x0 om EM2 to EM To ensure coventions 0x0 | I1 for DMA/ EU/<br>RW<br>I1 for DMA/ EU/<br>ompatibility with | ART RX interaction Transmitter DMA Wakeup ART TX interaction In future devices, always write bits to 0. More information in 1.2 Con- | | TXDMAWU Set to enable wakeup from Reserved RTSINV | 0x0<br>om EM2 to EM<br>To ensure coventions<br>0x0 | RW<br>I1 for DMA/ EU,<br>ompatibility with | Transmitter DMA Wakeup ART TX interaction In future devices, always write bits to 0. More information in 1.2 Con- | | Set to enable wakeup from Reserved | To ensure coventions 0x0 | I1 for DMA/ EU | ART TX interaction h future devices, always write bits to 0. More information in 1.2 Con- | | Reserved | To ensure coventions | ompatibility with | h future devices, always write bits to 0. More information in 1.2 Con | | RTSINV | ventions<br>0x0 | | · | | | | RW | Request-to-send Invert Enable | | When set, the RTS pin po | alarity ia invari | | | | | olanty is inven | ted. | | | Value | Mode | | Description | | 0 | DISABLE | | The RTS pin is active low | | 1 | ENABLE | | The RTS pin is active high | | CTSEN | 0x0 | RW | Clear-to-send Enable | | | | | link partner asserts CTS. Any data in the TX shift register will oad into the TX shift register | | Value | Mode | | Description | | 0 | DISABLE | | Ignore CTS | | 1 | ENABLE | | Stop transmitting when CTS is inactive | | CTSINV | 0x0 | RW | Clear-to-send Invert Enable | | When set, the CTS pin po | olarity is inver | ted. | | | Value | Mode | | Description | | 0 | DISABLE | | The CTS pin is active low | | 1 | ENABLE | | The CTS pin is active high | | | 0x0 | | Debug halt | | 1 1 1 | /alue CTSINV When set, the CTS pin power of the company c | /alue Mode DISABLE ENABLE CTSINV 0x0 When set, the CTS pin polarity is inver /alue Mode DISABLE ENABLE ENABLE | DISABLE ENABLE CTSINV 0x0 RW When set, the CTS pin polarity is inverted. Value Mode DISABLE | | Bit | Name | Reset Access | Description | |-----|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Value | Mode | Description | | | 0 | DISABLE | Continue normal UART operation even if core is halted | | | 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. | # 22.5.5 EUSART\_FRAMECFG - Frame Format Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|--------|---------|---|----|-----|----------|---|---|---|---|---|---|----------|----------| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | 3 | Š | | | 6 | OXO | | | | | | | 5 | N OX | | Access | | | | | | | | | | | | | | | | | | | 2 | ≥<br>Y | | | Š | <u>}</u> | | | | | | | <u> </u> | <u>}</u> | | Name | | | | | | | | | | | | | | | | | | | OFIGOR | SIGPBIS | | | , E | ጚ | | | | | | | OFIGATAC | - X | | Bit | Name | Reset | Access | Description | |--------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:14 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 13:12 | STOPBITS | 0x1 | RW | Stop-Bit Mode | | | Determines the nu | ımber of stop-bits ı | used. | | | | 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 | ONEAND | AHALF | 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 | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 11:10<br>9:8 | Reserved PARITY | | e compatibility with | n future devices, always write bits to 0. More information in 1.2 Con-<br>Parity-Bit Mode | | | PARITY | ventions<br>0x0 | RW | Parity-Bit Mode her even or odd parity should be used. | | | PARITY | ventions<br>0x0 | RW | Parity-Bit Mode | | | PARITY Determines wheth | ventions 0x0 er parity bits are e | RW | Parity-Bit Mode her even or odd parity should be used. | | | PARITY Determines wheth Value | ventions 0x0 er parity bits are e Mode | RW | Parity-Bit Mode her even or odd parity should be used. Description | | | PARITY Determines wheth Value 0 | ventions 0x0 er parity bits are e Mode NONE | RW | Parity-Bit Mode her even or odd parity should be used. Description Parity bits are not used Even parity are used. Parity bits are automatically generated | | | PARITY Determines wheth Value 0 2 | ventions 0x0 er parity bits are e Mode NONE EVEN ODD | RW<br>nabled, and whet | Parity-Bit Mode her even or odd parity should be used. Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. | | 9:8 | PARITY Determines wheth Value 0 2 | ventions 0x0 er parity bits are e Mode NONE EVEN ODD | RW<br>nabled, and whet | Parity-Bit Mode her even or odd parity should be used. Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. | | 9:8 | PARITY Determines wheth Value 0 2 3 Reserved | ventions 0x0 er parity bits are e Mode NONE EVEN ODD To ensure ventions 0x2 | RW nabled, and whet | Parity-Bit Mode her even or odd parity should be used. Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. In future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | PARITY Determines wheth Value 0 2 3 Reserved DATABITS | ventions 0x0 er parity bits are e Mode NONE EVEN ODD To ensure ventions 0x2 | RW nabled, and whet | Parity-Bit Mode her even or odd parity should be used. Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. In future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | PARITY Determines wheth Value 0 2 3 Reserved DATABITS Sets the number of | ventions 0x0 er parity bits are e Mode NONE EVEN ODD To ensure ventions 0x2 of data bits in a EU | RW nabled, and whet | Parity-Bit Mode her even or odd parity should be used. Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. In future devices, always write bits to 0. More information in 1.2 Con- Data-Bit Mode | | 9:8 | PARITY Determines wheth Value 0 2 3 Reserved DATABITS Sets the number of Value | ventions 0x0 er parity bits are e Mode NONE EVEN ODD To ensure ventions 0x2 of data bits in a EU Mode | RW nabled, and whet | Parity-Bit Mode her even or odd parity should be used. Description Parity bits are not used Even parity are used. Parity bits are automatically generated and checked by hardware. Odd parity is used. Parity bits are automatically generated and checked by hardware. In future devices, always write bits to 0. More information in 1.2 Con- Data-Bit Mode Description | | Bit | Name | Reset | Access | Description | |-----|------|-------|--------|-------------| | | | | | | # 22.5.6 EUSART\_IRHFCFG - HF IrDA Mod Config Register | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|---|----------|----------|-----|--------| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | ' | • | ' | ' | | • | • | | • | • | | • | ' | • | • | ' | • | ' | | • | | | | • | | | 0×0 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | SX<br>SX | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | IRHFFILT | IRHFPW | | IRHFEN | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|-----------------|------------------------------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 3 | IRHFFILT | 0x0 | RW | IrDA RX Filter | | | 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 4 consecutive clock cycles to be detected | | 2:1 | IRHFPW | 0x0 | RW | IrDA TX Pulse Width | | | Configure the puls | e width generated | by the modula | tor as a fraction of the configured EUART 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 | Enable IrDA Module | | | Enable IrDA modu | le and route EUAF | RT signals thro | ugh it. Used when EUART has HF clock. | # 22.5.7 EUSART\_IRLFCFG - LF IrDA Pulse Config Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | • | | | | | | | | | | • | • | | | | | | | | | | | | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | IRLFEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | IRLFEN | 0x0 | RW | Pulse Generator/Extender Enable | | | Filter EUART output thro | ough pulse ge | nerator and the | EUART input through the pulse extender. Used for LF operation. | # 22.5.8 EUSART\_TIMINGCFG - Timing Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------|------------| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | • | • | | • | | | | | | • | | | • | | | • | | | | | | | | | | • | • | | | Ç | OX<br>OX | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | <br>}<br>Y | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 74 1707 | I XDELAY | | Bit | Name | Reset | Access | Description | |------|--------------------|---------------------|-----------------|---------------------------------------------------------------------------| | 31:2 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | TXDELAY | 0x0 | RW | TX Delay Transmission | | | Configurable delay | y before new rtansf | ers. Frames s | ent back-to-back are not delayed. | | | Value | Mode | | 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. | | | | | | | # 22.5.9 EUSART\_STARTFRAMECFG - Start Frame Register | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|---|----|----|---|----|---|---|---|---|---|------------|---|---|---|---| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | | | | | | | | | ' | | ' | <u>'</u> | ' | ' | | ' | ' | | | | | | | | | 0X0 | | | , | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z<br>≪ | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | STARTFRAME | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:9 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 8:0 | STARTFRAME | 0x0 | RW | Start Frame | | | | | | | | | | When a frame matching STARTFRAME is received, the receiver detects that and STARTF interrupt flag is set. SFUBRX is set, RXBLOCK is cleared and the start frame is loaded in to the RX FIFO. | | | | | | | | | | | # 22.5.10 EUSART\_SIGFRAMECFG - Signal Frame Register | Offset | Bit Position | | | | | | | | | | | | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|--|--|--| | 0x024 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>- 0</th> | - 0 | | | | | | | | | | | | Reset | OXO | | | | | | | | | | | | | Access | R <sub>M</sub> ≤ Market and Mar | | | | | | | | | | | | | Name | SIGFRAME | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-----------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | SIGFRAME | 0x0 | RW | Signal Frame Value | | | When a frame matching | SIGFRAME i | s detected by th | e receiver, SIGF interrupt flag is set. | # 22.5.11 EUSART\_CLKDIV - Clock Divider Register | Offset | Bit Position | | | | | | | | | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|--|--|--| | 0x028 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>- 0</th> | - 0 | | | | | | | | | | | | Reset | 0% | | | | | | | | | | | | | Access | | | | | | | | | | | | | | Name | ≥io | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | |-------|----------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|--|--|--| | 31:23 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | | | | | 22:3 | DIV | 0x0 | RW | Fractional Clock Divider | | | | | | | total divider is ([22:8] + | [7:3]/32). To n | [7:3] are the fractional part and bits [22:8] are the integer part. The easier the total divider can also be calculated as ([22:8] + [7:0]/256) DEN in CFG0 register will overwrite the DIV field. | | | | | | | 2:0 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information ventions | | | | | | | # 22.5.12 EUSART\_TRIGCTRL - Trigger Control Register | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|-------|--------| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 41 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Z. | R<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TXTEN | RXTEN | | Bit | Name | Reset | Access | Description | |------|------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | TXTEN | 0x0 | RW | Transmit Trigger Enable | | | When set, the PRS char | nel selected b | by TSEL sets T | XEN, enabling the transmitter on positive trigger edges. | | 0 | RXTEN | 0x0 | RW | Receive Trigger Enable | | | When set, the PRS char | inel selected b | by TSEL sets R | XEN, enabling the receiver on positive trigger edges. | # 22.5.13 EUSART\_CMD - Command Register | Offset | Bit Position | | | | | | | | |--------|----------------------------------------------------------------|---------|---------|------------|-----------|-------|------|------------------| | 0x030 | 33 33 34 35 36 37 38 38 39 39 39 39 39 39 39 39 39 39 39 39 39 | 1 00 | , 9 | 5 | 4 | 3 | 7 | - 0 | | Reset | | 000 | 0 X | 000 | 0x0 | 0x0 | 0x0 | 000 | | Access | | 3 | 3 3 | > | > | > | > 3 | <b>&gt; &gt;</b> | | Name | | CLEARTX | TXTRIEN | RXBLOCKDIS | RXBLOCKEN | TXDIS | TXEN | RXDIS | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------|----------------------|-------------------|---------------------------------------------------------------------------| | 31:9 | Reserved | To ensur<br>ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 8 | CLEARTX | 0x0 | W | Clear TX FIFO | | | Set to clear TX FIFO disabling transmitter | | be enabled (EU | ARTn_EN=1) but should not be transmitting (can be achieved by | | 7 | TXTRIDIS | 0x0 | W | Transmitter Tristate Disable | | | Disables tristating of | the transmitter | output. | | | 6 | TXTRIEN | 0x0 | W | Transmitter Tristate Enable | | | Tristates the transmi | tter output. | | | | 5 | RXBLOCKDIS | 0x0 | W | Receiver Block Disable | | | Set to clear RXBLO0 | CK, resulting in | all incoming fran | mes being loaded into the RX FIFO | | 4 | RXBLOCKEN | 0x0 | W | Receiver Block Enable | | | Set to set RXBLOCK | K, resulting in a | Il incoming frame | es being discarded. | | 3 | TXDIS | 0x0 | W | Transmitter Disable | | | Set to disable transm | nission. Any on | going transmiss | ion will be aborted. | | 2 | TXEN | 0x0 | W | Transmitter Enable | | | Set to enable data tra | ansmission. | | | | 1 | RXDIS | 0x0 | W | Receiver Disable | | | Set to disable data redded. | eception. If a fr | ame is under rec | ception when the receiver is disabled, the incoming frame is discar- | | 0 | RXEN | 0x0 | W | Receiver Enable | | | Set to activate data r | eception on El | JARTn_RX. | | # 22.5.14 EUSART\_RXDATA - RX Data Register | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|------|------|---|---|---|---|--------|---|---|---|---| | 0x034 | 33 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 7 | _ | 0 | | Reset | | | | • | | | | | | | | | | | • | • | | | | | | 000 | 0x0 | | | | | 0×0 | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | œ | Ж | | | | | 2 | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | FERR | PERR | | | | | RXDATA | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:11 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 10 | FERR | 0x0 | R | Framing Error | | | Set if received data has | a framing err | or. Can be the r | esult of a break condition. | | 9 | PERR | 0x0 | R | Parity Error | | | Set if received data has | a parity error | | | | 8:0 | RXDATA | 0x0 | R | RX Data | | | Use this register to read | d data from the | e EUART buffer | | # 22.5.15 EUSART\_RXDATAP - RX Data Peek Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|-------|----------|---|---|---|---|---------|---|---|---|---| | 0x038 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | | | | | | | | | | | | | | | | 0x0 | 0x0 | | | | | 0×0 | | | | - | | Access | | | | | | | | | | | | | | | | | | | | | | œ | <u>~</u> | | | | | 2 | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | FERRP | PERRP | | | | | RXDATAP | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------------|-----------------------|-------------------|-------------------------------------------------------------------------| | 31:11 | Reserved | To ensure<br>ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 10 | FERRP | 0x0 | R | Framing Error Peek | | | Set if received data has | a framing er | or. Can be the r | esult of a break condition. | | 9 | PERRP | 0x0 | R | Parity Error Peek | | | Set if received data has | a parity erro | ·. | | | 8:0 | RXDATAP | 0x0 | R | RX Data Peek | | | Use this register to acco | ess data read | from the EUAR | T without popping the FIFO. | # 22.5.16 EUSART\_TXDATA - TX Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|--------|---------|---------|---------|--------|---|---|---|---|--------|---|---|---|---| | 0x03C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | 0X0 | 0X0 | 0×0 | 0X0 | 0×0 | | | | | 0×0 | | | | | | Access | | | | | | | | | | | | | | | | | | | > | > | > | > | W | | | | | ≥ | | | | | | Name | | | | | | | | | | | | | | | | | | | RXENAT | TXDISAT | TXBREAK | TXTRIAT | UBRXAT | | | | | TXDATA | | | | | | Bit | Name | Reset | Access | Description | |-------|------------------------------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:14 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 13 | RXENAT | 0x0 | W | Enable RXEN After Transmission | | | Set to enable reception a | after transmiss | sion. | | | 12 | TXDISAT | 0x0 | W | Clear TXEN After Transmission | | | Set to disable trasmitter | and release d | ata bus directly | after transmission. | | 11 | TXBREAK | 0x0 | W | Transit Data as Break | | | Set to send data as a bre the value of TXDATA. | eak. Recipient | t will see a frami | ng error or a break condition depending on its configuration and | | 10 | TXTRIAT | 0x0 | W | Set TXTRI After Transmisssion | | | Set to tri-state transmitte | er by setting T | XTRI after trans | mission. | | 9 | UBRXAT | 0x0 | W | Unblock RX After Transmission | | | Set to clear RXBLOCK a | ifter transmiss | sion, unblocking | the receiver. | | 8:0 | TXDATA | 0x0 | W | TX Data | | | Use this register to write | data to the E | UART. If TXEN | is set, a transfer will be initiated at the first opportunity. | # 22.5.17 EUSART\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|--------------|----|----|----|----|-------------|---|----------|------|------|----|--------|--------|---|----|---|--------|------|------|-----|----------|---------|---|-------|-------| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | | 0x0 | | | | | 0×0 | | 0×0 | | | ' | 0x1 | 0X1 | | ' | | 0×0 | 0×0 | 0×1 | 0×0 | 0×0 | 0×0 | | 000 | 0x0 | | Access | | | | | | | | 22 | | | | | 22 | | <u>~</u> | | | | ~ | 22 | | | | 22 | œ | œ | œ | <u>~</u> | œ | | œ | ~ | | Name | | | | | | | | AUTOBAUDDONE | | | | | CLEARTXBUSY | | TXFCNT | | | | TXIDLE | RXIDLE | | | | RXFULL | RXFL | TXFL | TXC | TXTRI | RXBLOCK | | TXENS | RXENS | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------------------|----------------|--------------------|--------------------------------------------------------------------------| | 31:25 | Reserved | To ensur | | ith future devices, always write bits to 0. More information in 1.2 Con- | | | | ventions | | | | 24 | AUTOBAUDDONE | 0x0 | R | Auto Baud Rate Detection Completed | | | Set when auto baud ra<br>set in CFG0 register, t | | | KDIV has been updated with required value. If AUTOBAUDEN is not | | 23:20 | Reserved | To ensur | e compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 19 | CLEARTXBUSY | 0x0 | R | TX FIFO Clear Busy | | | After issuing CLEART | X command, | wait on this statu | s flag until it goes low | | 18:16 | TXFCNT | 0x0 | R | Valid entries in TX FIFO | | | Count of TX valid FIFO | ) entries | | | | 15:14 | Reserved | To ensur | e compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 13 | TXIDLE | 0x1 | R | TX Idle | | | Set when TX idle | | | | | 12 | RXIDLE | 0x1 | R | RX Idle | | | Set when RX is idle | | | | | 11:9 | Reserved | To ensur | e compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 8 | RXFULL | 0x0 | R | RX FIFO Full | | | Set when the RX FIFC | ) is full. | | | | 7 | RXFL | 0x0 | R | RX FIFO Level | | | Set when data is availa | able in the R〉 | K FIFO. Depends | on the RXFIW setting in the CFG1 register. | | 6 | TXFL | 0x1 | R | TX FIFO Level | | | Set when there is space | ce for data in | the TX FIFO. De | pends on the TXFIW setting in CFG1 register. | | 5 | TXC | 0x0 | R | TX Complete | | | Set when a transmissi | on has compl | eted and no mor | e data is available in the TX FIFO and shift register. | | 4 | TXTRI | 0x0 | R | Transmitter Tristated | | | | | | | | Bit | Name | Reset | Access | Description | |-----|----------------------------------------|---------------------|-----------------|-------------------------------------------------------------------------------| | | Set when the tran then this bit is alw | | and cleared w | hen transmitter output is enabled. If AUTOTRI in UARTn_CFG is set, | | 3 | RXBLOCK | 0x0 | R | Block Incoming Data | | | When set, the rec at the instant the f | | | An incoming frame will not be loaded into the RX FIFO if this bit is set ved. | | 2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1 | TXENS | 0x0 | R | Transmitter Enable Status | | | Set when the tran | smitter is enabled. | | | | 0 | RXENS | 0x0 | R | Receiver Enable Status | | | Set when the rece | iver is enabled. | | | # 22.5.18 EUSART\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|--------------|----|----|----|----|--------|--------|----|------|------|----|--------|-----|---|--------|------|------|---|------|------|---------|--------|--------|--------|--------| | 0x044 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | æ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | | | ' | | | 0x0 | | | • | | 000 | 0×0 | | | | ' | 0x0 | 000 | | 0×0 | 0x0 | 0×0 | | 0X | 0×0 | 0×0 | 000 | 0x0 | 0×0 | 0x0 | | Access | | | | | | | | RW | | | | | ₩<br>W | RW | | | | | RW | S. | | ₩<br>M | RW | W. | | ₩ | Z. | RW<br>W | %<br>M | ₩<br>M | ₩<br>M | A<br>M | | Name | | | | | | | | AUTOBAUDDONE | | | | | SIGF | STARTF | | | | | TXIDLE | CCF | | MPAF | FERR | PERR | | TXOF | RXUF | RXOF | RXFULL | RXFL | TXFL | TXC | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|--------------------|--------------------------------------------------------------------------------------------------------------| | 31:25 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 24 | AUTOBAUDDONE | 0x0 | RW | Auto Baud Complete Interrupt Flag | | | Set when auto baud rate | e detection is | complete. | | | 23:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19 | SIGF | 0x0 | RW | Signal Frame Interrupt Flag | | | | | | when MPA, START, and SIGNAL are set to match the same arbitrary sequence due to synchronization uncertainty. | | 18 | STARTF | 0x0 | RW | Start Frame Interrupt Flag | | | | | | when MPA, START, and SIGNAL are set to match the same frame, ry sequence due to synchronization uncertainty. | | 17:14 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 13 | TXIDLE | 0x0 | RW | TX Idle Interrupt Flag | | | Set when TX goes idle. | At this point, t | ransmission has | sended | | 12 | CCF | 0x0 | RW | Collision Check Fail Interrupt Flag | | | Set when a collision che | ck notices an | error in the tran | smitted data. | | 11 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 10 | MPAF | 0x0 | RW | Multi-Processor Address Frame Interrupt | | | Set when a multi-proces | sor address f | rame is detected | I. | | 9 | FERR | 0x0 | RW | Framing Error Interrupt Flag | | | Set when a frame with a | framing error | r is received whil | le RXBLOCK is cleared. | | 8 | PERR | 0x0 | RW | Parity Error Interrupt Flag | | | Set when a frame with a | parity error is | s received while | RXBLOCK is cleared. | | 7 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 6 | TXOF | 0x0 | RW | TX FIFO Overflow Interrupt Flag | | Bit | Nomo | Reset | A 00000 | Pagarintian | |-----|----------------------------|------------------------------------------------------|------------------|---------------------------------------------------------------------------------------| | DIL | Name | | Access | Description | | | | is done to the TX for the TX for the TX FIFO while a | | full. The data already in the TX FIFO is preserved. Also set if DMA nmand is running. | | 5 | RXUF | 0x0 | RW | RX FIFO Underflow Interrupt Flag | | | Set when trying | to read from the RX | (FIFO when it is | s empty. | | 4 | RXOF | 0x0 | RW | RX FIFO Overflow Interrupt Flag | | | Set when data is new data. | complettly received | d in the receive | shift register but the RX FIFO is full. RX FIFO is not overwirtten by | | 3 | RXFULL | 0x0 | RW | RX FIFO Full Interrupt Flag | | | Set when the RX | (FIFO becomes ful | l. | | | 2 | RXFL | 0x0 | RW | RX FIFO Level Interrupt Flag | | | Set when data b | ecomes available ir | the RX FIFO. | This field depends on the RXFIW field in the CFG1 register. | | 1 | TXFL | 0x0 | RW | TX FIFO Level Interrupt Flag | | | Set when space | becomes available | in the TX FIFO | . This depends on the TXFIW field in the CFG1 register. | | 0 | TXC | 0x0 | RW | TX Complete Interrupt Flag | | | This interrupt is | set after a transmis | sion when both | the TX FIFO and shift register are empty. | # 22.5.19 EUSART\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----------|----|----|--------------|----|----|----|----|--------|--------|----|------|------|----|--------|-----|---|------|------|---------|---|--------|------|--------|--------|------|---------|---------| | 0x048 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | <u>'</u> | | | 000 | | | • | | 000 | 0x0 | | | • | ' | 0x0 | 0X0 | | 000 | 0x0 | 0×0 | | 0X0 | 000 | 000 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | ₩<br>M | | | | | ₩<br>W | W. | | | | | R<br>M | Z. | | W. | RW | ZW<br>W | | ₩<br>M | W. | R<br>W | W<br>M | R | ZW<br>W | ZW<br>W | | Name | | | | | | | | AUTOBAUDDONE | | | | | SIGF | STARTF | | | | | TXIDLE | CCF | | MPAF | FERR | PERR | | TXOF | RXUF | RXOF | RXFULL | RXFL | TXFL | TXC | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|-----------------|--------------------------------------------------------------------------| | 31:25 | Reserved | To ensure o | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 24 | AUTOBAUDDONE | 0x0 | RW | Auto Baud Complete IEN | | | Interrupt enable for Al | JTOBAUDDONI | EIF. | | | 23:20 | Reserved | To ensure o | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 19 | SIGF | 0x0 | RW | Signal Frame IEN | | | Interrupt enable for SI | GFIF. | | | | 18 | STARTF | 0x0 | RW | Start Frame IEN | | | Interrupt enable for ST | TARTFIF. | | | | 17:14 | Reserved | To ensure o | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 13 | TXIDLE | 0x0 | RW | TX IDLE IEN | | | Interrupt enable for TX | KIDLEIF. | | | | 12 | CCF | 0x0 | RW | Collision Check Fail IEN | | | Interrupt enable for Co | CFIF. | | | | 11 | Reserved | To ensure o | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 10 | MPAF | 0x0 | RW | Multi-Processor Addr Frame IEN | | | Interrupt enable for Mi | PAFIF. | | | | 9 | FERR | 0x0 | RW | Framing Error IEN | | | Interrupt enable for FE | ERRIF. | | | | 8 | PERR | 0x0 | RW | Parity Error IEN | | | Interrupt enable for PE | ERRIF. | | | | 7 | Reserved | To ensure o | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 6 | TXOF | 0x0 | RW | TX FIFO Overflow IEN | | | Interrupt enable for TX | (OFIF. | | | | Bit | Name | Reset | Access | Description | | | | | | |-----|-----------------------------|--------------------------------|--------|-----------------------|--|--|--|--|--| | 5 | RXUF | 0x0 | RW | RX FIFO Underflow IEN | | | | | | | | Interrupt enable for | or RXUFIF. | | | | | | | | | 4 | RXOF | 0x0 | RW | RX FIFO Overflow IEN | | | | | | | | Interrupt enable for | or RXOFIF. | | | | | | | | | 3 | RXFULL | 0x0 | RW | RX FIFO Full IEN | | | | | | | | Interrupt enable for | Interrupt enable for RXFULLIF. | | | | | | | | | 2 | RXFL | 0x0 | RW | RX FIFO Level IEN | | | | | | | | Interrupt enable for | or RXFLIF. | | | | | | | | | 1 | TXFL | 0x0 | RW | TX FIFO Level IEN | | | | | | | | Interrupt enable for | or TXFLIF. | | | | | | | | | 0 | TXC | 0x0 | RW | TX Complete IEN | | | | | | | | Interrupt enable for TXCIF. | | | | | | | | | # 22.5.20 EUSART\_SYNCBUSY - Synchronization Busy Register | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----------|----------|------------|-----------|-------|------|----------|------|-------|-------|-----| | 0x04C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | • | | | | | | • | • | | | | | • | | | 000 | 0x0 | 000 | 000 | 0x0 | 0X0 | 0X0 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | 22 | <u>~</u> | œ | 22 | 22 | 22 | <u>~</u> | œ | 22 | œ | œ | | Name | | | | | | | | | | | | | | | | | | | | | | TXTRIDIS | TXTRIEN | RXBLOCKDIS | RXBLOCKEN | TXDIS | TXEN | RXDIS | RXEN | TXTEN | RXTEN | DIV | | Bit | Name | Reset | Access | Description | | | | | | | |-------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--| | 31:11 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 10 | TXTRIDIS | 0x0 | R | SYNCBUSY in TXTRIDIS in CMD | | | | | | | | | 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. | | | | | | | | | | | 9 | TXTRIEN | 0x0 | R | SYNCBUSY for TXTRIEN in CMD | | | | | | | | | 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 | SYNCBUSY for RXBLOCKDIS in CMD | | | | | | | | | 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 | SYNCBUSY for RXBLOCKEN in CMD | | | | | | | | | 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 | SYNCBUSY for TXDIS in CMD | | | | | | | | | 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 | SYNCBUSY for TXEN in CMD | | | | | | | | | This bit is set when the this bit is set. | re is an ongoin | g synchronizatio | on of TXEN field. Do not do another write to the same field while | | | | | | | | 4 | RXDIS | 0x0 | R | SYNCBUSY for RXDIS in CMD | | | | | | | | | This bit is set when the this bit is set. | re is an ongoin | g synchronizatio | on of RXDIS field. Do not do another write to the same field while | | | | | | | | 3 | RXEN | 0x0 | R | SYNCBUSY for RXEN in CMD | | | | | | | | | This bit is set when the this bit is set. | re is an ongoin | g synchronizatio | on of RXEN field. Do not do another write to the same field while | | | | | | | | 2 | TXTEN | 0x0 | R | SYNCBUSY for TXTEN in TRIGCTRL | | | | | | | | | This bit is set when the this bit is set. | re is an ongoin | g synchronizatio | on of TXTEN field. Do not do another write to the same field while | | | | | | | | 1 | RXTEN | 0x0 | R | SYNCBUSY for RXTEN in TRIGCTRL | | | | | | | | | This bit is set when the this bit is set. | re is an ongoin | g synchronizatio | on of RXTEN field. Do not do another write to the same field while | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | |-----|---------------------------------------------------------------------------------------------------------------------------------------|-------|--------|----------------------------|--|--|--|--|--| | 0 | DIV | 0x0 | R | SYNCBUSY for DIV in CLKDIV | | | | | | | | This bit is set when there is an ongoing synchronization of DIV field. Do not do another write to the same field while th bit is set. | | | | | | | | | ## 23. 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^2C$ interface allows $I^2C$ 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^2C$ -bus with sub- $\mu$ A current consumption. #### 23.1 Introduction The $I^2C$ module provides an interface between the MCU and a serial $I^2C$ -bus. It is capable of acting as both a master and a slave and supports multi-master 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. Slave arbitration and timeouts are also provided to allow implementation of an SMBus compliant system. The interface provided to software by the $I^2C$ module allows precise control of the transmission process and highly automated transfers. Automatic recognition of slave addresses is provided in all energy modes (except EM4). ### 23.2 Features - · True multi-master 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 master and slave (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 - · Clock high timeout - · Arbitration lost - · Bus error detection - · Separate receive/ transmit 2-level buffers, with additional separate shift registers - Full DMA support ## 23.3 Functional Description An overview of the I2C module is shown in Figure 23.1 I2C Overview on page 676. Figure 23.1. I2C Overview #### 23.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 23.2 I2C-Bus Example on page 677. As a true multi-master bus it includes collision detection and arbitration to resolve situations where multiple masters transmit data at the same time without data loss. Figure 23.2. I2C-Bus Example Each device on the bus is addressable by a unique address, and an I<sup>2</sup>C master can address all the devices on the bus, including other masters. 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 **tr** for the given bus speed, and the estimated bus capacitance **Cb** as shown in Figure 23.3 I2C Pull-up Resistor Equation on page 677. $$R_{p(max)} = t_r/(0.8473 \times C_b).$$ Figure 23.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 µ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. ### 23.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 23.4 I2C START and STOP Conditions on page 678, 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 23.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 23.5 I2C Bit Transfer on I<sup>2</sup>C-Bus on page 678. Figure 23.5. I2C Bit Transfer on I<sup>2</sup>C-Bus #### 23.3.1.2 Bus Transfer When a master wants to initiate a transfer on the bus, it waits until the bus is idle and transmits a START condition on the bus. The master then transmits the address of the slave it wishes to interact with and a single R/W bit telling whether it wishes to read from the slave (R/W bit set to 1) or write to the slave (R/W bit set to 0). After the 7-bit address and the R/W bit, the master releases the bus, allowing the slave to acknowledge the request. During the next bit-period, the slave 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 slave or master 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 master ends the transmission after a (N)ACK by sending a STOP condition on the bus. After a STOP condition, any master wishing to initiate a transfer on the bus can try to gain control of it. If the current master 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 23.6 I2C Single Byte Write to Slave on page 679, Figure 23.7 I2C Double Byte Read from Slave on page 679, and Figure 23.8 I2C Single Byte Write, then Repeated Start and Single Byte Read on page 679. 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 23.6. I2C Single Byte Write to Slave Figure 23.7. I2C Double Byte Read from Slave Figure 23.8. I2C Single Byte Write, then Repeated Start and Single Byte Read #### 23.3.1.3 Addresses $I^2C$ 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 slave that the master wants to contact. In the 7-bit address space, several addresses are reserved. These addresses are summarized in Table 23.1 I2C Reserved $I^2C$ Addresses on page 680, and include a General Call address which can be used to broadcast a message to all slaves on the $I^2C$ -bus. Table 23.1. I2C 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 slave addressing mode | #### 23.3.1.4 10-bit Addressing To address a slave 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 master wishes to read from or write to the slave. The second byte contains the eight least significant bits of the slave address. When a slave receives a 10-bit address, it must acknowledge both the address bytes if they match the address of the slave. When performing a master transmitter operation, the master transmits the two address bytes and then the remaining data, as shown in Figure 23.9 I2C Master Transmitter/Slave Receiver with 10-bit Address on page 680. Figure 23.9. I2C Master Transmitter/Slave Receiver with 10-bit Address When performing a master receiver operation however, the master first transmits the two address bytes in a master transmitter operation, then sends a repeated START followed by the first address byte and then receives data from the addressed slave. The slave 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 23.10 I2C Master Receiver/Slave Transmitter with 10-bit Address on page 680. Figure 23.10. I2C Master Receiver/Slave Transmitter with 10-bit Address ### 23.3.1.5 Arbitration, Clock Synchronization, Clock Stretching Arbitration and clock synchronization are features aimed at allowing multi-master 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 masters driving the bus at once, and is a requirement for effective arbitration. Slaves 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 masters and slaves. Clock synchronization and clock stretching is also supported. #### 23.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^2C$ module and terminate any ongoing transfers, set the CORERST bit in $I2C\_CTRL$ . After resetting, the CORERST bit must be cleared to resume $I^2C$ 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. ### 23.3.3 Pin Configuration The I<sup>2</sup>C SDA and SCL pins are configured and enableed in the GPIO\_DBUSI2Cn\_ROUTEEN, GPIO\_DBUSI2Cn\_SCLROUTE, and GPIO\_DBUSI2Cn\_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. ### 23.3.4 Safely Disabling and Changing Slave Configuration The I<sup>2</sup>C slave is partially asynchronous, and some precautions are necessary to always ensure a safe slave disable or slave configuration change. These measures should be taken, if (while the slave is enabled) the user cannot guarantee that an address match will not occur at the exact time of slave disable or slave configuration change. Worst case consequences for an address match while disabling slave or changing configuration is that the slave may end up in an undefined state. To reset the slave back to a known state, the EN bit in I2C\_EN must be cleared. This should be done regardless of whether the slave is going to be re-enabled or not. #### 23.3.5 Clock Generation The $I^2C$ peripheral clock (I2CCLK) for I2C0 is derived from the LSPCLK (max freq = 25 MHz), and for I2C1 is derived from the PCLK (max freq = 50 MHz). The SCL signal generated by the I<sup>2</sup>C master 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_{12CCLK}/(((N_{low} + N_{high}) \times (DIV + 1)) + 8),$$ Figure 23.11. I2C Maximum Transmission Rate Where DIV is the clock divider value set in I2C\_CLKDIV, and 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. The values of $N_{low}$ and $N_{high}$ , in combination with the synchronization cycles (discussed below), 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: $$T_{high} >= ((N_{high}) \times (DIV + 1) + 4)/f_{I2CCLK},$$ $T_{low} >= (N_{low} \times (DIV + 1) + 4)/f_{I2CCLK}.$ Figure 23.12. I2C High and Low Cycles Equations In worst case, $T_{high}$ and $T_{low}$ can be 1 $f_{l2CCLK}$ cycle longer than the number found by above equations due to synchronization uncertainty (i.e., if the synchronization takes 3 $f_{l2CCLK}$ cycles instead of 2). Similarly, in the worst case the number 8 in the denominator in $f_{SCL}$ equation can be 9 (if the synchronization cycles were 3 instead of 2 in $T_{high}$ or $T_{low}$ ) or 10 (if synchronization cycles were 3 in both $T_{high}$ and $T_{low}$ ). Note: DIV must be set to 1 during slave mode operation. #### 23.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^2C$ device goes idle. If an $I^2C$ master loses arbitration during the transmission of an address, another master may be trying to address it. The master therefore receives the rest of the address, and if the address matches the slave address of the master, the master goes into either slave transmitter or slave receiver mode. #### Note: Arbitration can be lost both when operating as a master and when operating as a slave. ### 23.3.7 Buffers ### 23.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 23.1 I2C Overview on page 676. 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 23.13 I2C Transmit Buffer Operation on page 683 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\_STATUS 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 23.13. 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. ### 23.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 23.14 I2C Receive Buffer Operation on page 684. 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 23.14. 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. ## 23.3.8 Master 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 master issuing the START condition. The bus is considered free when a STOP condition is transmitted on the bus. After a STOP is detected, all masters 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 master must transmit a slave address (ADDR) with an R/W bit on the bus. If this address is available in the transmit buffer, the master transmits it immediately, but if the buffer is empty, the master 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 slave, depending on the value of the R/W bit (bit 0 in the address byte). If the bit was cleared, the master has entered a master transmitter role, where it now transmits data to the slave. If the bit was set, it has entered a master receiver role, where it now should receive data from the slave. In either case, an unlimited number of bytes can be transferred in one direction during the transmission. At the end of the transmission, the master 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 master mode, I2CCLK frequency must be higher than 2 MHz for Standard-mode, 9 MHz for Fast-mode, and 20 MHz for Fast-mode Plus. ### 23.3.8.1 Master State Machine The master state machine is shown in Figure 23.15 I2C Master State Machine on page 686. A master 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 23.15. I2C Master State Machine #### 23.3.8.2 Interactions Whenever the $I^2C$ 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 the of the $I^2C$ module. This state can be read from the $I2C_IF$ is set. As an example, Table 23.3 I2C Master Transmitter on page 689 shows the different states the I<sup>2</sup>C goes through when operating as a Master Transmitter, i.e., a master that transmits data to a slave. 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^2C$ module are listed in Table 23.2 I2C Interactions in Prioritized Order on page 687 in a prioritized order. If the $I^2C$ 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^2C$ will send out the STOP since it has the higher priority. Table 23.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 buf-<br>fer | | 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 23.2 I2C Interactions in Prioritized Order on page 687 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 23.2 I2C Interactions in Prioritized Order on page 687 is applied to the bus. Pending commands can be cleared by setting the CLEARPC command bit in I2C\_CMD. ## 23.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. ### 23.3.8.4 Reset State After a reset, the state of the $I^2C$ -bus is unknown. To avoid interrupting transfers on the $I^2C$ -bus after a reset of the $I^2C$ module or the entire MCU, the $I^2C$ -bus is assumed to be busy when coming out of a reset, and the BUSY flag in $I^2C$ -STATUS is thus set. To be able to carry through master operations on the $I^2C$ -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^2C$ module detects that the bus is idle can be significant. There are two ways of assuring that the $I^2C$ 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 master 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 master operations can be initiated. **Note:** If operating in slave mode, the above approach is not necessary. #### 23.3.8.5 Master Transmitter To transmit data to a slave, the master must operate as a master transmitter. Table 23.3 I2C Master Transmitter on page 689 shows the states the I<sup>2</sup>C module goes through while acting as a master 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 master operation is started by issuing a START command by setting START in I2C\_CMD. ADDR+W, i.e., the address of the slave + 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 slave in the 7 most significant bits and the least significant bit cleared (ADDR+W). This address will then be transmitted, and the slave will reply with an ACK or a NACK. If no slave replies to the address, the response will also be NACK. If the address was acknowledged, the master now has four choices. It can send data by placing it in I2C\_TXDATA/ I2C\_TXDOUBLE (the master should check the TXBL interrupt flag before writing to the transmit buffer), this data is then transmitted. The master 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 master 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 master wishing to initiate a transfer on the bus can try to gain control of it. If a NACK was received, the master 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 master has the same options as for when the address was sent. The master 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 master then checks which address was transmitted. If it was the address of the master, then the master goes to slave mode. After a master 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 master gains the bus next. The MSTOP interrupt flag in I2C\_IF is set when a STOP condition is transmitted by the master. Table 23.3. I2C Master Transmitter | I2C_STATE | Description | I2C_IF | Required in-<br>teraction | Response | |-----------|---------------------------------|-----------------------------------------------------|---------------------------|--------------------------------------------------------------------------------------| | 0x67 | Start transmitted | START interrupt flag<br>(BUSHOLD interrupt | ADDR+W -><br>TXDATA | ADDR+W will be sent | | | | flag) | STOP | STOP will be sent and bus released. | | | | | STOP +<br>START | STOP will be sent and bus released. Then a START will be sent when bus becomes idle. | | 0x67 | Repeated start trans-<br>mitted | START interrupt flag<br>(BUSHOLD interrupt<br>flag) | ADDR+W -><br>TXDATA | ADDR+W will be sent | | | | | STOP | STOP will be sent and bus released. | | | | | STOP +<br>START | STOP will be sent and bus released. Then a START will be sent when bus becomes idle. | | - | ADDR+W transmitted | TXBL interrupt flag<br>(TXC interrupt flag) | None | | | I2C_STATE | Description | I2C_IF | Required in-<br>teraction | Response | |-----------|---------------------------------------|---------------------------------------------------|---------------------------|---------------------------------------------------------------------------------------------| | | ADDR+W transmitted, | ACK interrupt flag | TXDATA | DATA will be sent | | | ACK received | (BUSHOLD interrupt flag) | STOP | STOP will be sent. Bus will be released | | | | | START | Repeated start condition will be sent | | | | | STOP +<br>START | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle | | 0x9F | ADDR+W transmit-<br>ted,NACK received | NACK (BUSHOLD interrupt flag) | CONT +<br>TXDATA | DATA will be sent | | | | | STOP | STOP will be sent. Bus will be released | | | | | START | Repeated start condition will be sent | | | | | STOP +<br>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<br>(BUSHOLD interrupt<br>flag) | TXDATA | DATA will be sent | | | | | STOP | STOP will be sent. Bus will be released | | | | | START | Repeated start condition will be sent | | | | | STOP +<br>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 inter-<br>rupt flag) | CONT +<br>TXDATA | DATA will be sent | | | | | STOP | STOP will be sent. Bus will be released | | | | | START | Repeated start condition will be sent | | | | | STOP +<br>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 | | | | | | START | START will be sent when bus becomes idle | | - | Arbitration lost | ARBLOST interrupt flag | None | | | | | | START | START will be sent when bus becomes idle | #### 23.3.8.6 Master Receiver To receive data from a slave, the master must operate as a master receiver, see Table 23.4 I2C Master Receiver on page 691. This is done by transmitting ADDR+R as the address byte instead of ADDR+W, which is transmitted to become a master transmitter. The address byte loaded into the data register thus has to contain the 7-bit slave address in the 7 most significant bits of the byte, and have the least significant bit set. When the address has been transmitted, the master 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 slave 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 slave. 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 master 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 master transmitter, arbitration can be lost as a master receiver. When this happens the ARBLOST interrupt flag in I2C\_IF is set, and the master has a possibility of being selected as a slave given the correct conditions. Table 23.4. I2C Master Receiver | I2C_STATE | Description | I2C_IF | Required in-<br>teraction | Response | |-----------|---------------------------------------|--------------------------------------------|---------------------------|---------------------------------------------------------------------------------------------| | 0x63 | START transmitted | START interrupt flag<br>(BUSHOLD interrupt | ADDR+R -><br>TXDATA | ADDR+R will be sent | | | | flag) | STOP | STOP will be sent and bus released. | | | | | STOP +<br>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 inter- | ADDR+R -><br>TXDATA | ADDR+R will be sent | | | | rupt flag) | STOP | STOP will be sent and bus released. | | | | | STOP +<br>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 interrupt flag(BUS- | RXDATA | Start receiving | | | ACK received | HOLD) | STOP | STOP will be sent and the bus released | | | | | START | Repeated START will be sent | | | | | STOP +<br>START | STOP will be sent and the bus released. Then a START will be sent when the bus becomes idle | | 0x9B | ADDR+R transmit-<br>ted,NACK received | NACK(BUSHOLD) | CONT +<br>RXDATA | Continue, start receiving | | | | | STOP | STOP will be sent and the bus released | | | | | START | Repeated START will be sent | | | | | STOP +<br>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 in-<br>teraction | Response | |-----------|------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------| | 0xB3 | Data received | RXDATA interrupt flag(BUSHOLD inter- | ACK + RXDA-<br>TA | ACK will be transmitted, reception continues | | | | NACK +<br>CONT +<br>RXDATA | NACK will be transmitted, reception continues | | | | | | [1.151.11.11.11.11.11.11.11.11.11.11.11.1 | ACK/NACK will be sent and the bus will be released. | | | | | ACK/NACK +<br>START | ACK/NACK will be sent, and then a repeated start condition. | | | | ACK/NACK +<br>STOP +<br>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 | | | | | | START | START will be sent when bus becomes idle | | - | Arbitration lost | ARBLOST interrupt flag | None | | | | | START | START will be sent when bus becomes idle | | ## 23.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 I2C module is in single master mode, and when the slave doesn't use clock stretching. Additionally, firmware should set the ARBDIS bit in I2C\_CTRL when using the SDA/SCL monitoring to prevent the bus being released. The SDA monitor is enabled by setting the SDAMONEN in I2C\_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 I2C\_IF it fails to read SDA==1. To allow the SDAERR flag to generate an IRQ, set the SDAERR bit in I2C\_IEN. Similarly, the SCL monitor is enabled by setting the SCLMONEN in I2C\_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 I2C\_IF it fails to read SCL==1. To allow the SCLERR flag to generate an IRQ, set the SCLERR bit in I2C\_IEN. #### 23.3.9 Bus States The I2C\_STATE register can be used to determine which state the $I^2C$ module and the $I^2C$ bus are in at a given time. The register consists of the STATE bit-field, which shows which state the $I^2C$ 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^2C$ module waiting for a software response. The possible values of the STATE field are summarized in Table 23.5 I2C STATE Values on page 693. When this field is cleared, the $I^2C$ module is not a part of any ongoing transmission. The remaining status bits in the I2C\_STATE register are listed in Table 23.6 I2C Transmission Status on page 693. Table 23.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 23.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 master. Cleared at all other times. | | TRANSMITTER | Set when operating as a transmitter; either a master transmitter or a slave 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^2$ 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. ## 23.3.10 Slave Operation The $I^2C$ module operates in master mode by default. To enable slave operation, i.e., to allow the device to be addressed as an $I^2C$ slave, the SLAVE bit in $I^2C$ must be set. In this case the $I^2C$ module operates in a mixed mode, both capable of starting transmissions as a master, and being addressed as a slave. When operating in the slave mode, $I^2CCLK$ frequency must be higher than 2 MHz for Standard-mode, 5 MHz for Fast-mode, and 14 MHz for Fast-mode Plus. ### 23.3.10.1 Slave State Machine The slave state machine is shown in Figure 23.16 I2C Slave State Machine on page 694. 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 23.16. I2C Slave State Machine ## 23.3.10.2 Address Recognition The $I^2C$ 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 23.3.12 Using 10-bit Addresses. Address recognition is supported in EM2/3 for $I^2CO$ - however, the $I^2CO$ 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 slave 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 slave 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 slave 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. #### 23.3.10.3 Slave 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 master 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 slave 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 slave, and the slave 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 master wishes to read from the slave, the slave now goes into the slave transmitter mode. Software interaction is now required to decide whether the slave 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 slave responds with a command. The slave can reject the request with a single NACK command. The slave will in that case go to an idle state, and wait for the next start condition. To continue the transmission, the slave must make sure data is loaded into the transmit buffer and send an ACK. The loaded data will then be transmitted to the master, and an ACK or NACK will be received from the master. 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 master 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 master has received enough bytes and wishes to end the transmission. The slave 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 master ends the transmission by sending a STOP or a repeated START. The SSTOP interrupt flag in I2C\_IF is set when the master 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 slave 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 slave goes idle. See Table 23.7 I2C Slave Transmitter on page 695 for more information. Table 23.7. I2C Slave Transmitter | I2C_STATE | Description | I2C_IF | Required in-<br>teraction | Response | |-----------|--------------------------------|------------------------------------------------------|----------------------------|------------------------------------| | 0x01 | Repeated START received | RSTART interrupt flag<br>(BUSHOLD interrupt<br>flag) | RXDATA | Receive and compare address | | 0x75 | ADDR + R received | ADDR interrupt flag | ACK + TXDA-<br>TA | ACK will be sent, then DATA | | | | RXDATA interrupt flag | NACK | NACK will be sent, slave goes idle | | | | (BUSHOLD interrupt flag) | NACK +<br>CONT +<br>TXDATA | NACK will be sent, then DATA. | | - | Data transmitted | TXBL interrupt flag (TXC interrupt flag) | None | | | 0xD5 | Data transmitted, ACK received | ACK interrupt flag<br>(BUSHOLD interrupt<br>flag) | TXDATA | DATA will be transmitted | | 0xDD | Data transmitted, NACK | NACK interrupt flag | None | The slave goes idle | | received | (BUSHOLD interrupt flag) | CONT +<br>TXDATA | DATA will be transmitted | | | I2C_STATE | Description | I2C_IF | Required in-<br>teraction | Response | |-----------|------------------|------------------------|---------------------------|----------------------------------------------| | - | Stop received | SSTOP interrupt flag | None | The slave goes idle | | | | | START | START will be sent when bus becomes idle | | - | Arbitration lost | ARBLOST interrupt flag | None | The slave goes idle | | | | | START | START will be sent when the bus becomes idle | #### 23.3.10.4 Slave Receiver A slave receiver operation is started in the same way as a slave transmitter operation, with the exception that the address transmitted by the master has the R/W bit cleared (W), indicating that the master wishes to write to the slave. The slave then goes into slave receiver mode. To receive data from the master, the slave should respond to the address with an ACK and make sure space is available in the receive buffer. Transmission will then continue, and the slave will receive a byte from the master. If a NACK is sent without a CONT, the transmission is ended for the slave, and it goes idle. If the slave issues both the NACK and CONT commands and has space available in the receive buffer, it will be open for continuing reception from the master. When a byte has been received from the master, the slave must ACK or NACK the byte. The responses here are the same as for the reception of the address byte. The master ends the transmission by sending a STOP or a repeated START. The SSTOP interrupt flag is set when the master 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 slave 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 slave goes idle. See Table 23.8 I2C - Slave Receiver on page 697 for more information. Table 23.8. I2C - Slave Receiver | I2C_STATE | Description | I2C_IF | Required in-<br>teraction | Response | |-----------|-------------------------|------------------------------------------------------|----------------------------|----------------------------------------------| | 0x01 | Repeated START received | RSTART interrupt flag<br>(BUSHOLD interrupt<br>flag) | RXDATA | Receive and compare address | | 0x71 | ADDR + W received | ADDR interrupt flag<br>RXDATA interrupt flag | ACK +<br>RXDATA | ACK will be sent and data will be received | | | | (BUSHOLD interrupt flag) | NACK | NACK will be sent, slave goes idle | | | | | NACK +<br>CONT +<br>RXDATA | NACK will be sent and DATA will be received. | | 0xB1 | Data received | RXDATA interrupt flag<br>(BUSHOLD interrupt<br>flag) | ACK +<br>RXDATA | ACK will be sent and data will be received | | | | | NACK | NACK will be sent and slave will go idle | | | | | NACK +<br>CONT +<br>RXDATA | NACK will be sent and data will be received | | - | Stop received | SSTOP interrupt flag | None | The slave goes idle | | | | | START | START will be sent when bus becomes idle | | - Art | Arbitration lost | ARBLOST interrupt flag | None | The slave goes idle | | | | | START | START will be sent when the bus becomes idle | ### 23.3.11 Transfer Automation The I<sup>2</sup>C can be set up to complete transfers with a minimal amount of interaction. #### 23.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. ### 23.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. #### 23.3.11.3 Automatic STOP A STOP can be generated automatically on two conditions. These apply only to the master 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 master 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 slave. 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. ## 23.3.12 Using 10-bit Addresses When using 10-bit addresses in slave 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 slave 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 slave, the slave should ACK the byte to continue the transmission, and if it does not match, the slave should NACK it. When the master is operating as a master transmitter, the data bytes will follow after the second address byte. When the master is operating as a master 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 slave that found a match on the entire 10-bit address in the previous message should ACK this address. The repeated start should take the master into a master receiver mode, and after the single address byte sent this time around, the slave begins transmission to the master. ### 23.3.13 Error Handling **Note:** Some registers in the $I^2C$ module are considered static. This means that these need to be set before an $I^2C$ 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 DBUSI2Cn ROUTEEN, GPIO DBUSI2Cn SCLROUTE, and GPIO DBUSI2Cn SDAROUTE registers ### 23.3.13.1 ABORT Command Some bus errors may require software intervention to be resolved. The $I^2C$ 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^2C$ module is in the middle of a transmission it cannot get out of, or for some other reason the $I^2C$ 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. #### 23.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. #### 23.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 23.9 I2C Bus Error Response on page 699. Table 23.9. I2C Bus Error Response | | Misplaced START | Misplaced STOP | |-----------------------------|------------------------------------|---------------------------------------| | In a master/slave operation | Treated as START. Receive address. | Go idle. Perform any pending actions. | ### 23.3.13.4 Bus Lockup A lockup occurs when a master or slave on the $I^2$ 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 slave-only devices operating on an $I^2C$ -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 slaves 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 master should send 9 clock pulses on SCL while tristating the SDA. This procedure is performed in the GPIO module after clearing the GPIO\_DBUSI2Cn\_ROUTEEN register and disabling the I2C 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 slaves. 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 23.3.13.6 Clock Low Timeout ### 23.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 23.3.8.4 Reset State. ## 23.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. #### 23.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 master or a misbehaving slave) 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 I<sup>2</sup>C device goes to idle. ### 23.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\_TXDOUBLE register. In order to write to the I2C\_TXDOUBLE register (i.e., transferring 2 bytes simultaneously to the transmit buffer using the DMA), DMA\_USEBURSTS needs to be set to 1 for the selected DMA channel. This ensures that the transfer is made to the transmit buffer only when both buffer elements are empty. For performing a DMA write to the I2C\_TXDATA register, DMA\_USEBURSTC needs to be set to 1 for the selected DMA channel. This ensures that a DMA transfer is made even when the transmit buffer is half-empty. 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). To receive from I2C\_RXDOUBLE (i.e., receive only when both buffer elements are full), DMA\_USEBURSTS needs to be set to 1 for the selected DMA channel. In order to receive from I2C\_RXDATA through the DMA, DMA\_USEBURSTC needs to be set to 1. This ensures that the data gets picked up even when the receive buffer is half-full. ## 23.3.15 Interrupts The interrupts generated by the $I^2C$ module are combined into one interrupt vector, $I2C_INT$ . If $I^2C$ 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_IF$ are set. ## 23.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. ## 23.4 I2C Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | 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 | Slave Address Register | | 0x020 | I2C_SADDRMASK | RW | Slave 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 | Slave Address Register | | 0x1020 | I2C_SADDRMASK_SET | RW | Slave 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 | Туре | 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 | Slave Address Register | | 0x2020 | I2C_SADDRMASK_CLR | RW | Slave 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 | Slave Address Register | | 0x3020 | I2C_SADDRMASK_TGL | RW | Slave 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 | ## 23.5 I2C Register Description # 23.5.1 I2C\_IPVERSION - IP VERSION Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | <u> </u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | <u>α</u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | INCIOGE/Val | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP version ID | | | The read only IPVERSION | • | | this module. There may be minor software changes required for | ## 23.5.2 I2C\_EN - Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | • | | | | | | | | | | | | | | | | | | • | | | | • | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | | Bit | Name | Reset | Access | Description | |------|----------|----------------------|--------|--------------------------------------------------------------------------------------------------| | 31:1 | Reserved | To ensui<br>ventions | | with future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | module enable | | | | | | ould write to CONFIG type registers before setting the ENABLE bit. after setting the ENABLE bit. | | | Value | Mode | | Description | | | | | | · | | | 0 | DISABLI | Ξ | Disable Peripheral Clock | ## 23.5.3 I2C\_CTRL - Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----------|----------|----|----|------|------|--------|----|----|----------|---|----|---|----------|-------|--------|--------|--------|--------|---------|--------|---------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | ' | | | | 0x0 | 0×0 | | | 000 | | 0×0 | | Š | S<br>S | | ' | Š | Š | 0X0 | 0X0 | 000 | 0x0 | 0×0 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | M | RW | | | ₽ | | W. | | 2 | <u>}</u> | | | Š | <u>}</u> | S. | Z. | R<br>W | RW | R. | RW | ₩<br>M | RW | | Name | | | | | | | | | | | SDAMONEN | SCLMONEN | | | CLTO | | GIBITO | | C | OII | | | 9 | א<br>ביי | TXBIL | GCAMEN | ARBDIS | AUTOSN | AUTOSE | AUTOACK | SLAVE | CORERST | | Bit | Name | Reset | Access | Description | |-------|--------------------------------------------|---------------------|--------------------|------------------------------------------------------------------------| | 31:22 | Reserved | To ensure o | compatibility wit | n future devices, always write bits to 0. More information in 1.2 Con- | | 21 | SDAMONEN | 0x0 | RW | SDA Monitor Enable | | | Set to enable SDA<br>MultiMaster applica | | nis will enable S | DA rise check at loopback path. This monitor can not be enabled in | | | Value | Mode | | Description | | | 0 | DISABLE | | Disable SDA Monitor | | | 1 | ENABLE | | Enable SDA Monitor | | 20 | SCLMONEN | 0x0 | RW | SCL Monitor Enable | | | Set to enable SCL i<br>MultiMaster applica | | nis will enable S | CL rise check at loopback path. This monitor can not be enabled in | | | Value | Mode | | Description | | | 0 | DISABLE | | Disable SCL monitor | | | 1 | ENABLE | | Enable SCL monitor | | | | | | a futura daviana alwaya uwita hita ta 0. Mara information in 1.2 Can | | 19 | Reserved | To ensure oventions | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | 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 | I2C1024P | CC | Timeout after 1024 prescaled clock cycles. In standard mode at 100 kHz, this results in a 1280us timeout. | | 15 | GIBITO | 0x0 | RW | Go Idle on Bus Idle Timeout | | | When set, the bus | automatically goe | s 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 | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 13:12 | ВІТО | 0x0 | RW | Bus Idle Timeout | | | the value defined l<br>SCL remains high<br>GIBITO is set. It is | by BITO, it sets the The bus idle time also stopped a ST or the bus goes BU | e BITO interrup<br>out is active as<br>FOP condition<br>ISY, i.e. a STA | t, a timer is started whenever SCL goes high. When the timer reaches of flag. The BITO interrupt flag will then be set periodically as long as slong as BUSY is set. It is thus stopped automatically on a timeout if is detected and when the ABORT command is issued. The timeout is IRT condition is detected. The timeout value can be calculated by | | | Value | Mode | | Description | | | 0 | OFF | | Timeout disabled | | | 1 | 12C40PC0 | | Timeout after 40 prescaled clock cycles. In standard mode at 100 kHz, this results in a 50us timeout. | | | 2 | 12C80PC0 | : | Timeout after 80 prescaled clock cycles. In standard mode at 100 kHz, this results in a 100us timeout. | | | 3 | I2C160PC | C | Timeout after 160 prescaled clock cycles. In standard mode at 100 kHz, this results in a 200us timeout. | | 11:10 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | CLHR | 0x0 | RW | Clock Low High Ratio | | | Determines the va | lues of (and ratio b | petween) the lo | ow and high parts of the clock signal generated on SCL as master. | | | Value | Mode | | Description | | | 0 | STANDAF | RD | Nlow=4 and Nhigh=4, and the Nlow:Nhigh ratio is 4:4 | | | 1 | ASYMME | TRIC | 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 | TX Buffer Interrupt Level | | | Determines the int | errupt and status I | evel of the trar | nsmit 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_FUL | L | 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 | General Call Address Match Enable | | | Set to enable address n | natch on gene | eral call in addition | on to the programmed slave address. | | | Value | Mode | | Description | | | 0 | DISABLE | | General call address will be NACK'ed if it is not included by the slave address and address mask. | | | 1 | ENABLE | | When a general call address is received, a software response is required | | 5 | ARBDIS | 0x0 | RW | Arbitration Disable | | | A master or slave will no | ot 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 | Automatic STOP on NACK | | | Write to 1 to make a ma | ster transmitte | er send a STOP | when a NACK is received from a slave. | | | Value | Mode | | Description | | | 0 | DISABLE | | Stop is not automatically sent if a NACK is received from a slave. | | | 1 | ENABLE | | The master automatically sends a STOP if a NACK is received from a slave. | | 3 | AUTOSE | 0x0 | RW | Automatic STOP when Empty | | | Write to 1 to make a ma | ster transmitte | er 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 master automatically sends a STOP when no more data is available for transmission. | | 2 | AUTOACK | 0x0 | RW | Automatic Acknowledge | | | Set to enable automatic | acknowledge | S. | | | | 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 | Addressable as Slave | | Bit | Name | Reset | Access | Description | |-----|-----------------------------------------|--------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Set this bit to allow | w the device to be | selected as an | I2C slave. | | | Value | Mode | | Description | | | 0 | DISABLE | | All addresses will be responded to with a NACK | | | 1 | ENABLE | | Addresses matching the programmed slave address or the general call address (if enabled) require a response from software. Other addresses are automatically responded to with a NACK. | | 0 | CORERST | 0x0 | RW | Soft Reset the internal state registers | | | Set to reset the I2 operation condition | | , and return the | e I2C module to the IDLE state. Must clear this bit to resume normal | | | Value | Mode | | Description | | | 0 | DISABLE | | No change to internal state registers | | | | | | | ## 23.5.4 I2C\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---------|---------|-------|------|------|-----|------|-------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | ' | | ' | • | | | | | | | ' | • | | • | | | • | | | | | • | 000 | 000 | 0x0 | 000 | 0X0 | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | > | ≥ | ≥ | ≥ | > | ≥ | ≥ | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | CLEARPC | CLEARTX | ABORT | CONT | NACK | ACK | STOP | START | | Bit | Name | Reset | Access | Description | |------|----------------------|---------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:8 | Reserved | To ensure ventions | e compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 7 | CLEARPC | 0x0 | W | Clear Pending Commands | | | Set to clear pending | g commands. | | | | 6 | CLEARTX | 0x0 | W | Clear TX | | | Set to clear transmi | it buffer and shift | register. Will no | t abort ongoing transfer. | | 5 | ABORT | 0x0 | W | Abort transmission | | | | | | le. When used in combination with STOP, a STOP condition is sent n. The stop condition is subject to clock synchronization. | | 4 | CONT | 0x0 | W | Continue transmission | | | Set to continue tran | smission after a | NACK has been | ı received. | | 3 | NACK | 0x0 | W | Send NACK | | | Set to transmit a NA | ACK the next tim | e an acknowledo | ge is required. | | 2 | ACK | 0x0 | W | Send ACK | | | Set to transmit an A | ACK the next time | e an acknowledg | ge is required. | | 1 | STOP | 0x0 | W | Send stop condition | | | Set to send stop co | ndition as soon a | as possible. | | | 0 | START | 0x0 | W | Send start condition | | | sent as soon as the | bus is idle. If the | e current transm | transmission is ongoing and not owned, the start condition will be ission is owned by this module, a repeated start condition will be automatically send a STOP, then a START when the bus becomes | # 23.5.5 I2C\_STATE - State Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|-------|---|---------|--------|-------------|--------|----------| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | | | | | | | | | | | | | | | | | | • | | 0×0 | | 0×0 | 0x0 | 0x0 | 0x0 | 0x1 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | 22 | | 22 | 22 | 22 | 22 | <u>~</u> | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | STATE | | BUSHOLD | NACKED | TRANSMITTER | MASTER | BUSY | | Bit | Name | Reset | Access | Description | |------|----------------------------------------------|--------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 31:8 | Reserved | To ensure ventions | e compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 7:5 | STATE | 0x0 | R | Transmission State | | | The state of any curre | ent transmissio | n. 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 | ADDRAC | K | Address ack/nack transmit or receive phase | | | 5 | DATA | | Data transmit or receive phase | | | 6 | DATAAC | < | Data ack/nack transmit or receive phase | | 4 | BUSHOLD | 0x0 | R | Bus Held | | | Set if the bus is curre | ntly being held | by this I2C mod | ule. | | 3 | NACKED | 0x0 | R | Nack Received | | | Set if a NACK was re | ceived and ST | ATE is ADDRAC | CK or DATAACK. | | 2 | TRANSMITTER | 0x0 | R | Transmitter | | | Set when operating a ter receiver, a slave r | | | ve transmitter. When cleared, the system may be operating as a mas-<br>not known. | | 1 | MASTER | 0x0 | R | Master | | | Set when operating a | s an I2C maste | er. When cleared | I, the system may be operating as an I2C slave. | | 0 | BUSY | 0x1 | R | Bus Busy | | | | s out of reset, | the state of the b | s in control of the bus or not has no effect on the value of this bit. bus is not known, and thus BUSY is set. Use the ABORT command he BUSY state. | # 23.5.6 I2C\_STATUS - Status Register | Offset | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|----------|----|--------|---------|------|-----|--------|-------|-------|----------|-------|--------| | 0x014 | 31 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | | | | | | | | | | | | | • | 2 | 2 | 0×0 | 0×0 | 0×1 | 0×0 | 0×0 | 0x0 | 0X0 | 0x0 | 0×0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | ۵ | ۷ | Ж | 22 | 22 | œ | 22 | 22 | 22 | <u>~</u> | 22 | 2 | | Name | | | | | | | | | | | | | | | | | | | | TVDIIEVI | | RXFULL | RXDATAV | TXBL | TXC | PABORT | PCONT | PNACK | PACK | PSTOP | PSTART | | Bit | Name | Reset | Access | Description | |-------|-------------------------------------------------------|--------------------|--------------------|-----------------------------------------------------------------------------| | 31:12 | Reserved | To ensure ventions | compatibility witl | h future devices, always write bits to 0. More information in 1.2 Con- | | 11:10 | TXBUFCNT | 0x0 | R | TX Buffer Count | | | Indicates the number of | buffers filled | with valid data a | nd not transmit to tx shift register | | 9 | RXFULL | 0x0 | R | RX FIFO Full | | | Set when the receive by for one more frame in the | | | receive buffer is no longer full. When this bit is set, there is still room | | 8 | RXDATAV | 0x0 | R | RX Data Valid | | | Set when data is availa | ble in the rece | ive buffer. Clear | ed when the receive buffer is empty. | | 7 | TXBL | 0x1 | R | TX Buffer Level | | | Indicates the level of the transmit buffer is half fu | | fer. if TXBIL==0, | set when the transmit buffer is empty. if TXBIL==1, set when the | | 6 | TXC | 0x0 | R | TX Complete | | | Set when a transmissio mission starts. | n has complet | ed and no more | data is available in the transmit buffer. Cleared when a new trans- | | 5 | PABORT | 0x0 | R | Pending abort | | | An abort is pending and | l will be transr | nitted as soon as | s possible. | | 4 | PCONT | 0x0 | R | Pending continue | | | A continue is pending a | nd will be tran | smitted as soon | as possible. | | 3 | PNACK | 0x0 | R | Pending NACK | | | A not-acknowledge is p | ending and wi | II be transmitted | as soon as possible. | | 2 | PACK | 0x0 | R | Pending ACK | | | An acknowledge is pen | ding and will b | e transmitted as | soon as possible. | | 1 | PSTOP | 0x0 | R | Pending STOP | | | A stop condition is pend | ding and will b | e transmitted as | soon as possible. | | 0 | PSTART | 0x0 | R | Pending START | | | A start condition is pend | ding and will b | e transmitted as | soon as possible. | ## 23.5.7 I2C\_CLKDIV - Clock Division Register | Offset | Bit Position | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------| | 0x018 | 33 34 35 36 37 38 39 30 31 32 33 34 35 36 37 38 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>∞ ν ο τ 4 ω ν ο</th> | ∞ ν ο τ 4 ω ν ο | | Reset | | 0×0 | | Access | | RW | | Name | | ≥IQ | | Bit | Name | Reset | Access | Description | |------|----------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | DIV | 0x0 | RW | Clock Divider | | | Specifies the clock divide | er for the I2C. | Note that DIV r | nust be 1 or higher when slave is enabled. | ## 23.5.8 I2C\_SADDR - Slave Address Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|------|---|---|---|---| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | | | | | | | | | | | | | • | • | | | | | | | • | • | • | | | | 0X0 | • | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | ADDR | | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:1 | ADDR | 0x0 | RW | Slave address | | | Specifies the slave addre | ess of the dev | ice. | | | 0 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | ## 23.5.9 I2C\_SADDRMASK - Slave Address Mask Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|-----------|---|---|---|---| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | | | | | | • | | • | | | • | • | | | • | • | | | | | | 0x0 | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | R | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | SADDRMASK | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------------|--------------------|-----------------|-----------------------------------------------------------------------------| | 31:8 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 7:1 | SADDRMASK | 0x0 | RW | Slave Address Mask | | | Specifies the significa 0x7F will only match to | | | etting the mask to 0x00 will match all addresses, while setting it to ADDR. | | 0 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | # 23.5.10 I2C\_RXDATA - Receive Buffer Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|--------|---|---|---|---| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 6 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | • | | | | | • | | • | • | • | • | | | | | | • | | | | | | | 2 | 3 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ω | _ | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | PXDATA | 7 | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|---------------|-------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | RXDATA | 0x0 | R | RX Data | | | Use this register to read | from the rece | ive buffer. Buffe | er is emptied on read access. | ## 23.5.11 I2C\_RXDOUBLE - Receive Buffer Double Data Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|-----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|-----|---|----|---|---|---|---|---|---------|---|---|---|---| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 000000000000000000000000000000000000000 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | ב | ۲ | | | | | | | ۵ | ۷ | | | | | Name | | | | | | | | | | | | | | | | | | | | - V | | | | | | | | 0 V L V | 2 | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | | | 2 | 2 | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|------------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 15:8 | RXDATA1 | 0x0 | R | RX Data 1 | | | Second byte read from b | uffer. Buffer i | s emptied on re | ad access. | | 7:0 | RXDATA0 | 0x0 | R | RX Data 0 | | | First byte read from buffe | er. Buffer is ei | mptied on read | access. | # 23.5.12 I2C\_RXDATAP - Receive Buffer Data Peek Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---------|----------|---|---|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | OXO | 3 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ω | <u> </u> | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | RXDATAP | | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | RXDATAP | 0x0 | R | RX Data Peek | | | Use this register to read | from the rece | ive buffer. Buffe | er is not emptied on read access. | ## 23.5.13 I2C\_RXDOUBLEP - Receive Buffer Double Data Peek Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----------|----|---|---|---|---|---|-----|---|---|---|---| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | 8 8 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | δ δ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | , | KADATAPI | | | | | | | 047 | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|------------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 15:8 | RXDATAP1 | 0x0 | R | RX Data 1 Peek | | | Second byte read from b | uffer. Buffer is | s not emptied or | n read access. | | 7:0 | RXDATAP0 | 0x0 | R | RX Data 0 Peek | | | First byte read from buffe | er. Buffer is no | ot emptied on re | ad access. | # 23.5.14 I2C\_TXDATA - Transmit Buffer Data Register | Offset | Bit Position | | |--------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | 0x034 | 31<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40<br>40 | ~ 0 \ \tau \ 4 \ \tau \ \tau \ \tau \ \ 0 | | Reset | | 0×0 | | Access | | > | | Name | | TXDATA | | Bit | Name | Reset | Access | Description | |------|----------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | TXDATA | 0x0 | W | TX Data | | | Use this register to write | a byte to the | transmit buffer. | | ## 23.5.15 I2C\_TXDOUBLE - Transmit Buffer Double Data Register | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |-------|----|----|----------|-------------------------------------------------|----------------------------|----------------------------|----------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|----|--------------------|---------|------------------------------------------|-------------------------------------------------|-------|------|---|----------|-------|--------|-------|---|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | 3 | 7 | _ | 0 | | 80 00 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 | > | | | | | | | } | > | | | | | | | | | | | | | | | | | | | | | | | | + 4 C > | ADAIAI | | | | | | | YNATA0 | | | | | | | 31 | 30 | 30 30 29 | 30 30 38 30 30 30 30 30 30 30 30 30 30 30 30 30 | 31<br>30<br>29<br>28<br>27 | 31<br>29<br>27<br>27<br>26 | 31<br>30<br>29<br>27<br>27<br>26<br>26<br>26<br>25 | 31<br>22<br>23<br>24<br>24<br>24 | 31<br>30<br>30<br>27<br>28<br>27<br>28<br>27<br>28<br>28<br>27<br>28<br>28<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | 31<br>22<br>23<br>24<br>25<br>25<br>27<br>28<br>28<br>29<br>20<br>21<br>22<br>23<br>23<br>24<br>25<br>26<br>27<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28 | 31<br>30<br>28<br>28<br>27<br>28<br>27<br>28<br>27<br>28<br>27<br>28<br>27<br>28<br>28<br>29<br>20<br>20<br>21<br>22<br>23<br>24<br>25<br>27<br>27<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28 | 25 22 22 23 20 20 20 20 20 20 20 20 20 20 20 20 20 | 31<br>30<br>28<br>28<br>24<br>25<br>22<br>23<br>20<br>20<br>21<br>20<br>21<br>20<br>21<br>20<br>21<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>27<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28 | 31<br>22<br>23<br>24<br>25<br>25<br>27<br>28<br>20<br>27<br>28<br>20<br>21<br>26<br>27<br>28<br>28<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | | | | Bit Position 31 | | 20 20 20 20 20 20 20 20 20 20 20 20 20 2 | 30 30 30 31 31 31 31 31 31 31 31 31 31 31 31 31 | W 0X0 | W NX | W | W 0X0 12 | W 0X0 | W NXO | W OXO | W | W OXO 3 4 5 6 6 7 7 8 8 8 7 9 9 9 9 9 9 9 9 9 9 9 9 9 9 | N N N N 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 <t< th=""></t<> | | Bit | Name | Reset | Access | Description | |-------|------------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 15:8 | TXDATA1 | 0x0 | W | TX Data | | | Second byte to write to b | uffer. | | | | 7:0 | TXDATA0 | 0x0 | W | TX Data | | | First byte to write to buffe | er. | | | ## 23.5.16 I2C\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|--------|--------|-------|--------|-------|---------|------|------|------|---------|--------|---------|--------|---------|-----|---------|------|-----|------|--------|-------| | 0x03C | 33 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | , | • | | • | | • | • | | | • | 000 | 000 | 000 | 000 | 000 | 0x0 | 0×0 | 0x0 | 000 | 0x0 | 000 | 0x0 | 000 | 000 | 000 | 000 | 000 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | W. | W. | S. | ₩<br>N | Z. | RW<br>W | W. | RW | ₩. | RW | R<br>W | RW | ₩<br>N | RW<br>W | W. | S. | W. | S. | RW | W. | RW | | Name | | | | | | | | | | | SDAERR | SCLERR | CLERR | RXFULL | SSTOP | CLTO | BITO | RXUF | TXOF | BUSHOLD | BUSERR | ARBLOST | MSTOP | NACK | ACK | RXDATAV | TXBL | TXC | ADDR | RSTART | START | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:21 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information ventions | | | | | | | | | | | | 20 | SDAERR | 0x0 | RW | SDA Error Interrupt Flag | | | | | | | | | | | Set when the SDA at loopback path is not equal to SDA output | | | | | | | | | | | | | 19 | SCLERR | 0x0 | RW | SCL Error Interrupt Flag | | | | | | | | | | | Set when the SCL at loopback path is not equal to SCL output | | | | | | | | | | | | | 18 | CLERR | 0x0 | RW | Clock Low Error Interrupt Flag | | | | | | | | | | | Set when the clock is pulled low before a START or a STOP condition could be transmitted. | | | | | | | | | | | | | 17 | RXFULL | 0x0 | RW | Receive Buffer Full Interrupt Flag | | | | | | | | | | | Set when the receive buffer becomes full. | | | | | | | | | | | | | 16 | SSTOP | 0x0 | RW | Slave STOP condition Interrupt Flag | | | | | | | | | | | Set when a STOP condition has been received. Will be set regardless of the slave being involved in the transaction or not. | | | | | | | | | | | | | 15 | CLTO | 0x0 | RW | Clock Low Timeout Interrupt Flag | | | | | | | | | | | 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 | Bus Idle Timeout Interrupt Flag | | | | | | | | | | | Set on each bus idl | e timeout. The tir | neout value car | n be set in the BITO bit field in the I2Cn_CTRL register. | | | | | | | | | | 13 | RXUF | 0x0 | RW | Receive Buffer Underflow Interrupt Flag | | | | | | | | | | | | | | gh the I2Cn_RXDATA register while the receive buffer is empty. It is UBLE while the buffer is not full. | | | | | | | | | | 12 | TXOF | 0x0 | RW | Transmit Buffer Overflow Interrupt Flag | | | | | | | | | | | Set when data is w | ritten to the trans | mit buffer while | the transmit buffer is full. | | | | | | | | | | 11 | BUSHOLD | 0x0 | RW | Bus Held Interrupt Flag | | | | | | | | | | | Set when the bus b | ecomes held by | the I2C module. | | | | | | | | | | | 10 | BUSERR | 0x0 | RW | Bus Error Interrupt Flag | | | | | | | | | | | Set when a bus error is detected. The bus error is resolved automatically, but the current transfer is aborted. | | | | | | | | | | | | | 9 | ARBLOST | 0x0 | RW | Arbitration Lost Interrupt Flag | | | | | | | | | | | Set when arbitration is lost. | | | | | | | | | | | | | 8 | MSTOP | 0x0 | RW | Master STOP Condition Interrupt Flag | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |-----|---------------------------------------------------------|---------------------|-----------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--| | | Set when a STOF | | en successfull | y transmitted. If arbitration is lost during the transmission of the STOP | | | | | | | | | 7 | NACK | 0x0 | RW | Not Acknowledge Received Interrupt Flag | | | | | | | | | | Set when a NACh | K has been receive | ed. | | | | | | | | | | 6 | ACK | 0x0 | RW | Acknowledge Received Interrupt Flag | | | | | | | | | | Set when an ACK | ( has been receive | d. | | | | | | | | | | 5 | RXDATAV | 0x0 | RW | Receive Data Valid Interrupt Flag | | | | | | | | | | Set when received data is half full | | | | | | | | | | | | 4 | TXBL | 0x0 | RW | Transmit Buffer Level Interrupt Flag | | | | | | | | | | if TXBIL==0, set v | when the transmit | buffer is empty | y. if TXBIL==1, set when the transmit is half full | | | | | | | | | 3 | TXC | 0x0 | RW | Transfer Completed Interrupt Flag | | | | | | | | | | Set when the tran | smit shift register | becomes emp | ty and there is no more data in the transmit buffer. | | | | | | | | | 2 | ADDR | 0x0 | RW | Address Interrupt Flag | | | | | | | | | | Set when incomir | ng address is acce | pted, i.e. own | address or general call address is received. | | | | | | | | | 1 | RSTART | 0x0 | RW | Repeated START condition Interrupt Flag | | | | | | | | | | Set when a repeated start condition is detected. | | | | | | | | | | | | 0 | START | 0x0 | RW | START condition Interrupt Flag | | | | | | | | | | Set when a start condition is successfully transmitted. | | | | | | | | | | | ## 23.5.17 I2C\_IEN - Interrupt Enable Register | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----------------------------------------------------------------------------------|--|--|--|--|--|--|--|----|----|--------|--------|--------|--------|--------|-------|------|------|------|------|---------|--------|---------|--------|------|--------|---------|------|--------|------|--------|-------| | 0x040 | 31<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30 | | | | | | | | | | | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 19 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | 0x0 | 0×0 | 0X0 | 0x0 | 000 | 000 | 000 | 0x0 | 0X0 | 0x0 | 0×0 | 0x0 | 0×0 | 0x0 | 000 | 0×0 | 0x0 | 0×0 | 0x0 | 0×0 | 0x0 | | Access | | | | | | | | | RW | W. | ₩<br>M | W. | W. | R<br>W | W. | RW | Z. | RW | W. | RW | W. | W. | ₩<br>M | W<br>M | RW | W<br>M | R | W. | R<br>W | | | | | Name | | | | | | | | | | | | SDAERR | SCLERR | CLERR | RXFULL | SSTOP | CLTO | BITO | RXUF | TXOF | ВИЅНОГД | BUSERR | ARBLOST | MSTOP | NACK | ACK | RXDATAV | TXBL | TXC | ADDR | RSTART | START | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|----------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:21 | Reserved | To ensure ventions | To ensure compatibility with future devices, always write bits to 0. More information ventions | | | | | | | | | | | 20 | SDAERR | 0x0 | RW | SDA Error Interrupt Flag | | | | | | | | | | | Set when SDA at loopback path is not equal to SDA output | | | | | | | | | | | | | 19 | SCLERR | 0x0 | RW | SCL Error Interrupt Flag | | | | | | | | | | | Set when SCL at loopback path is not equal to SCL output | | | | | | | | | | | | | 18 | CLERR | 0x0 | RW | Clock Low Error Interrupt Flag | | | | | | | | | | | Set when the clock is pulled low before a START or a STOP condition could be transmitted. | | | | | | | | | | | | | 17 | RXFULL | 0x0 | RW | Receive Buffer Full Interrupt Flag | | | | | | | | | | | Set when the receive buffer becomes full. | | | | | | | | | | | | | 16 | SSTOP | 0x0 | RW | Slave STOP condition Interrupt Flag | | | | | | | | | | | Set when a STOP condition has been received. Will be set regardless of the slave being involved in the transaction or not. | | | | | | | | | | | | | 15 | CLTO | 0x0 | RW | Clock Low Timeout Interrupt Flag | | | | | | | | | | | 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 | Bus Idle Timeout Interrupt Flag | | | | | | | | | | | Set on each bus idl | le timeout. The tir | neout value car | n be set in the BITO bit field in the I2Cn_CTRL register. | | | | | | | | | | 13 | RXUF | 0x0 | RW | Receive Buffer Underflow Interrupt Flag | | | | | | | | | | | | | | gh the I2Cn_RXDATA register while the receive buffer is empty. It is UBLE while the buffer is not full. | | | | | | | | | | 12 | TXOF | 0x0 | RW | Transmit Buffer Overflow Interrupt Flag | | | | | | | | | | | Set when data is w | ritten to the trans | mit buffer while | the transmit buffer is full. | | | | | | | | | | 11 | BUSHOLD | 0x0 | RW | Bus Held Interrupt Flag | | | | | | | | | | | Set when the bus b | ecomes held by | the I2C module | | | | | | | | | | | 10 | BUSERR | 0x0 | RW | Bus Error Interrupt Flag | | | | | | | | | | | Set when a bus error is detected. The bus error is resolved automatically, but the current transfer is aborted. | | | | | | | | | | | | | 9 | ARBLOST | 0x0 | RW | Arbitration Lost Interrupt Flag | | | | | | | | | | | Set when arbitration is lost. | | | | | | | | | | | | | 8 | MSTOP | 0x0 | RW | Master STOP Condition Interrupt Flag | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | |-----|---------------------------------------------------------|---------------------|------------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--| | | Set when a STOP condition, then the | | | transmitted. If arbitration is lost during the transmission of the STOP . | | | | | | | | | 7 | NACK | 0x0 | RW | Not Acknowledge Received Interrupt Flag | | | | | | | | | | Set when a NACK | has been receive | ed. | | | | | | | | | | 6 | ACK | 0x0 | RW | Acknowledge Received Interrupt Flag | | | | | | | | | | Set when an ACK | has been receive | d. | | | | | | | | | | 5 | RXDATAV | 0x0 | RW | Receive Data Valid Interrupt Flag | | | | | | | | | | Set when data is a | vailable in the red | ceive buffer. Cl | eared automatically when the receive buffer is read. | | | | | | | | | 4 | TXBL | 0x0 | RW | Transmit Buffer Level Interrupt Flag | | | | | | | | | | Set when the trans | smit buffer becom | es empty. Clea | ared automatically when new data is written to the transmit buffer. | | | | | | | | | 3 | TXC | 0x0 | RW | Transfer Completed Interrupt Flag | | | | | | | | | | Set when the trans | smit shift register | becomes empt | y and there is no more data in the transmit buffer. | | | | | | | | | 2 | ADDR | 0x0 | RW | Address Interrupt Flag | | | | | | | | | | Set when incoming | g address is acce | pted, i.e. own a | address or general call address is received. | | | | | | | | | 1 | RSTART | 0x0 | RW | Repeated START condition Interrupt Flag | | | | | | | | | | Set when a repeat | ed start condition | is detected. | | | | | | | | | | 0 | START | 0x0 | RW | START condition Interrupt Flag | | | | | | | | | | Set when a start condition is successfully transmitted. | | | | | | | | | | | ## 24. 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. #### 24.1 Introduction The IADC uses an Incremental Analog to Digital architecture, with a resolution of 12 bits when operating at one million samples per second (1 Msps). The flexible incremental architecture uses oversampling to allow applications to trade speed for higher resolution. An integrated input multiplexer can select from external I/Os and several internal signals. #### 24.2 Features - · Flexible oversampled architecture allows for tradeoffs between speed and resolution. - 1 Msps with oversampling ratio = 2 - 555 ksps with oversampling ratio = 4 - · 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 4-entry 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 4-entry 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 gueue 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 ## 24.3 Functional Description The incremental ADC module block diagram is shown in Figure 24.1 IADC Overview on page 722. Figure 24.1. IADC Overview ## 24.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. #### 24.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 Figure 24.2 Clocking on page 724. 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. 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. PRESCALE must be set to limit ADC\_CLK to no faster than 10 MHz in normal mode for 0.5x and 1x analog gain settings. For analog gain of 2x, 3x, and 4x, the maximum ADC\_CLK is 5 MHz, 3.3 MHz, or 2.5 MHz respectively. **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\_ADCCLKSUS-PENDn will force the clock to only be running when one of the queues is enabled. Figure 24.2. Clocking #### 24.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. The OSR is configured with the OSRHS bit field in the IADC\_CFGx register. Different OSRs may be specified for each configuration group. It is important to note that oversampling is an analog process (pre-digital filter). ### 24.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 TIME-BASE 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 24.3 Start-up Timing on page 725. 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 24.3. Start-up Timing #### 24.3.3.2 Conversion Pipeline The IADC uses a pipelined architecture to perform different stages of the ADC conversion in parallel. The conversion time for a single sample can be determined from the OSR and the pre-scaled CLK\_ADC frequency (f<sub>CLK ADC</sub>) as: Conversion Time = $((4 * OSR) + 2) / f_{CLK\_ADC}$ The minimum OSR is 2, meaning that the fastest possible conversion lasts 10 CLK\_ADC clock cycles. The IADC will automatically insert 2 additional cycles in the pipeline when changing channels to a new GPIO. This allows for hold timing on the previous conversion and allows for time to tristate the ABUS analog buses before connecting the next GPIO to the analog bus. Therefore the maximum sampling rate while continuously sampling on one channel (with CLK\_ADC = 10 MHz) is 1 Msps, and the maximum sampling rate while switching channels is 833 ksps. Figure 24.4 Normal ADC Mode Pipeline on page 726 shows both single-channel and channel-switching scenarios 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 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 24.4. Normal ADC Mode Pipeline #### 24.3.3.3 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 ADC\_SRC\_CLK cycles to synchronize. This is useful for triggering conversions as needed from asynchronous peripheral sources such as GPIO inputs, RTCC 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. ### 24.3.3.3.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 24.5 Immediate Single Conversion on page 728 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 24.5. Immediate Single Conversion #### **Periodic Scans** Another common use case is to periodically trigger the IADC to perform a multi-channel scan. Figure 24.6 Periodic Scan Example on page 729 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 24.6. Periodic Scan Example #### **Tailgating Examples** An example using conversion tailgating is shown in Figure 24.7 Simple Conversion with Tailgating Enabled on page 730. 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 24.7. Simple Conversion with Tailgating Enabled Another example, shown in Figure 24.8 Conversions with Tailgating Disabled on page 731, demonstrates how requests are handled on the different conversion gueues 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 24.8. Conversions with Tailgating Disabled #### **Continuous Conversions** An example of continuous conversions triggered from the scan queue is shown in Figure 24.9 Continuous Conversions on page 731. 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. Figure 24.9. Continuous Conversions #### 24.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. Refer to Table 24.1 Mode Settings on page 732. Table 24.1. Mode Settings | Reference | Description | Voltage | |-----------|---------------------|-----------------------------| | VBGR | Internal | 1.21V | | VDDX | Analog Power Supply | AVDD | | VREF | External | 1.0V - AVDD (1.25V Nominal) | 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 require slower ADC\_CLK as detailed in 24.3.2 Clocking. 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 2x, and a full-scale reading occurs at 2x V / 2x = 2x 0.625 V. If ANALOGGAIN is set to 2x, the full-scale reading of the ADC will not occur until the input reaches 2x 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. #### 24.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\_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, GND, and VREFP. The "odd" multiplexer consists of all ODD ABUS selections, GND, and VREFN. One selection from each multiplexer is allowed on the positive and negative input. More detailed examples may be found in 24.3.5.3 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 24.3.5.4 Scan Queue for more details on using the scan queue. ### 24.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 24.3.5.3 Input Selection Examples. ## 24.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 measurments using internal reference options, all supplies are attenuated by a factor of 4. Table 24.2. Supply Selection (PORTPOS = SUPPLY) | PINPOS | Supply Connection | Voltage at Positive Input | |--------|-------------------|---------------------------| | 0 | AVDD | AVDD / 4 | | 1 | VDDIO | VDDIO / 4 | | 2 | VSS | VSS | | 3 | VSS | vss | | 4 | DVDD | DVDD / 4 | | 7 | DECOUPLE | DECOUPLE | #### 24.3.5.3 Input Selection Examples When configuring to measure a single-ended signal, the positive input selection should always point to the desired input, and PORT-NEG should be programmed to GND. Correct configuration examples for single-ended conversions are shown in Figure 24.10 Single Ended Port/Pin Selection Odd Channel on page 734 and Figure 24.11 Single Ended Port/Pin Selection Even Channel on page 734. Note that the IADC logic will automatically swap the appropriate multiplexer to the positive input of the ADC. Figure 24.10. Single Ended Port/Pin Selection Odd Channel Figure 24.11. Single Ended Port/Pin Selection Even Channel Figure 24.12 Single Ended Port/Pin Selection Polarity Error on page 735 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 24.12. Single Ended Port/Pin Selection Polarity Error Correct configuration examples for differential conversions are shown in Figure 24.13 Differential Port/Pin Selection without Swap on page 735 and Figure 24.14 Differential Port/Pin Selection with Swap on page 736. 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 24.13. Differential Port/Pin Selection without Swap Figure 24.14. Differential Port/Pin Selection with Swap Figure 24.15 Differential Port/Pin Selection Polarity Error on page 736 shows an example where the 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 0x7FFFF. Likewise, a polarity error will occur if both inputs are selected from EVEN buses. Figure 24.15. Differential Port/Pin Selection Polarity Error #### 24.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\_MASKWRITEPENDING 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\_MASKWRITEPENDING returns to 0 before updating IADC\_MASKREQ again. Figure 24.16 MASKREQ Updates on page 737 shows a time line of when the MASKREQ write is updated. Figure 24.16. MASKREQ Updates #### 24.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 $\pm$ 1. 2.5% of full scale. OFFSET is encoded as a 2's complement, 18-bit number with the LSB representing 1 / $\pm$ 20 of full scale. Thus, bit 8 of OFFSET aligns with bit 0 of the 12-bit IADC output word. ## 24.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. #### 24.3.6.1.1 Gain Correction 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\_SCALEx. Using this gain correction mechanism will result in a slight increase to the DNL of the converter, which is reduced by higher OSR settings. Gain error is measured during production test at various settings of ANALOGGAIN, and stored in the DEVINFO\_IADC0GAIN0 and DE-VINFO\_IADC0GAIN1 locations. The GAINCANA1 field is used for 0.5x and 1x ANALOGGAIN settings, while GAINCANA2, GAINCA-NA3, and GANCANA4 are used for ANALOGGAIN settings of 2x, 3x, and 4x, respectively. The GAINCANAn values are expressed as the full 16-bit fixed-point gain, and must be compressed before writing to the IADC\_SCALEx register. To apply a factory-calibrated gain: - 1. Read the appropriate GAINCANAn field from the DEVINFO locations for the selected ANALOGGAIN. - 2. Write the MSB (bit 15) of GAINCANAn to GAIN3MSB in IADC\_SCALEx. - 3. Write the 13 LSBs (bits 12-0) of GAINCANAn to GAIN13LSB in IADC\_SCALEx. #### 24.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\_SCALEx, 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. The production offset calibration consists of four 16-bit terms written to the DEVICEINFO space in the IADCOFFSETCAL0 and IADCOFFSETCAL1 locations: 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: $off_gain = 0$ For ANALOGGAIN set to 2x, 3x, or 4x, off gain is calculated as: off\_gain = OFFSETANA2NORM \* (gain - 1) This is summarized in Table 24.3 Offset Gain Adjustment on page 739. Table 24.3. 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): off\_ana = OFFSETANA1NORM + off\_gain For all other OSR settings, 4x - 64x: off\_ana = OFFSETANABASE + 2\*(OFFSETANA3NORM - off\_gain)/OSR The following table expresses these equations: Table 24.4. 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_{REF}$ , adjust the off\_ana term by a factor of 1.25 / $V_{REF}$ . off\_ana = off\_ana \* (1.25 / V<sub>REF</sub>) 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: off sys = 640\*(256/OSR) Total uncorrected offset (off tot) is calculated by: off\_tot = (off\_ana \* 4 + 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: off\_tot = GAIN\_FACTOR \* (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. OFFSET = 0x3FFFF & (-off tot) #### 24.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 0x000000 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<sup>17</sup> - 1) or less than (-2<sup>17</sup>), the offset is too large to be corrected. #### 24.3.7 Output Data FIFOs The single and scan queues each have a four-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 SINGLEFIFOCFG or SCANFIFOCFG 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 DMAWUFIFOSINGLE or DMAWUFIFOSCAN bits in SINGLEFIFOCFG or SCANFIFOCFG 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 SINGLEFIFOUFIF or SCANFIFOUFIF flag will be set. ## 24.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\_SINGLEFIFOCFG register. For the scan queue, alignment and channel ID are configured in the IADC\_SCANFIFOCFG register. The ALIGNMENT bit field specifies the data justification and the number of data bits as shown in Figure 24.17 Data Alignment on page 742. By default, the converter will produce 12-bit right-justified data, corresponding to ALIGNMENT = RIGHT12. | | • | — się | gn exten | d | |---------|------------|-------|------------|---------------| | RIGHT12 | S | S | | DATA[11:0] | | RIGHT16 | S | S | | DATA[15:0] | | RIGHT20 | SS | | DATA[19:0] | | | LEFT20 | DATA[19:0 | 0] | | 00000000000 | | LEFT16 | DATA[15:0] | | 00 | 0000000000000 | | LEFT12 | DATA[11:0] | | 0000000 | 00000000000 | Figure 24.17. 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 24.18 Data Alignment With ID on page 742 shows output data formatting including the ID, when SHOWID = 1. | RIGHT12 | ID[7:0] | | SS | | D | ATA[11:0] | |---------|------------|-----|---------|------------|------------|-----------| | RIGHT16 | ID[7:0] | S | S | | DATA[15:0] | | | RIGHT20 | ID[7:0] | SS | | DATA[19:0] | | 0] | | LEFT20 | DATA[19:0] | | | | 0000 | ID[7:0] | | LEFT16 | DATA[15:0] | | | 0000 | 0000 | ID[7:0] | | LEFT12 | DATA[11:0 | 000 | 0000000 | 000 | ID[7:0] | | ID for single queue result is 0x20 Figure 24.18. Data Alignment With ID #### 24.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. ### 24.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. #### 24.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: Output Resolution = 11 + log<sub>2</sub>(OversamplingRatio × 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 24.17 Data Alignment on page 742 and Figure 24.18 Data Alignment With ID on page 742. 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. | Alignment Setting | Oversampling Ratio | Digital Averaging | Number of aver-<br>aged samples | | Recommended<br>Mask for DATA<br>field | |-------------------|--------------------|-------------------|---------------------------------|---------|---------------------------------------| | 16-bit | 2x | 1x | 2 | 12 bits | 0xFFF0 | | 16-bit | 8x | 2x | 16 | 15 bits | 0xFFFE | | 20-bit | 2x | 1x | 2 | 12 bits | 0xFFF00 | | 20-bit | 16x | 4x | 64 | 17 bits | 0xFFFF8 | Table 24.5. Output Resolution Masking Examples ## 24.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 (SINGLEFIFOFLUSH or SCANFIFOFLUSH) in the IADC\_CMD register. - 5. Wait for the corresponding status bit (SINGLEFIFOFLUSHING or SCANFIFOFLUSHING) in IADC\_STATUS to go low. #### 24.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\_CMPTHR 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 <= ADLT and DATA >= GT. When ADLT is less than ADGT, the comparator will trigger on an "outside" condition, or when DATA <= ADLT or DATA >= GT. Figure 24.19 Window Comparison Examples on page 744 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 24.19. Window Comparison Examples #### 24.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 SINGLEFIFOCFG DVL has been reached or exceeded. - SCANFIFODVLIF The scan FIFO watermark specified in SCANFIFOCFG 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. - SINGLEFIFOUFIF A single FIFO underflow has occurred. - · SCANFIFOUFIF 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 interrupts 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. ## 24.4 IADC Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | 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 | R(r)H | Single FIFO Read Data | | 0x078 | IADC_SINGLEFIFOSTAT | RH | Single FIFO Status | | 0x07C | IADC_SINGLEDATA | RH SYNC | Single Data | | 0x080 | IADC_SCANFIFOCFG | RW CONFIG | Scan FIFO Configuration | | 0x084 | IADC_SCANFIFODATA | R(r)H | 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 | Туре | 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 | R(r)H | Single FIFO Read 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 | R(r)H | 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 | R(r)H | Single FIFO Read 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 | R(r)H | Scan FIFO Read Data | | 0x2088 | IADC_SCANFIFOSTAT_CLR | RH | Scan FIFO Status | | Offset | Name | Туре | 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_SINGLEFIFOCFG_TGL | RW CONFIG | Single FIFO Configuration | | 0x3074 | IADC_SINGLEFIFODATA_TGL | R(r)H | Single FIFO Read Data | | 0x3078 | IADC_SINGLEFIFOSTAT_TGL | RH | Single FIFO Status | | 0x307C | IADC_SINGLEDATA_TGL | RH SYNC | Single Data | | 0x3080 | IADC_SCANFIFOCFG_TGL | RW CONFIG | Scan FIFO Configuration | | 0x3084 | IADC_SCANFIFODATA_TGL | R(r)H | Scan FIFO Read Data | | 0x3088 | IADC_SCANFIFOSTAT_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 | ## 24.5 IADC Register Description # 24.5.1 IADC\_IPVERSION - IPVERSION | Offset | Bit Position | | | | | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 0x000 | 33 34 4 5 6 6 6 7 7 8 8 8 9 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | | | | | | | Reset | 80 | | | | | | | Access | Ψ | | | | | | | Name | PVERSION R | | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x1 | R | IP version ID | | | The read only IPVERSION modules with different v | • | | this module. There may be minor software changes required for | ## 24.5.2 IADC\_EN - Enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|-----| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | • | | | | | | | | | | | | | | | | | | • | | | | | | | • | | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | EN | | Bit | Name | Reset | Access | Description | |------|--------------------|--------------------------|--------------------|---------------------------------------------------------------------------| | 31:1 | Reserved | To ensur<br>ventions | | with future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | Enable IADC Module | | | | | | rite to CONFIG type registers before setting the EN bit. Software | | | Should write to Sh | NC type registers | s only after setti | ng the EN bit. | | | Value | /NC type registers Mode | s only after setti | ng the EN bit. Description | | | | | | | # 24.5.3 IADC\_CTRL - Control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|-----------|----|----|----|----|----|----|----|----|----|----------|---|----|------|------|----|----|----|---|---|---|---|---|-----|---|------------|---------|----------------|----------------|---------------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | . 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | 000 | | | | ' | | | | | | 0X0 | | | | | | | ' | | ' | • | | • | | 6 | S<br>S | 000 | 0×0 | 0×0 | 0x0 | | Access | | | RW | | | | | | | | | | Z<br>M | | | | | | | | | | | | | | à | ≥<br>Y | Z. | RW | W. | RW | | Name | | | HSCLKRATE | | | | | | | | | | TIMEBASE | | | | | | | | | | | | | | | WAKMUPWOUE | DBGHALT | ADCCLKSUSPEND1 | ADCCLKSUSPEND0 | EM23WUCONVERT | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-----------------|-------------------------------------------------------------------------------------------------| | 31 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 30:28 | HSCLKRATE | 0x0 | RW | High Speed Clock Rate | | | Ratio to divide incomi | ng 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 | To ensure | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 22:16 | TIMEBASE | 0x0 | RW | Time Base | | | | | | rate a 1 us interval for warm up and start up timing. Does not allow uced with 0x1 (2 cycles). | | 15:6 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | WARMUPMODE | 0x0 | RW | Warmup Mode | | | Select the warmup m | ode for the AD | C. | | | | Value | Mode | , | Description | | | 0 | NORMAL | | Shut down the IADC after conversions have completed. | | | 1 | KEEPINS | TANDBY | Switch to standby mode after conversions have completed. The next warmup time will require 1us. | | | 2 | KEEPWA | RM | Keep IADC fully powered after conversions have completed. | | 3 | DBGHALT | 0x0 | RW | Debug Halt | | Bit | Name | Reset | Access | Description | |-----|-----------------------|---------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | ADC behavior when hal | Ited by debug | ger. | | | | 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 | ADC_CLK Suspend - PRS1 | | | | ains running. | In EM2 and EM | RSPOS or PRSNEG. In EM0 and EM1, this gates the local clock 3, this disables the clock source until the PRSPOS or PRSNEG ADC timer is running. | | | Value | Mode | | Description | | | 0 | PRSWUDI | IS | Normal mode which does not disable the ADC_CLK. | | | 1 | PRSWUEI | N | 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 | ADC_CLK Suspend - PRS0 | | | | ınning. In EM | 2 and EM3, this | SPOS or PRSNEG. In EM0 and EM1, this gates the local clock while disables the clock source until the PRSPOS or PRSNEG event is running. | | | Value | Mode | | Description | | | 0 | PRSWUDI | IS | Normal mode which does not disable the ADC_CLK. | | | 1 | PRSWUE | N | 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 | EM23 Wakeup on Conversion | | | EM23 wake up on conv | ersion | | | | | 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 | WUCONV | ERT | 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. | ## 24.5.4 IADC\_CMD - Command | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|---------------|-----------------|----|----|----|----|----|----|----------|---------|------|----|----|----|---|----|---|---|---|---|---|----------|-----------|---|------------|-------------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 19 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | | | 0×0 | 0×0 | | | ' | | | | 0×0 | 0×0 | | ' | • | ' | 1 | • | | | | ' | | 0×0 | 000 | | 0×0 | 0x0 | | Access | | | | | | | > | > | | | | | | | > | > | | | | | | | | | | | | > | > | | > | > | | Name | | | | | | | SCANFIFOFLUSH | SINGLEFIFOFLUSH | | | | | | | TIMERDIS | TIMEREN | | | | | | | | | | | | SCANSTOP | SCANSTART | | SINGLESTOP | SINGLESTART | | Dif | Nama | Booot | A 00000 | Description | |-------|-----------------------------------------------------------------|--------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 31:26 | Reserved | ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 25 | SCANFIFOFLUSH | 0x0 | W | Flush the Scan FIFO | | | | TUS.SCANFIF | OFLUSHING h | not suspended, and the IADC clock must be running. Operation has as gone low. The scan queue should be disabled. Any incoming scan | | 24 | SINGLEFIFOFLUSH | 0x0 | W | Flush the Single FIFO | | | Flush the Single FIFO completed when STA single queue data will | TUS.SINGLEF | IFOFLUSHING | not suspended, and the IADC clock must be running. Operation has has gone low. The Single queue should be disabled. Any incoming . | | 23:18 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 17 | TIMERDIS | 0x0 | W | Timer Disable | | | Disable the local time | r and reset the | counter to time | er reload value. | | 16 | TIMEREN | 0x0 | W | Timer Enable | | | Enable the local timer | | | | | 15:5 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 4 | SCANSTOP | 0x0 | W | Scan Queue Stop | | | | ill continue unt | il it is complete. | lears pending conversions in the Scan queue. Any conversion that If the scan queue is stopped before all entries of the scan table have ted. | | 3 | SCANSTART | 0x0 | W | Scan Queue Start | | | Start the Scan queue. | Enables trigge | ering of the Sca | n queue. | | 2 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1 | SINGLESTOP | 0x0 | W | Single Queue Stop | | | Stop the Single queue sion that has already | | | ers and clears pending conversions in the Single queue. Any convercomplete. | | 0 | SINGLESTART | 0x0 | W | Single Queue Start | | | Start the Single queue | e. Enables trigg | gering of the Sir | ngle queue. | | | | | | | ## 24.5.5 IADC\_TIMER - Timer | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|----------|---|---|---|---|---|---|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | • | • | | | | | | | • | • | | | | | | | | | 2 | 2 | • | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | TIMED | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | TIMER | 0x0 | RW | Timer Period | | | Number of CLK_SRC_A | DC cycles pe | r timer event. | | ## 24.5.6 IADC\_STATUS - Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|---------|----|----|----|----|----|----------|----|----|---------------------|--------------------|----|----|----|-------------|------------------|--------------------|----|----|---|----|------------|--------------|---|------------|---|------------------|---------|---|--------------------|-----------| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | 0x0 | | • | | 1 | ' | 0×0 | | | 000 | 0×0 | | | | 0×0 | 0×0 | 0×0 | | | | | 0x0 | 0x0 | | 0x0 | | 0x0 | 0×0 | | 0x0 | 000 | | Access | | 2 | | | | | | 2 | | | 22 | 22 | | | | 22 | 22 | 22 | | | | | 2 | 2 | | 2 | | 2 | 22 | | R | 2 | | Name | | ADCWARM | | | | | | SYNCBUSY | | | MASKREQWRITEPENDING | SINGLEWRITEPENDING | | | | TIMERACTIVE | SCANFIFOFLUSHING | SINGLEFIFOFLUSHING | | | | | SCANFIFODV | SINGLEFIFODV | | CONVERTING | | SCANQUEUEPENDING | SCANQEN | | SINGLEQUEUEPENDING | SINGLEQEN | | D:4 | | | | | |-------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 31 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 30 | ADCWARM | 0x0 | R | ADCWARM | | | | | | ay before converting when coming from a powered down or standend and reference are ready. | | 29:25 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 24 | SYNCBUSY | 0x0 | R | SYNCBUSY | | | Indicates synchronization | ongoing | | | | 23:22 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 21 | MASKREQWRITE-<br>PENDING | 0x0 | R | MASKREQ write pending | | | A write to MASKREQ is p | ending The | | | | | to the local working version | | | sing a local working mask register, and only transfers MASKREQ not converting. | | 20 | to the local working version SINGLEWRITEPEND-ING | | | | | 20 | SINGLEWRITEPEND-ING The SINGLE register write | 0x0 e is pending. | R The ADC conve | not converting. | | 20 | SINGLEWRITEPEND-ING The SINGLE register write | 0x0 e is pending. | R The ADC convergersion when the | SINGLE write pending erts using a local working version of the SINGLE register, and only | | | SINGLEWRITEPEND-ING The SINGLE register writtransfer SINGLE to the lo | 0x0 e is pending. cal working v | R The ADC convergersion when the | SINGLE write pending erts using a local working version of the SINGLE register, and only SINGLE queue is not being converted. | | 19:17 | SINGLEWRITEPEND-ING The SINGLE register writtransfer SINGLE to the lo | on when the source on when the source on when the source of o | R The ADC convergersion when the | SINGLE write pending erts using a local working version of the SINGLE register, and only SINGLE queue is not being converted. future devices, always write bits to 0. More information in 1.2 Con- | | 19:17 | SINGLEWRITEPEND-ING The SINGLE register writtransfer SINGLE to the lo Reserved TIMERACTIVE | on when the source on when the source on when the source of o | R The ADC convergersion when the | SINGLE write pending erts using a local working version of the SINGLE register, and only SINGLE queue is not being converted. future devices, always write bits to 0. More information in 1.2 Con- | | 19:17<br>16 | SINGLEWRITEPEND-ING The SINGLE register write transfer SINGLE to the lo Reserved TIMERACTIVE The local timer is running | on when the sound which the sound on which the sound on the sound on which the sound on of the sound on | R The ADC convergersion when the compatibility with R | SINGLE write pending erts using a local working version of the SINGLE register, and only SINGLE queue is not being converted. future devices, always write bits to 0. More information in 1.2 Con- Timer Active | | 19:17<br>16 | SINGLEWRITEPEND-ING The SINGLE register writtensfer SINGLE to the lo Reserved TIMERACTIVE The local timer is running SCANFIFOFLUSHING | on when the sound which the sound on which the sound on which the sound on | R The ADC convergersion when the compatibility with R | SINGLE write pending erts using a local working version of the SINGLE register, and only SINGLE queue is not being converted. future devices, always write bits to 0. More information in 1.2 Con- Timer Active | | Bit | Name | Reset | Access | Description | |-------|----------------------------------------------------|----------------|--------------------|----------------------------------------------------------------------| | 13:10 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 9 | SCANFIFODV | 0x0 | R | SCANFIFO Data Valid | | | At least one result in the | single FIFO is | s ready to read. | | | 8 | SINGLEFIFODV | 0x0 | R | SINGLEFIFO Data Valid | | | At least one result in the | scan FIFO is | ready to read. | | | 7 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 6 | CONVERTING | 0x0 | R | Converting | | | The ADC is warmed up a | and in the pro | cess of performi | ng a conversion. | | 5 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | SCANQUEUEPENDING | 0x0 | R | Scan Queue Pending | | | The Scan queue has bee | en triggered a | nd is waiting to | start conversion. | | 3 | SCANQEN | 0x0 | R | Scan Queued Enabled | | | The Scan queue is enabl | ed. | | | | 2 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 1 | SINGLEQUEUEPEND-<br>ING | 0x0 | R | Single Queue Pending | | | The Single queue has be ING will remain high until | | | start conversion. When tailgating is used, SINGLEQUEUEPEND-npleted. | | 0 | SINGLEQEN | 0x0 | R | Single Queue Enabled | | | The Single queue is enab | oled. | | | # 24.5.7 IADC\_MASKREQ - Mask Request | Offset | | Bit Po | | | | | | | | | | | | | Position | | | | | | | | | | | | | | | | | | |--------|----|--------|----|----|----|----|----|----|----|----|----|----|----|---------|----------|----|----|---|----|----|---|----|---|-----|--------|---|---|---|---|---|---|---| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | | | | | | | | | | | | | | | | | | | 2 | S<br>S | | • | • | | | | | | Access | | | | | | | | | | | | | | MX<br>W | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | 070 | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------|-------------------------|--|--|--|--|--|--|--|--| | 31:16 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 ventions | | | | | | | | | | | | 15:0 | MASKREQ | 0x0 | RW | Scan Queue Mask Request | | | | | | | | | | | Allows software to specify which entries in the Scan table should be converted. For example MASKREC means that scan table entries 15, 4, and 2 will be converted. The other entries will not be converted. | | | | | | | | | | | | ## 24.5.8 IADC\_STMASK - Scan Table Mask | Offset | | Bit Po | | | | | | | | | | | | | Position | | | | | | | | | | | | | | | | | | |--------|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|----|---|--------|--------------|---|---|---|---|---|---|---| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | • | | | | | | | | | | | | • | | | | | 2 | 2 | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | ۵ | ۷ | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | STMACK | <u>{</u><br> | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |-------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:16 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 ventions | | | | | | | | | | | | 15:0 | STMASK | 0x0 | R | Scan Table Mask | | | | | | | | | | | This is the active / working sequence or when no sc | | | gister that the ADC uses. It will only be updated at the end of a scan | | | | | | | | | # 24.5.9 IADC\_CMPTHR - Digital Window Comparator Threshold | Offset | | Bit Po | | | | | | | | | | | | | Position | | | | | | | | | | | | | |--------|-------------------------------------------------------------------------|--------|--|--|--|--|--|--|--|--|--|--|------|-----|----------|--|--|--|--|--|--|--|--|--|--|--|--| | 0x020 | 33 33 33 33 34 35 36 36 37 38 38 39 39 39 39 39 39 39 39 39 39 39 39 39 | | | | | | | | | | | | 7 | _ | 0 | | | | | | | | | | | | | | Reset | | 0×0 | | | | | | | | | | | | 0×0 | | | | | | | | | | | | | | | Access | | <br>≫ | | | | | | | | | | | | R& | | | | | | | | | | | | | | | Name | | ADGT | | | | | | | | | | | ADLT | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------------------------------|--------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:16 | ADGT | 0x0 | RW | ADC Greater Than or Equal to Threshold | | | mat regardless of the FI value. Comparisons with | FO ALIGNM<br>n 20-bit forma<br>n ADGT is g | ENT setting. Co<br>ats will ignore the<br>reater than ADL | o comparison. ADGT should be specified in a left-justified, 16-bit for-<br>omparisons with 12-bit formats will ignore the 4 LSBs of the ADGT<br>ne 4 LSBs of the 20-bit result. Unipolar or bipolar mode is considered<br>.T, the comparison is true if the result is either greater than ADGT or<br>the values. | | 15:0 | ADLT | 0x0 | RW | ADC Less Than or Equal to Threshold | | | regardless of the FIFO A<br>Comparisons with 20-bit | ALIGNMENT<br>formats will<br>T is greater | setting. Compa<br>ignore the 4 LS<br>than ADLT, the | comparison. ADLT should be specified in a left-justified, 16-bit format arisons with 12-bit formats will ignore the 4 LSBs of the ADLT value. SBs of the 20-bit result. Unipolar or bipolar mode is considered in the comparison is true if the result is either greater than ADGT or less alues. | # 24.5.10 IADC\_IF - Interrupt Flags | Offset | | | | | | | | | | | | | | | Bi | t Po | ositi | on | | | | | | | | | | | | | | | |--------|----------------|----|----|----|----|----|----|----|----|----|----|----|------------|--------------|------------|--------------|-------|----|--------------|-------------|---|----|------------|---------------|---------------|---|---|---|---------|-----------|-------------|---------------| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 000 | | | | | ' | • | | ' | | | | 000 | 0×0 | 0×0 | 0×0 | | ' | 0x0 | 000 | | ' | 0x0 | 0×0 | 0X0 | | ' | • | 0×0 | 0x0 | 0×0 | 0x0 | | Access | R<br>W | | | | | | | | | | | | M | ₽ | ₩<br>M | ZW<br>W | | | Z. | ₽ | | | RW | Z. | ₽ | | | | ₽ | RW | ₽ | RW | | Name | EM23ABORTERROR | | | | | | | | | | | | SCANFIFOUF | SINGLEFIFOUF | SCANFIFOOF | SINGLEFIFOOF | | | PORTALLOCERR | POLARITYERR | | | SINGLEDONE | SCANTABLEDONE | SCANENTRYDONE | | | | SCANCMP | SINGLECMP | SCANFIFODVL | SINGLEFIFODVL | | Bit | Name | Reset | Access | Description | |-------|---------------------------------------|-----------------------|-------------------|--------------------------------------------------------------------------| | 31 | EM23ABORTERROR | 0x0 | RW | EM2/3 Abort Error | | | The system entered EM | 12 or EM3 du | ring a conversion | on with an unsupported clock. Conversion results may be corrupted. | | 30:20 | Reserved | To ensure<br>ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 19 | SCANFIFOUF | 0x0 | RW | Scan FIFO Underflow | | | A scan FIFO underflow | has occured. | | | | 18 | SINGLEFIFOUF | 0x0 | RW | Single FIFO Underflow | | | A single FIFO underflow | v has occured | d. | | | 17 | SCANFIFOOF | 0x0 | RW | Scan FIFO Overflow | | | A scan FIFO overflow h | as occured. | | | | 16 | SINGLEFIFOOF | 0x0 | RW | Single FIFO Overflow | | | A single FIFO overflow | has occured. | | | | 15:14 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 13 | PORTALLOCERR | 0x0 | RW | Port Allocation Error | | | A pin was selected on a | port which h | as not been allo | ocated to the IADC in GPIO control. | | 12 | POLARITYERR | 0x0 | RW | Polarity Error | | | Either two even channe set to 0xFFFF. | ls or two odd | channels were | programmed into the channel mux selection. The ADC result will be | | 11:10 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 9 | SINGLEDONE | 0x0 | RW | Single Conversion Done | | | A single conversion has | completed. | | | | 8 | SCANTABLEDONE | 0x0 | RW | Scan Table Done | | | A scan sequence comp | leted. Set at t | the end of a sca | an sequence after all valid entries of the scan table have completed. | | 7 | SCANENTRYDONE | 0x0 | RW | Scan Entry Done | | | A scan table conversion | completed. | Set at the comp | oletion of each valid entry of the scan table. | | | | | | | | | | | • | | |-----|------------------------|-----------------------|------------------|-------------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 6:4 | Reserved | To ensure<br>ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 3 | SCANCMP | 0x0 | RW | Scan Result Window Compare | | | Scan digital compare w | rindow tripped | | | | 2 | SINGLECMP | 0x0 | RW | Single Result Window Compare | | | Single digital compare | window trippe | d. | | | 1 | SCANFIFODVL | 0x0 | RW | Scan FIFO Data Valid Level | | | A minimum of (DVL+1) | entries are re | ady to be read f | from the Scan FIFO. | | 0 | SINGLEFIFODVL | 0x0 | RW | Single FIFO Data Valid Level | | | A minimum of (DVL+1) | entries are re | ady to be read t | from the Single FIFO. | # 24.5.11 IADC\_IEN - Interrupt Enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----------------|----|----|----|----|----|----|----|----|----|----|----|------------|--------------|------------|--------------|------|----|--------------|-------------|---|----|------------|---------------|---------------|---|---|---|---------|-----------|-------------|---------------| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | 000 | | • | | • | | • | | | | | | 000 | 0x0 | 000 | 0x0 | | • | 0x0 | 0x0 | | | 0x0 | 000 | 0x0 | | • | • | 0X0 | 0x0 | 000 | 0x0 | | Access | R<br>W | | | | | | | | | | | | M | ₽ | ₩<br>M | W. | | | Z. | ZW<br>W | | | RW | ₽ | ₽ | | | | Z. | Z. | ₽ | RW | | Name | EM23ABORTERROR | | | | | | | | | | | | SCANFIFOUF | SINGLEFIFOUF | SCANFIFOOF | SINGLEFIFOOF | | | PORTALLOCERR | POLARITYERR | | | SINGLEDONE | SCANTABLEDONE | SCANENTRYDONE | | | | SCANCMP | SINGLECMP | SCANFIFODVL | SINGLEFIFODVL | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31 | EM23ABORTERROR | 0x0 | RW | EM2/3 Abort Error Enable | | | EM2/3 Abort Error Enal | ole | | | | 30:20 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 19 | SCANFIFOUF | 0x0 | RW | Scan FIFO Underflow Enable | | | Scan FIFO underflow in | iterrupt enab | le | | | 18 | SINGLEFIFOUF | 0x0 | RW | Single FIFO Underflow Enable | | | Single FIFO underflow | nterrupt ena | ble | | | 17 | SCANFIFOOF | 0x0 | RW | Scan FIFO Overflow Enable | | | Scan FIFO overflow into | errupt enable | ; | | | 16 | SINGLEFIFOOF | 0x0 | RW | Single FIFO Overflow Enable | | | Single FIFO overflow in | terrupt enab | le | | | 15:14 | Reserved | To ensure | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 13 | PORTALLOCERR | 0x0 | RW | Port Allocation Error Enable | | | Port Allocation Error En | able | | | | 12 | POLARITYERR | 0x0 | RW | Polarity Error Enable | | | Polarity Error Enable | | | | | 11:10 | Reserved | To ensure | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 9 | SINGLEDONE | 0x0 | RW | Single Conversion Done Enable | | | Single Conversion Done | e interrupt er | nable | | | 8 | SCANTABLEDONE | 0x0 | RW | Scan Table Done Enable | | | Scan Table Done interr | upt enable | | | | 7 | SCANENTRYDONE | 0x0 | RW | Scan Entry Done Enable | | | Scan Entry Done interru | upt enable | | | | | | | _ | | |-----|--------------------------|-------------------|-------------------|----------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | 6:4 | Reserved | To ensure o | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 3 | SCANCMP | 0x0 | RW | Scan Result Window Compare Enable | | | Scan Result Window Co | mpare Enable | : | | | 2 | SINGLECMP | 0x0 | RW | Single Result Window Compare Enable | | | Single Result Window Co | ompare Enabl | е | | | 1 | SCANFIFODVL | 0x0 | RW | Scan FIFO Data Valid Level Enable | | | Scan FIFO Data Valid Le | evel interrupt of | enable | | | 0 | SINGLEFIFODVL | 0x0 | RW | Single FIFO Data Valid Level Enable | | | Single FIFO Data Valid L | evel interrupt | enable | | # 24.5.12 IADC\_TRIGGER - Trigger | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|------|----|----|------------------|---|----|---------------|---|---|---|---|----------------|---|---|-------------|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | • | | • | | | | | • | • | 0×0 | | | | 0×0 | | | 0X0 | | | • | | 000 | | | 0×0 | | | Access | | | | | | | | | | | | | | | | ₩<br>M | | | | Z. | | | R | | | | | ₩<br>M | | | Z<br>N | | | Name | | | | | | | | | | | | | | | | SINGLETAILGATE | | | | SINGLETRIGACTION | | | SINGLETRIGSEL | | | | | SCANTRIGACTION | | | SCANTRIGSEL | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|--------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:17 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 16 | SINGLETAILGATE | 0x0 | RW | Single Tailgate Enable | | | Enables tailgating. | | | | | | Value | Mode | | Description | | | 0 | TAILGATE | OFF | The single queue is ready to start warming up and converting once the trigger had been detected. | | | 1 | TAILGATE | EON | 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 | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 12 | SINGLETRIGACTION | 0x0 | RW | Single Trigger Action | | | Selects the trigger action | n for the sing | le queue. | | | | 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.ask. | | | 1 | CONTINU | ous | 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 | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 10:8 | SINGLETRIGSEL | 0x0 | RW | Single Trigger Select | | | Selects the trigger source | ce for the sing | gle queue. | | | | | | | | | 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 | PRSCLKGF | RP | 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 ADC_SRC_CLK 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 ADC_SRC_CLK 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 | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 4 | SCANTRIGACTION | 0x0 | RW | Scan Trigger Action | | | Selects the trigger action | for the scan | queue. | | | | 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 | CONTINUC | DUS | 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 | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 2:0 | SCANTRIGSEL | 0x0 | RW | Scan Trigger Select | | | Selects the trigger source | e for the scan | queue. | | | | Value | Mode | | Description | | | 0 | IMMEDIATE | ≣ | Immediate triggering. The scan queue will be disabled once all conversions in the scan table are complete, unless TRIGGER-ACTION is set to continuous. | | | 1 | TIMER | | Triggers when the local timer count reaches zero. | | | 2 | PRSCLKGF | RP | 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 ADC_SRC_CLK 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 ADC_SRC_CLK 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. | # 24.5.13 IADC\_CFGx - Configuration | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|---------------|----|----|----|----|----|----|--------|----|----|----|---|--------|------|------|----|------------|----|---|---|---|---|---|---|---|---|-------|---|---------| | 0x048 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | 3 | 2 | - 0 | | Reset | | | 2 | 2 | | | | | | 0x0 | | | | | 0X0 | | | | 0x2 | | | • | • | | • | | | | 000 | | 0x0 | | Access | | | غ<br>م | Ž | | | | | | W. | | | | | Z<br>M | | | | ΑŠ | | | | | | | | | | Z. | | ₽<br>§ | | Name | | | I GIVIO CONT. | | | | | | | DIGAVG | | | | | REFSEL | | | | ANALOGGAIN | | | | | | | | | | OSRHS | | ADCMODE | | | Name | Reset A | ccess | Description | |----------------|-----------------------------------|--------------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:30 | Reserved | To ensure com ventions | npatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 29:28 | TWOSCOMPL | 0x0 R' | \W | Two's Complement | | | Selects output word | l polarity. | | | | | Value | Mode | | Description | | | 0 | AUTO | | Automatic: Single ended measurements are reported as unipolar and differential measurements are reported as bipolar. | | | 1 | FORCEUNIPO | LAR | Force all measurements to result in unipolar output. Negative differential numbers will saturate to 0. | | | 2 | FORCEBIPOL | AR | Force all measurements to result in bipolar output. Single ended measurements are half the range, but allow for small negative measurements. | | 27:24 | Reserved | To ensure com | npatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 23:21 | DIGAVG | 0x0 R' | :W | Digital Averaging | | | Number of output w | ords to convert and av | verage. | | | | | | | | | | Value | Mode | | Description | | | Value<br>0 | Mode<br>AVG1 | | Description Collect one output word (no digital averaging). | | | | | | <u> </u> | | | 0 | AVG1 | | Collect one output word (no digital averaging). | | | 0 | AVG1<br>AVG2 | | Collect one output word (no digital averaging). Collect and average 2 digital output words. | | | 0 1 2 | AVG1<br>AVG2<br>AVG4 | | Collect one output word (no digital averaging). Collect and average 2 digital output words. Collect and average 4 digital output words. | | 20:19 | 0<br>1<br>2<br>3 | AVG1<br>AVG2<br>AVG4<br>AVG8<br>AVG16 | npatibility v | Collect one output word (no digital averaging). Collect and average 2 digital output words. Collect and average 4 digital output words. Collect and average 8 digital output words. | | 20:19<br>18:16 | 0<br>1<br>2<br>3<br>4 | AVG1 AVG2 AVG4 AVG8 AVG16 To ensure comventions | npatibility v | Collect one output word (no digital averaging). Collect and average 2 digital output words. Collect and average 4 digital output words. Collect and average 8 digital output words. Collect and average 16 digital output words. | | | 0<br>1<br>2<br>3<br>4<br>Reserved | AVG1 AVG2 AVG4 AVG8 AVG16 To ensure comventions 0x0 R | | Collect one output word (no digital averaging). Collect and average 2 digital output words. Collect and average 4 digital output words. Collect and average 8 digital output words. Collect and average 16 digital output words. | | | 0 1 2 3 4 Reserved | AVG1 AVG2 AVG4 AVG8 AVG16 To ensure comventions 0x0 R | | Collect one output word (no digital averaging). Collect and average 2 digital output words. Collect and average 4 digital output words. Collect and average 8 digital output words. Collect and average 16 digital output words. | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | | 1 | VREF | | External Reference. (Calibrated for 1.25V nominal.) | | | 3 | VDDX | | AVDD (unbuffered) | | | 4 | VDDX0P8 | BUF | AVDD (buffered) * 0.8 | | 15 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 14:12 | ANALOGGAIN | 0x2 | RW | Analog Gain | | | Sets analog froont er | nd gain. | | | | | Value | Mode | | Description | | | 1 | ANAGAIN | 0P5 | Analog gain of 0.5x. | | | 2 | ANAGAIN | 1 | Analog gain of 1x. | | | 3 | ANAGAIN | 2 | Analog gain of 2x. | | | 4 | ANAGAIN | 3 | Analog gain of 3x. | | | 5 | ANAGAIN | 4 | Analog gain of 4x. | | 11:5 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 4:2 | OSRHS | 0x0 | RW | High Speed OSR | | | Over sampling ratio f | or high speed o | onversions. | | | | 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 | ADC Mode | | | Selects ADC convers | sion mode. | | | | | Value | Mode | | Description | | | 0 | NORMAL | | High speed mode with a maximum CLK_ADC of 10 MHz. | # 24.5.14 IADC\_SCALEx - Scaling | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|--------|---------|---|---|---|---|---|---|---|---| | 0x050 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x1 | | 000 | | | | | | | | | | | | | | | | | | | | | OXXCOOO | | | | | | | | | | Access | ₩<br>N | | | | | | | | | | | | | | | | | | | | | | Ž | ≥<br>Y | | | | | | | | | | Name | GAIN3MSB | _ | | | | | | | | | | | | | | | | | | | | Ĺ | OFFSEI | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------------|----------|--------|-----------------------------------------------------------------------------------------------------| | 31 | GAIN3MSB | 0x1 | RW | Gain 3 MSBs | | | | | | or 1.00). Example {GAIN3MSB, GAIN13LSB} = {100, B, 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 | Gain 13 LSBs | | | 13 LSBs of the 16-bit gain | n value. | | | | 17:0 | OFFSET | 0x2C000 | RW | Offset | | | Offset | | | | # 24.5.15 IADC\_SCHEDx - Scheduling | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |----|----|----|-------|----------------|----------------------|----------------------------------------|----------------------------------------------------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------|-------|----|--------------------|----|---|----|---|---|---|---|----------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | 3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - | ζ | | | | | | | 31 | 30 | 30 31 | 30 31 31 32 39 | 30<br>29<br>28<br>27 | 30<br>29<br>27<br>26<br>27<br>26<br>27 | 31<br>27<br>28<br>29<br>27<br>26<br>26<br>27<br>28<br>29<br>29<br>29 | 31<br>29<br>27<br>27<br>24<br>25<br>25 | 31<br>22<br>23<br>24<br>25<br>24<br>25<br>25<br>25<br>27<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28 | 31<br>22<br>23<br>24<br>25<br>25<br>26<br>27<br>27<br>28<br>28<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | 30<br>29<br>27<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>27<br>28<br>28<br>27<br>28<br>27<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28 | 31<br>22<br>23<br>24<br>25<br>26<br>27<br>27<br>28<br>28<br>28<br>29<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | 31<br>30<br>31<br>31<br>32<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31 | 31<br>31<br>32<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31<br>31 | | | | Bit Position 31 | | | | | | | | | 31<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>4<br>4<br>4<br>4<br>4<br>4 | 31 31 32 33 34 35 36 36 37 38 39 39 39 39 39 39 39 39 39 39 39 39 39 | WW 0X0 0X0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | ALE RW 0x0 5 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 31 31 32 33 34 35 36 36 37 36 37 36 37 37 38 38 38 39 39 39 39 39 39 39 39 39 39 39 39 39 | | Bit | Name | Reset | Access | Description | |-------|-------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:10 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 9:0 | PRESCALE | 0x0 | RW | Prescale | | | Second level prescaler - only be used with HSCL | | | by (PRESCALE + 1) to generate CLK_ADC. PRESCALE=0 should | # 24.5.16 IADC\_SINGLEFIFOCFG - Single FIFO Configuration | Offset | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|-----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|-----------------|---|---|----|----------|--------|---|-----------|---| | 0x070 | 30 | 8 6 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | | | | • | | • | | | | • | | • | | | | | | 0x0 | | | 2 | S<br>S | 000 | | 0X | | | Access | | | | | | | | | | | | | | | | | | | | | | | Z. | | | 20 | <u>}</u> | ₩<br>M | | Σ. | | | Name | | | | | | | | | | | | | | | | | | | | | | | DMAWUFIFOSINGLE | | | 70 | ۵۷<br>۱ | SHOWID | | ALIGNMENT | | | Bit | Name | Reset | Access | Description | |------|----------------------------------------------------|--------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 31:9 | Reserved | To ensure ventions | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 8 | DMAWUFIFOSINGLE | 0x0 | RW | Single FIFO DMA wakeup. | | | Enables single FIFO to | wake DMA in | EM2 or EM3. | | | | Value | Mode | | Description | | | 0 | DISABLED | 1 | 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:6 | Reserved | To ensure ventions | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | DVL | 0x3 | RW | Data Valid Level | | | Data valid level before r requests will be generat | | IA transfer. If the | e number of words in the FIFO reaches or exceeds DVL+1, DMA | | | 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. | | 3 | SHOWID | 0x0 | RW | Show ID | | | ID of 0x20 will be applie | d in the outpu | it words. | | | 2:0 | ALIGNMENT | 0x0 | RW | Alignment | | | Alignment of output data | a written into F | FIFO. | | | | Value | Mode | | Description | | | | | | | | Bit | Name | Reset Access | 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], 0000000000000, ID[7:0] | | | 4 | LEFT16 | DATA[15:0], 00000000, ID[7:0] | | | 5 | LEFT20 | DATA[19:0], 0000, ID[7:0] | | | | | | # 24.5.17 IADC\_SINGLEFIFODATA - Single FIFO Read Data | Offset | Bit Position | |--------|---------------------------------------------------------------------------------------------| | 0x074 | 33 34 4 5 6 6 7 8 8 8 7 12 2 12 22 22 23 24 25 26 26 27 27 27 27 27 27 27 27 27 27 27 27 27 | | Reset | 0x0 | | Access | R(r) | | Name | DATA | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|-------------------------------------------------------|-------|--------|-----------------------|--|--|--|--|--|--|--|--| | 31:0 | DATA | 0x0 | R(r) | Single FIFO Read Data | | | | | | | | | | | Reads and pops the oldest value from the single FIFO. | | | | | | | | | | | | # 24.5.18 IADC\_SINGLEFIFOSTAT - Single FIFO Status | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------|---| | 0x078 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | • | • | | | | | | ' | • | ' | | | • | | | | • | ' | | | | | ' | | 0x0 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ď | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | FIFOREADCNT | | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:3 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 2:0 | FIFOREADCNT | 0x0 | R | FIFO Read Count | | | Number of valid entrie | es available to | read. | | # 24.5.19 IADC\_SINGLEDATA - Single Data | Offset | Bit Position | | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x07C | 33 34 35 36 37 38 38 39 30 30 30 31 32 33 34 45 45 46 47 47 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | | | | | | | | | | | | Reset | 0×0 | | | | | | | | | | | | | Access | α | | | | | | | | | | | | | Name | DATA | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--|--|--|--| | 31:0 | DATA | 0x0 | R | Data | | | | | | | | | | | | 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. | | | | | | | | | | | | | # 24.5.20 IADC\_SCANFIFOCFG - Scan FIFO Configuration | Offset | Bit Position | | | | | | | | | | | | | | |--------|---------------------------------------------------|----------------|----------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x080 | 33 34 5 5 6 7 7 8 7 8 7 8 7 8 7 8 7 8 7 8 7 8 7 8 | 8 / 9 | το 4 κ α τ O | | | | | | | | | | | | | Reset | | OXO | 000 000 | | | | | | | | | | | | | Access | | À<br>Y | RW RW | | | | | | | | | | | | | Name | | DIMAWOFIFOSCAN | DVL<br>SHOWID<br>ALIGNMENT | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:9 | Reserved | To ensure ventions | e compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | 8 | DMAWUFIFOSCAN | 0x0 | RW | Scan FIFO DMA Wakeup | | | Enables scan FIFO to | wake DMA in | EM2 or EM3. | | | | Value | Mode | | Description | | | 0 | DISABLE | D | While in EM2 or EM3, the DMA controller will not be requested. | | | 1 | ENABLE | ) | 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:6 | Reserved | To ensure | e compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | F. 4 | DVL | 0x3 | RW | Data Valid Level | | 5:4 | DVL | UXS | IT V V | Data Valid Level | | 5.4 | | requesting D | | ne number of words in the FIFO reaches or exceeds DVL+1, DMA | | 5.4 | Data valid level before | requesting D | | - <del> </del> | | 5.4 | Data valid level before requests will be generated | e requesting D<br>ated. | | ne number of words in the FIFO reaches or exceeds DVL+1, DMA | | 5.4 | Data valid level before requests will be generally | e requesting D<br>ated. | | Description When 1 entry in the scan FIFO is valid, set the SCANFIFODVL | | 5.4 | Data valid level before requests will be generally Value | e requesting D<br>ated. Mode VALID1 | | Description When 1 entry in the scan FIFO is valid, set the SCANFIFODVL interrupt and request DMA. When 2 entries in the scan FIFO are valid, set the SCANFI- | | 5.4 | Data valid level before requests will be generally Value | Mode VALID1 VALID2 | | Description When 1 entry in the scan FIFO is valid, set the SCANFIFODVL interrupt and request DMA. When 2 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 3 entries in the scan FIFO are valid, set the SCANFI- | | 3 | Data valid level before requests will be generally Value 0 1 | Mode VALID1 VALID2 VALID3 | | Description When 1 entry in the scan FIFO is valid, set the SCANFIFODVL interrupt and request DMA. When 2 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 3 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 4 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. | | | Data valid level before requests will be generally Value 0 1 2 3 | requesting D ated. Mode VALID1 VALID2 VALID3 VALID4 | MA transfer. If the | Description When 1 entry in the scan FIFO is valid, set the SCANFIFODVL interrupt and request DMA. When 2 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 3 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 4 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 4 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. | | | Data valid level before requests will be generally Value 0 1 2 3 SHOWID | requesting D ated. Mode VALID1 VALID2 VALID3 VALID4 | MA transfer. If the | Description When 1 entry in the scan FIFO is valid, set the SCANFIFODVL interrupt and request DMA. When 2 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 3 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 4 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 4 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. | | 3 | Data valid level before requests will be generally Value 0 1 2 3 SHOWID Enable ID in output wo | wated. Mode VALID1 VALID2 VALID3 VALID4 0x0 ords. 0x0 | MA transfer. If the RW | Description When 1 entry in the scan FIFO is valid, set the SCANFIFODVL interrupt and request DMA. When 2 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 3 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. When 4 entries in the scan FIFO are valid, set the SCANFIFODVL interrupt and request DMA. Show ID | | Bit | Name | Reset Access | s 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] | | | | | | # 24.5.21 IADC\_SCANFIFODATA - Scan FIFO Read Data | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x084 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 0×0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | DATA | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | ame Reset Access | | Description | | | | | | | | | | |------|-----------------------------------------------------|------------------|------|-------------|--|--|--|--|--|--|--|--|--| | 31:0 | DATA | 0x0 | R(r) | Data | | | | | | | | | | | | Reads and pops the oldest value from the scan FIFO. | | | | | | | | | | | | | # 24.5.22 IADC\_SCANFIFOSTAT - Scan FIFO Status | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|----|---|----|----|---|---|---|---|---|---|---|---|---|---|-------------|---| | 0x088 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | ' | | • | • | | | | | | ' | • | ' | | | • | | | | • | ' | | ' | ' | | | | 0x0 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u>~</u> | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | FIFOREADCNT | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|--------------------------------------------|--------------------|-------------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:3 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 2:0 | FIFOREADCNT | 0x0 | R | FIFO Read Count | | | | | | | | | | | | Number of valid entries available to read. | | | | | | | | | | | | | # 24.5.23 IADC\_SCANDATA - Scan Data | Offset | Bit Position | | | | | | | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x08C | 33 34 35 36 37 38 38 39 30 31 32 33 34 35 36 37 38 47 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 | | | | | | | | | | | | | Reset | OXO | | | | | | | | | | | | | Access | α | | | | | | | | | | | | | Name | DATA | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------------|--|--|--|--|--|--|--|--|--| | 31:0 | DATA | 0x0 | R | Data | | | | | | | | | | | | 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. | | | | | | | | | | | | | # 24.5.24 IADC\_SINGLE - Single Queue Port Selection | Offset | Bit Position | | | | | | | | | | | | | | |--------|----------------------------------------------------------------------------------------------------------|------------------------------------------|---------|-------------|--------|--|--|--|--|--|--|--|--|--| | 0x098 | 33<br>33<br>34<br>35<br>36<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37<br>37 | 17 17 17 17 17 17 17 17 17 17 17 17 17 1 | 1 8 0 7 | , 0 r 4 r c | 1 - 0 | | | | | | | | | | | Reset | | 000 000 000 | 0x0 | 000 | 0x0 | | | | | | | | | | | Access | | W W W | RW | RW | S<br>S | | | | | | | | | | | Name | | CFG PORTPOS | PINPOS | PORTNEG | PINNEG | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|--------------------|------------------------------------------------------------------------| | 31:18 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 17 | CMP | 0x0 | RW | Comparison Enable | | | Enable digital window of | comparison fo | r this entry. | | | 16 | CFG | 0x0 | RW | Configuration Group Select | | | Select which configurat | ion group (CF | FGx, SCALEx, SC | CHEDx 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 | Positive Port Select | | | Port (A, B, C, D) or spe | cial signal ass | signed to the posi | tve input of the ADC | | | Value | Mode | | Description | | | 0 | GND | | Ground | | | 1 | SUPPLY | | Supply Pin - Select specific supply using PINPOS | | | 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 | Positive Pin Select | | | Pin number for the pos | itive input of th | he ADC. | | | 7:4 | PORTNEG | 0x0 | RW | Negative Port Select | | | Port (A, B, C, D) or spe | cial signal ass | signed to the nega | ative input of the ADC | | | Value | Mode | | Description | | | 0 | GND | | Ground (single-ended) | | | 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 | | | | | | | | Bit | Name | Reset | Access | Description | | |-----|--------------------|-------------------|------------|-----------------------------------------|--| | | 11 | PORTD | | Port D - Select pin number using PINNEG | | | 3:0 | PINNEG | 0x0 | RW | Negative Pin Select | | | | Pin number for the | negative input of | f the ADC. | | | # 24.5.25 IADC\_SCANx - SCAN Entry | Offset | Bit Position | | | | | | |--------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|--|--| | 0x0A0 | 25 25 27 28 39 39 31 45 55 55 55 55 55 55 55 55 55 55 55 55 | 7 10 10 11 12 13 14 15 15 17 17 18 19 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 11 10 8 8 7 9 4 | 0 1 2 3 | | | | Reset | | 000 000 | 000 | 0x0 | | | | Access | | RW RW | RW RW | A<br>W | | | | Name | | CFG PORTPOS | PINPOS | PINNEG | | | | 31:18 Reserved To ensure compatibility with future devices, always write ventions 17 CMP 0x0 RW Comparison Enable Enable digital window comparison for this entry. 16 CFG 0x0 RW Configuration Group Se Select which configuration group (CFGx, SCALEx, SCHEDx registers) is used with Value Mode Description 0 CONFIG0 Use configuration group 1 15:12 PORTPOS 0x0 RW Positive Port Select 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 specifications | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------| | Enable digital window comparison for this entry. 16 | te bits to 0. More information in 1.2 Con- | | 16 CFG 0x0 RW Configuration Group Se Select which configuration group (CFGx, SCALEx, SCHEDx registers) is used with Value Mode Description 0 CONFIG0 Use configuration group 0 1 CONFIG1 Use configuration group 1 15:12 PORTPOS 0x0 RW Positive Port Select Port (A, B, C, D) or special signal assigned to the positive input of the ADC Value Mode Description 0 GND Ground | | | Select which configuration group (CFGx, SCALEx, SCHEDx registers) is used with Value Mode Description 0 CONFIG0 Use configuration group 0 1 CONFIG1 Use configuration group 1 15:12 PORTPOS 0x0 RW Positive Port Select Port (A, B, C, D) or special signal assigned to the positive input of the ADC Value Mode Description 0 GND Ground | | | Value Mode Description 0 CONFIG0 Use configuration group 0 1 CONFIG1 Use configuration group 1 15:12 PORTPOS 0x0 RW Positive Port Select Port (A, B, C, D) or special signal assigned to the positive input of the ADC Value Mode Description 0 GND Ground | lect | | 0 CONFIG0 Use configuration group 0 1 CONFIG1 Use configuration group 1 15:12 PORTPOS 0x0 RW Positive Port Select Port (A, B, C, D) or special signal assigned to the positive input of the ADC Value Mode Description 0 GND Ground | th this entry. | | 1 CONFIG1 Use configuration group 1 15:12 PORTPOS 0x0 RW Positive Port Select Port (A, B, C, D) or special signal assigned to the positive input of the ADC Value Mode Description 0 GND Ground | | | 15:12 PORTPOS 0x0 RW Positive Port Select Port (A, B, C, D) or special signal assigned to the positive input of the ADC Value Mode Description 0 GND Ground | | | Port (A, B, C, D) or special signal assigned to the positive input of the ADC Value Mode Description 0 GND Ground | | | ValueModeDescription0GNDGround | | | 0 GND Ground | | | | | | 1 SLIPPLY Sunnly Pin - Select specif | | | 1 Out I The Output I II - Output I III I | ic supply using PINPOS | | 8 PORTA Port A - Select pin number | r using PINPOS | | 9 PORTB Port B - Select pin number | r using PINPOS | | 10 PORTC Port C - Select pin number | er using PINPOS | | 11 PORTD Port D - Select pin number | er using PINPOS | | 11:8 PINPOS 0x0 RW Positive Pin Select | | | Pin number for the positive input of the ADC. | | | 7:4 PORTNEG 0x0 RW Negative Port Select | | | Port (A, B, C, D) or special signal assigned to the negative input of the ADC | | | Value Mode Description | | | 0 GND Ground (single-ended) | | | 8 PORTA Port A - Select pin number | r using PINNEG | | 9 PORTB Port B - Select pin number | DININEO | | 10 PORTC Port C - Select pin number | r using PINNEG | | Bit | Name | Reset | Access | Description | |-----|--------------------|-------------------|----------|-----------------------------------------| | | 11 | PORTD | | Port D - Select pin number using PINNEG | | 3:0 | PINNEG | 0x0 | RW | Negative Pin Select | | | Pin number for the | negative input of | the ADC. | | ## 25. GPIO - General Purpose Input/Output #### **Quick Facts** ### What? The General Purpose Input/Output (GPIO) is used for pin configuration, direct pin manipulation, and sensing, 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. ## 25.1 Introduction In the EFR32xG22 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. ### 25.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 - · 2 Interrupt lines using either levels or edges - EM4 wake-up pins are selectable for level interrupts - · All GPIO pins are selectable for edge interrupts - · Separate enable, status, set and clear registers - · Asynchronous sensing - · Rising, falling or both edges - · High or low level detection - Wake up from EM1-EM3 - · Peripheral Reflex System producer - · All GPIO pins are selectable ### 25.3 Functional Description An overview of the GPIO module is shown in Figure 25.1 Pin Configuration on page 779. 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 25.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 25.1. Pin Configuration ## 25.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,..7) which control pins 0-7, while GPIO\_Px\_MODEH contains 8 bit fields named MODEn (n=8,9,..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 25.1 Pin Configuration on page 780 shows the available configurations. Table 25.1. Pin Configuration | MODEn | Input | Output | DOUT | Pull-<br>down | Pull-<br>up | Alt Port<br>Ctrl | Input<br>Filter | Description | |-------------------------|------------------|--------------------------|------|---------------|-------------|------------------|-----------------|-------------------------------------------------------------------| | DISABLED | Disabled | Disabled | 0 | | | | | Input disabled | | | | | 1 | | On | | | Input disabled with pull-up | | INPUT | Enabled | | 0 | | | | | Input enabled | | | if not<br>DINDIS | | 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-<br>down and filter | | | | | 1 | | On | | On | Input enabled with pull-up and filter | | PUSHPULL | | Push- | х | | | | | Push-pull | | PUSHPULLALT | | pull | х | | | On | | Push-pull with alternate port control values | | WIREDOR | | Open | х | | | | | Open-source | | WIREDORPULLDOWN | | Source<br>(Wired-<br>OR) | х | On | | | | Open-source with pull-down | | WIREDAND | | Open | х | | | | | Open-drain | | WIREDANDFILTER | | Drain<br>(Wired- | х | | | | On | Open-drain with filter | | WIREDANDPULLUP | | AND) | х | | On | | | Open-drain with pull-up | | WIREDANDPULLUPFILTER | | | х | | On | | On | Open-drain with pull-up and filter | | WIREDANDALT | | | х | | | On | | Open-drain with alternate port control values | | WIREDANDALTFILTER | | | х | | | 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 | | | х | | 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 25.2 Tristated Output with Optional Pull-up or Pull-down on page 781. Figure 25.2. Tristated Output with Optional Pull-up or Pull-down When MODEn is PUSHPULL or PUSHPULLALT, 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 25.3 Push-Pull Configuration on page 781. Figure 25.3. Push-Pull Configuration When MODEn is WIREDOR or WIREDORPULLDOWN, the pin operates in open-source mode (with a pull-down resistor for WIREDORPULLDOWN). When driving a high value in open-source mode, the pull-down is disconnected to save power. When the mode is prefixed with WIREDAND, the pin operates in open-drain mode as shown in Figure 25.4 Open-drain on page 781. 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 25.4. Open-drain #### 25.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. ### 25.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. ## 25.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 DINDISALT. ## 25.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. ### 25.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. ### 25.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. ## 25.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\_EXTILEVEL register. Figure 25.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\_IFC bit, which clears 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. ## 25.3.9 Debug Connections ## 25.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 DEBUGROUTEPEN to 0. ## 25.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\_DEBUGROUTEPEN to 0. The Serial Wire Viewer pin, SWV, can be enabled by setting the SWVPEN bit in GPIO\_TRACEROUTEPEN. ### 25.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\_DBGROUTEPEN register can only be updated when the debugger is disconnected from the system. Any attempts to modify GPIO\_DBGROUTEPEN 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. #### 25.3.9.4 ETM Trace Connections There is a single trace pin available on the device. One trace clock which can be enabled by setting the TRACECLKPEN bit-field in GPIO\_TRACEROUTEPEN. The data pin can be enabled individually by setting TRACEDATA0PEN 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 SW Debug port signals. ## 25.3.10 Interrupt Generation ## 25.3.10.1 Edge Interrupt Generation The GPIO can generate an interrupt from any edge of the input of any GPIO pin on the device. The edge interrupts have asynchronous sense capability, enabling wake-up from energy modes as low as EM3, see Figure 25.6 Pin n Interrupt Generation on page 784. **Note:** In EM2 and EM3, only pins on Port A and Port B are available for edge interrupts. All pins are available for edge interrupts in EM0 and EM1. Figure 25.6. Pin n Interrupt Generation The 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\_IFS and GPIO\_IFC registers. 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. ## 25.3.10.2 Level Interrupt Generation on EM4WU Pins In addition to being an EM4 wake source, any of the EM4WU (EM4 wake-up) pins on the device may be used to generate level-sensitive interrupts in EM0, EM1, EM2, and EM3. In order to enable the level interrupt, set the EM4WUIENn field in the GPIO\_IEN register and the EM4WUENn field in the EM4WUEN register. The EM4WUPOLn field in the GPIO\_EM4WUPOL register is used to set the desired polarity for the interrupt. Upon a level 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\_EXTILEVEL and EM4WU[8] in GPIO\_IEN, the interrupt flag EM4WU[8] in GPIO\_IF will be triggered by a high level on pin EM4WU8 and a interrupt request will be sent on IRQ\_GPIO\_EVEN. The wake-up granularity of the level 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 25.2 Level Interrupt Energy Mode Wakeup on page 785). EM4WUENn in **EM4WUIENn in GPIO IEN Energy Mode Wakeup** Interrupt **GPIO\_EM4WUEN** 0 No Wake X No Interrupt 1 Wake from EM4 n No Interrupt 1 1 Wake from EM1, EM2, EM3, or Interrupt from EM0, EM1, EM2, EM4 or EM3 Table 25.2. Level Interrupt Energy Mode Wakeup For example, to configure the device to wake up and generate an interrupt when PD02 (EM4WU9) is logic low: - 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 logic low level 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. ## **25.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 25.3.10 Interrupt Generation for an illustration of where the PRS output signal is generated. ## 25.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 hardwired 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 25.3.12.1 Digital Bus (DBUS) which allows for extremely flexible resource placement. Analog route-able resources are connected to pins though the 25.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. ## 25.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 25.7 Digital Bus Interconnect on page 786. There are two DBUSes on the EFR32xG22 - one serving ports A and B and the other 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. 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 TX resource of USART1 to PB3, set PORT to 0x1 and PIN to 0x3 in GPIO\_USART1\_TXROUTE. Then set the GPIO\_USART1\_ROUTEN.TXEN bit. Any pin connected to a digital resource should be properly configured for that resource. For example USART1 TX should be configured as push-pull and USART1 RX should be configured as an input. Figure 25.7. Digital Bus Interconnect ## 25.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 EFR32xG22: 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. 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 25.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. ## 25.3.12.3 Pin Function Tables This section details the functions and GPIO pins available on the most fully-featured devices in the EFR32xG22 family. Availability of GPIO may vary on smaller packages. Refer to the device datasheet for specific peripheral and GPIO availability. Fixed-pin peripheral resources are shown in Table 25.3 GPIO Fixed Pin Function Table on page 787, ABUS routing options are listed in Table 25.4 ABUS Routing Table on page 787, and DBUS routing options are listed in Table 25.5 DBUS Routing Table on page 787 **Table 25.3. GPIO Fixed Pin Function Table** | GPIO | | | Alternate Function | | |------|---------------|----------------|----------------------|--| | PC00 | GPIO.EM4WU6 | GPIO.THMSW_EN | | | | PC05 | GPIO.EM4WU7 | | | | | PC07 | GPIO.EM4WU8 | | | | | PB03 | GPIO.EM4WU4 | | | | | PB01 | GPIO.EM4WU3 | | | | | PB00 | IADC0.VREFN | | | | | PA00 | IADC0.VREFP | | | | | PA01 | GPIO.SWCLK | | | | | PA02 | GPIO.SWDIO | | | | | PA03 | GPIO.SWV | GPIO.TDO | GPIO.TRACEDA-<br>TA0 | | | PA04 | GPIO.TDI | GPIO.TRACECLK | | | | PA05 | GPIO.EM4WU0 | | | | | PD02 | GPIO.EM4WU9 | | | | | PD01 | LFXO.LFXTAL_I | LFXO.LF_EXTCLK | | | | PD00 | LFXO.LFXTAL_O | | | | Table 25.4. ABUS Routing Table | Peripheral | Signal | Р | Α | Р | В | Р | С | Р | D | |------------|---------|------|-----|------|-----|------|-----|------|-----| | | | EVEN | ODD | EVEN | ODD | EVEN | ODD | EVEN | ODD | | IADC0 | ana_neg | Yes | | ana_pos | Yes Table 25.5. DBUS Routing Table | Peripheral.Resource | PORT | | | | | | |---------------------|-----------|-----------|-----------|-----------|--|--| | | PA | РВ | PC | PD | | | | CMU.CLKIN0 | | | Available | Available | | | | CMU.CLKOUT0 | | | Available | Available | | | | CMU.CLKOUT1 | | | Available | Available | | | | CMU.CLKOUT2 | Available | Available | | | | | | Peripheral.Resource | | PC | DRT | | |---------------------|-----------|-----------|-----------|-----------| | | PA | РВ | PC | PD | | EUART0.CTS | Available | Available | Available | Available | | EUART0.RTS | Available | Available | Available | Available | | EUART0.RX | Available | Available | Available | Available | | EUART0.TX | Available | Available | Available | Available | | FRC.DCLK | | | Available | Available | | FRC.DFRAME | | | Available | Available | | FRC.DOUT | | | Available | Available | | I2C0.SCL | Available | Available | Available | Available | | I2C0.SDA | Available | Available | Available | Available | | I2C1.SCL | | | Available | Available | | I2C1.SDA | | | 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 | | | | PDM.CLK | Available | Available | Available | Available | | PDM.DAT0 | Available | Available | Available | Available | | PDM.DAT1 | Available | Available | Available | Available | | PRS.ASYNCH0 | Available | Available | | | | PRS.ASYNCH1 | Available | Available | | | | PRS.ASYNCH10 | | | Available | Available | | PRS.ASYNCH11 | | | Available | Available | | Peripheral.Resource | | PC | PRT | | |---------------------|-----------|-----------|-----------|-----------| | | PA | РВ | PC | PD | | PRS.ASYNCH2 | Available | Available | | | | PRS.ASYNCH3 | Available | Available | | | | 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 | | 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 | РВ | 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 | | | | | | USARTO.CS | Available | Available | Available | Available | | | | | | USARTO.CTS | Available | Available | Available | Available | | | | | | USART0.RTS | Available | Available | Available | Available | | | | | | USART0.RX | Available | Available | Available | Available | | | | | | USART0.TX | Available | Available | Available | Available | | | | | | USART1.CLK | Available | Available | | | | | | | | USART1.CS | Available | Available | | | | | | | | USART1.CTS | Available | Available | | | | | | | | USART1.RTS | Available | Available | | | | | | | | USART1.RX | Available | Available | | | | | | | | USART1.TX | Available | Available | | | | | | | ## 25.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 these HFBUSCLK. Consequently, when a pin changes state, the change will propagate to GPIO\_Px\_DIN after two 2 HFBUSCLK cycles. Synchronization (also running on the HFBUSCLK) is also added for interrupt input. To save power when the external interrupts or level interrupts are not used, the synchronization flip-flops for these can be turned off by clearing the EXTINT field in the GPIO\_IEN register. # 25.5 GPIO Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|---------------------|-------------|-----------------------------------------| | 0x000 | GPIO_PORTA_CTRL | RW | Port control | | 0x004 | GPIO_PORTA_MODEL | RW | mode low | | 0x00C | GPIO_PORTA_MODEH | RW | mode high | | 0x010 | GPIO_PORTA_DOUT | RW | data out | | 0x014 | GPIO_PORTA_DIN | RH | data in | | 0x030 | GPIO_PORTB_CTRL | RW | Port control | | 0x034 | GPIO_PORTB_MODEL | RW | mode low | | 0x040 | GPIO_PORTB_DOUT | RW | data out | | 0x044 | GPIO_PORTB_DIN | RH | data in | | 0x060 | GPIO_PORTC_CTRL | RW | Port control | | 0x064 | GPIO_PORTC_MODEL | RW | mode low | | 0x070 | GPIO_PORTC_DOUT | RW | data out | | 0x074 | GPIO_PORTC_DIN | RH | data in | | 0x090 | GPIO_PORTD_CTRL | RW | Port control | | 0x094 | GPIO_PORTD_MODEL | RW | mode low | | 0x0A0 | GPIO_PORTD_DOUT | RW | data out | | 0x0A4 | GPIO_PORTD_DIN | RH | data in | | 0x300 | GPIO_LOCK | W | Lock Register | | 0x310 | GPIO_GPIOLOCKSTATUS | RH | Lock Status | | 0x320 | GPIO_ABUSALLOC | RW | A Bus allocation | | 0x324 | GPIO_BBUSALLOC | RW | B Bus allocation | | 0x328 | GPIO_CDBUSALLOC | RW | CD Bus allocation | | 0x400 | GPIO_EXTIPSELL | RW | External Interrupt Port Select Low | | 0x404 | GPIO_EXTIPSELH | RW | External interrupt Port Select High | | 0x408 | GPIO_EXTIPINSELL | RW | External Interrupt Pin Select Low | | 0x40C | GPIO_EXTIPINSELH | RW | External Interrupt Pin Select High | | 0x410 | GPIO_EXTIRISE | RW | External Interrupt Rising Edge Trigger | | 0x414 | GPIO_EXTIFALL | RW | External Interrupt Falling Edge Trigger | | 0x420 | GPIO_IF | RWH INTFLAG | Interrupt Flag | | 0x424 | GPIO_IEN | RW | Interrupt Enable | | 0x42C | GPIO_EM4WUEN | RW | EM4 wakeup enable | | 0x430 | GPIO_EM4WUPOL | RW | EM4 wakeup polarity | | 0x440 | GPIO_DBGROUTEPEN | RW | Debugger Route Pin enable | | 0x444 | GPIO_TRACEROUTEPEN | RW | Trace Route Pin Enable | | 0x450 | GPIO_CMU_ROUTEEN | RW | CMU pin enable | | Offset | Name | Туре | Description | |--------|----------------------------------|------|-----------------------------| | 0x454 | GPIO_CMU_CLKIN0ROUTE | RW | CLKIN0 port/pin select | | 0x458 | GPIO_CMU_CLKOUT0ROUTE | RW | CLKOUT0 port/pin select | | 0x45C | GPIO_CMU_CLKOUT1ROUTE | RW | CLKOUT1 port/pin select | | 0x460 | GPIO_CMU_CLKOUT2ROUTE | RW | CLKOUT2 port/pin select | | 0x46C | GPIO_DCDC_ROUTEEN | RW | DCDC pin enable | | 0x47C | GPIO_FRC_ROUTEEN | RW | FRC pin enable | | 0x480 | GPIO_FRC_DCLKROUTE | RW | DCLK port/pin select | | 0x484 | GPIO_FRC_DFRAMEROUTE | RW | DFRAME port/pin select | | 0x488 | GPIO_FRC_DOUTROUTE | RW | DOUT port/pin select | | 0x490 | GPIO_I2C0_ROUTEEN | RW | I2C0 pin enable | | 0x494 | GPIO_I2C0_SCLROUTE | RW | SCL port/pin select | | 0x498 | GPIO_I2C0_SDAROUTE | RW | SDA port/pin select | | 0x4A0 | GPIO_I2C1_ROUTEEN | RW | I2C1 pin enable | | 0x4A4 | GPIO_I2C1_SCLROUTE | RW | SCL port/pin select | | 0x4A8 | GPIO_I2C1_SDAROUTE | RW | SDA port/pin select | | 0x4B0 | GPIO_LETIMER0_ROUTEEN | RW | LETIMER pin enable | | 0x4B4 | GPIO_LETIMER0_OUT0ROUTE | RW | OUT0 port/pin select | | 0x4B8 | GPIO_LETIMER0_OUT1ROUTE | RW | OUT1 port/pin select | | 0x4C0 | GPIO_EUART0_ROUTEEN | RW | EUART pin enable | | 0x4C4 | GPIO_EUART0_CTSROUTE | RW | CTS port/pin select | | 0x4C8 | GPIO_EUART0_RTSROUTE | RW | RTS port/pin select | | 0x4CC | GPIO_EUART0_RXROUTE | RW | RX port/pin select | | 0x4D0 | GPIO_EUART0_TXROUTE | RW | TX port/pin select | | 0x4D8 | GPIO_MODEM_ROUTEEN | RW | MODEM pin enable | | 0x4DC | GPIO_MODEM_ANTOROUTE | RW | ANT0 port/pin select | | 0x4E0 | GPIO_MODEM_ANT1ROUTE | RW | ANT1 port/pin select | | 0x4E4 | GPIO_MODEM_ANTROLLO-<br>VERROUTE | RW | ANTROLLOVER port/pin select | | 0x4E8 | GPIO_MO-<br>DEM_ANTRR0ROUTE | RW | ANTRR0 port/pin select | | 0x4EC | GPIO_MO-<br>DEM_ANTRR1ROUTE | RW | ANTRR1 port/pin select | | 0x4F0 | GPIO_MO-<br>DEM_ANTRR2ROUTE | RW | ANTRR2 port/pin select | | 0x4F4 | GPIO_MO-<br>DEM_ANTRR3ROUTE | RW | ANTRR3 port/pin select | | 0x4F8 | GPIO_MO-<br>DEM_ANTRR4ROUTE | RW | ANTRR4 port/pin select | | 0x4FC | GPIO_MO-<br>DEM_ANTRR5ROUTE | RW | ANTRR5 port/pin select | | 0x5000 GPIO_MODEM_ANTSWEN-ROUTE RW ANTSWEN port/pin select 0x504 GPIO_MODEM_ANTSWUS-ROUTE RW ANTTRIG port/pin select 0x506 GPIO_MODEM_ANTTRIG-ROUTE RW ANTTRIG port/pin select 0x507 GPIO_MODEM_DCLKROUTE RW DCLK port/pin select 0x510 GPIO_MODEM_DCLKROUTE RW DCLK port/pin select 0x514 GPIO_MODEM_DCLKROUTE RW DIN port/pin select 0x518 GPIO_MODEM_DOUTROUTE RW DOUT port/pin select 0x524 GPIO_PDM_CLKROUTE RW DAT0 port/pin select 0x524 GPIO_PDM_DATROUTE RW DAT1 port/pin select 0x524 GPIO_PDM_DATROUTE RW DAT1 port/pin select 0x525 GPIO_PDM_DATROUTE RW DAT1 port/pin select 0x526 GPIO_PRSD_ROUTEN RW PRS0 pin enable 0x533 GPIO_PRSD_ASYNCHROUTE RW ASYNCH0 port/pin select 0x544 GPIO_PRSD_ASYNCHROUTE RW ASYNCH2 port/pin select 0x545 GPIO_PRSD_ASYNCHROUTE RW A | Offset | Name | Туре | Description | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------|------|-----------------------------| | NOUTE RW ANTTRIG port/pin select 0x500 RODEM_ANTTRIG-RW ANTTRIG port/pin select 0x500 GPIO_MODEM_ANTTRIGSTOP-RW ANTTRIGSTOP port/pin select 0x510 GFIO_MODEM_DCLKROUTE RW DCLK port/pin select 0x514 GPIO_MODEM_DINROUTE RW DIN port/pin select 0x520 GPIO_PDM_COLTROUTE RW DOUT port/pin select 0x524 GPIO_PDM_CAROUTE RW DATO port/pin select 0x524 GPIO_PDM_DATROUTE RW DATO port/pin select 0x524 GPIO_PDM_DATROUTE RW DATO port/pin select 0x524 GPIO_PRSO_ASYNCHEROUTE RW DATO port/pin select 0x524 GPIO_PRSO_ASYNCHEROUTE RW ASYNCH0 port/pin select 0x534 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH2 port/pin select 0x540 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH2 port/pin select 0x540 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x544 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH0 port/pin select 0x54 | 0x500 | | RW | ANTSWEN port/pin select | | National | 0x504 | | RW | ANTSWUS port/pin select | | ROUTE | 0x508 | | RW | ANTTRIG port/pin select | | 0x514 GPIO_MODEM_DINROUTE RW DIN port/pin select 0x518 GPIO_MODEM_DOUTROUTE RW DOUT port/pin select 0x520 GPIO_PDM_ROUTEEN RW PDM pin enable 0x524 GPIO_PDM_CLKROUTE RW CLK port/pin select 0x528 GPIO_PDM_DATOROUTE RW DATO port/pin select 0x526 GPIO_PDM_DATIROUTE RW DAT1 port/pin select 0x534 GPIO_PRSO_ASYNCHEN RW PRSO pin enable 0x536 GPIO_PRSO_ASYNCHIROUTE RW ASYNCH0 port/pin select 0x537 GPIO_PRSO_ASYNCHIROUTE RW ASYNCH1 port/pin select 0x540 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x544 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH4 port/pin select 0x548 GPIO_PRSO_ASYNCH6ROUTE RW ASYNCH5 port/pin select 0x550 GPIO_PRSO_ASYNCH7ROUTE RW ASYNCH6 port/pin select 0x554 GPIO_PRSO_ASYNCH8ROUTE RW ASYNCH9 port/pin select 0x556 GPIO_PRSO_ASYNCH9ROUTE RW | 0x50C | | RW | ANTTRIGSTOP port/pin select | | 0x518 GPIO_MODEM_DOUTROUTE RW DOUT port/pin select 0x520 GPIO_PDM_ROUTEEN RW PDM pin enable 0x524 GPIO_PDM_CLKROUTE RW CLK port/pin select 0x528 GPIO_PDM_DATOROUTE RW DATO port/pin select 0x520 GPIO_PDM_DATIROUTE RW DAT1 port/pin select 0x534 GPIO_PRSO_ASYNCHOROUTE RW ASYNCH0 port/pin select 0x538 GPIO_PRSO_ASYNCHOROUTE RW ASYNCH1 port/pin select 0x540 GPIO_PRSO_ASYNCHOROUTE RW ASYNCH2 port/pin select 0x541 GPIO_PRSO_ASYNCHAROUTE RW ASYNCH3 port/pin select 0x542 GPIO_PRSO_ASYNCHAROUTE RW ASYNCH4 port/pin select 0x543 GPIO_PRSO_ASYNCHGROUTE RW ASYNCH6 port/pin select 0x544 GPIO_PRSO_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x550 GPIO_PRSO_ASYNCH6ROUTE RW ASYNCH9 port/pin select 0x554 GPIO_PRSO_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x556 GPIO_PRSO_ASYNCH0ROUTE R | 0x510 | GPIO_MODEM_DCLKROUTE | RW | DCLK port/pin select | | 0x520 GPIO_PDM_ROUTEEN RW PDM pin enable 0x524 GPIO_PDM_CLKROUTE RW CLK port/pin select 0x528 GPIO_PDM_DATOROUTE RW DATO port/pin select 0x52C GPIO_PDM_DATIROUTE RW DAT1 port/pin select 0x534 GPIO_PRS0_ASYNCHOROUTE RW PRS0 pin enable 0x538 GPIO_PRS0_ASYNCHOROUTE RW ASYNCH0 port/pin select 0x540 GPIO_PRS0_ASYNCH2ROUTE RW ASYNCH2 port/pin select 0x544 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x548 GPIO_PRS0_ASYNCHAROUTE RW ASYNCH4 port/pin select 0x540 GPIO_PRS0_ASYNCHROUTE RW ASYNCH5 port/pin select 0x544 GPIO_PRS0_ASYNCHROUTE RW ASYNCH6 port/pin select 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH7 port/pin select 0x550 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUTE RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_ASYNCH0ROUTE RW </td <td>0x514</td> <td>GPIO_MODEM_DINROUTE</td> <td>RW</td> <td>DIN port/pin select</td> | 0x514 | GPIO_MODEM_DINROUTE | RW | DIN port/pin select | | 0x524 GPIO_PDM_CLKROUTE RW CLK port/pin select 0x528 GPIO_PDM_DATOROUTE RW DAT0 port/pin select 0x52C GPIO_PRD_DAT1ROUTE RW DAT1 port/pin select 0x534 GPIO_PRS0_ROUTEEN RW PRS0 pin enable 0x538 GPIO_PRS0_ASYNCHOROUTE RW ASYNCH0 port/pin select 0x540 GPIO_PRS0_ASYNCH2ROUTE RW ASYNCH1 port/pin select 0x544 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x548 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH4 port/pin select 0x540 GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH5 port/pin select 0x544 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH7 port/pin select 0x554 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select 0x556 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH1ROUTE RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_SYNCH2ROUTE | 0x518 | GPIO_MODEM_DOUTROUTE | RW | DOUT port/pin select | | 0x528 GPIO_PDM_DATOROUTE RW DATO port/pin select 0x52C GPIO_PDM_DAT1ROUTE RW DAT1 port/pin select 0x534 GPIO_PRS0_ROUTEEN RW PRS0 pin enable 0x538 GPIO_PRS0_ASYNCH0ROUTE RW ASYNCH0 port/pin select 0x540 GPIO_PRS0_ASYNCH2ROUTE RW ASYNCH1 port/pin select 0x544 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x548 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH4 port/pin select 0x540 GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH4 port/pin select 0x544 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH9 port/pin select 0x554 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH9 port/pin select 0x556 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x565 GPIO_PRS0_ASYNCH10ROUTE RW ASYNCH10 port/pin select 0x566 GPIO_PRS0_ASYNCH10ROUTE RW SYNCH10 port/pin select 0x568 GPIO_PRS0_SYNCH2ROUTE< | 0x520 | GPIO_PDM_ROUTEEN | RW | PDM pin enable | | 0x52C GPIO_PDM_DATIROUTE RW DAT1 port/pin select 0x534 GPIO_PRSO_ROUTEEN RW PRSO pin enable 0x538 GPIO_PRSO_ASYNCHOROUTE RW ASYNCH0 port/pin select 0x530 GPIO_PRSO_ASYNCH2ROUTE RW ASYNCH2 port/pin select 0x540 GPIO_PRSO_ASYNCH2ROUTE RW ASYNCH2 port/pin select 0x544 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x546 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x547 GPIO_PRSO_ASYNCH3ROUTE RW ASYNCH5 port/pin select 0x548 GPIO_PRSO_ASYNCH5ROUTE RW ASYNCH6 port/pin select 0x540 GPIO_PRSO_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x550 GPIO_PRSO_ASYNCH7ROUTE RW ASYNCH8 port/pin select 0x554 GPIO_PRSO_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x555 GPIO_PRSO_ASYNCH9ROUTE RW ASYNCH10 port/pin select 0x566 GPIO_PRSO_ASYNCH11ROUT RW ASYNCH10 port/pin select 0x568 GPIO_PRSO_SYNCH2 | 0x524 | GPIO_PDM_CLKROUTE | RW | CLK port/pin select | | 0x534 GPIO_PRS0_ROUTEEN RW PRS0 pin enable 0x538 GPIO_PRS0_ASYNCH0ROUTE RW ASYNCH0 port/pin select 0x53C GPIO_PRS0_ASYNCH1ROUTE RW ASYNCH1 port/pin select 0x540 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH2 port/pin select 0x544 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH3 port/pin select 0x548 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH5 port/pin select 0x54C GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH5 port/pin select 0x560 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH5 port/pin select 0x554 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH9 port/pin select 0x558 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUTE RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_ASYNCH1ROUTE RW ASYNCH10 port/pin select 0x566 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select 0x566 GPIO_PRS0_SYNCH3ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SY | 0x528 | GPIO_PDM_DAT0ROUTE | RW | DAT0 port/pin select | | Ox538 GPIO_PRS0_ASYNCH0ROUTE RW ASYNCH0 port/pin select Ox53C GPIO_PRS0_ASYNCH1ROUTE RW ASYNCH1 port/pin select Ox540 GPIO_PRS0_ASYNCH2ROUTE RW ASYNCH2 port/pin select Ox544 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH3 port/pin select Ox548 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH4 port/pin select Ox540 GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH4 port/pin select Ox540 GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH5 port/pin select Ox550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select Ox554 GPIO_PRS0_ASYNCH7ROUTE RW ASYNCH7 port/pin select Ox556 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select Ox550 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select Ox550 GPIO_PRS0_ASYNCH10ROUTE RW ASYNCH10 port/pin select Ox560 GPIO_PRS0_ASYNCH10ROUTE RW ASYNCH10 port/pin select Ox560 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select Ox564 GPIO_PRS0_SYNCH0ROUTE RW SYNCH1 port/pin select Ox565 GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select Ox560 GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select Ox560 GPIO_PRS0_SYNCH1ROUTE RW SYNCH2 port/pin select Ox560 GPIO_PRS0_SYNCH3ROUTE RW SYNCH2 port/pin select Ox570 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select Ox570 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select Ox570 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select Ox570 GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable Ox580 GPIO_TIMER0_CCOROUTE RW CC0 port/pin select Ox584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select Ox588 GPIO_TIMER0_CC1ROUTE RW CC2 port/pin select | 0x52C | GPIO_PDM_DAT1ROUTE | RW | DAT1 port/pin select | | 0x53C GPIO_PRS0_ASYNCH1ROUTE RW ASYNCH1 port/pin select 0x540 GPIO_PRS0_ASYNCH2ROUTE RW ASYNCH2 port/pin select 0x544 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x548 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH4 port/pin select 0x54C GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH5 port/pin select 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x554 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH8 port/pin select 0x556 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUT RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_ASYNCH1ROUTE RW ASYNCH1 port/pin select 0x568 GPIO_PRS0_SYNCH2ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x571 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x572 GPIO_TIMERO_ROUTEEN RW TIMERO pin enable 0x580 GPIO_TIMERO_CCOROUTE RW CC0 port/pin select 0x584 | 0x534 | GPIO_PRS0_ROUTEEN | RW | PRS0 pin enable | | 0x540 GPIO_PRS0_ASYNCH2ROUTE RW ASYNCH2 port/pin select 0x544 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x548 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH4 port/pin select 0x550 GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH6 port/pin select 0x554 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x554 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select 0x555 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x556 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH10 port/pin select 0x560 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select 0x564 GPIO_PRS0_ASYNCH11ROUTE RW SYNCH0 port/pin select 0x566 GPIO_PRS0_SYNCHROUTE RW SYNCH1 port/pin select 0x567 GPIO_PRS0_SYNCH2ROUTE RW SYNCH1 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH2 port/pin select 0x576 GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CCOROUTE RW CC0 port/pin select 0x584 | 0x538 | GPIO_PRS0_ASYNCH0ROUTE | RW | ASYNCH0 port/pin select | | 0x544 GPIO_PRS0_ASYNCH3ROUTE RW ASYNCH3 port/pin select 0x548 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH4 port/pin select 0x54C GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH6 port/pin select 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH7 port/pin select 0x554 GPIO_PRS0_ASYNCH7ROUTE RW ASYNCH8 port/pin select 0x558 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH9 port/pin select 0x55C GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH10 port/pin select 0x560 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select 0x564 GPIO_PRS0_ASYNCH11ROUTE RW SYNCH0 port/pin select 0x565 GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x566 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x570 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW TIMER0 pin enable 0x580 GPIO_TIMER0_CCOROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 | 0x53C | GPIO_PRS0_ASYNCH1ROUTE | RW | ASYNCH1 port/pin select | | 0x548 GPIO_PRS0_ASYNCH4ROUTE RW ASYNCH4 port/pin select 0x54C GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH5 port/pin select 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x554 GPIO_PRS0_ASYNCH7ROUTE RW ASYNCH8 port/pin select 0x558 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select 0x550 GPIO_PRS0_ASYNCH10ROUTE RW ASYNCH10 port/pin select 0x560 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select 0x564 GPIO_PRS0_ASYNCH0ROUTE RW SYNCH0 port/pin select 0x560 GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x560 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x570 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x574 GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CCOROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x540 | GPIO_PRS0_ASYNCH2ROUTE | RW | ASYNCH2 port/pin select | | 0x54C GPIO_PRS0_ASYNCH5ROUTE RW ASYNCH5 port/pin select 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x554 GPIO_PRS0_ASYNCH7ROUTE RW ASYNCH7 port/pin select 0x558 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select 0x55C GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH10 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUTE RW ASYNCH11 port/pin select 0x564 GPIO_PRS0_ASYNCH1ROUTE RW SYNCH0 port/pin select 0x568 GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CCOROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x544 | GPIO_PRS0_ASYNCH3ROUTE | RW | ASYNCH3 port/pin select | | 0x550 GPIO_PRS0_ASYNCH6ROUTE RW ASYNCH6 port/pin select 0x554 GPIO_PRS0_ASYNCH7ROUTE RW ASYNCH7 port/pin select 0x558 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select 0x550 GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUT RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select 0x568 GPIO_PRS0_ASYNCH11ROUT RW SYNCH0 port/pin select 0x560 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select 0x560 GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x575 GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CCOROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x548 | GPIO_PRS0_ASYNCH4ROUTE | RW | ASYNCH4 port/pin select | | 0x554 GPIO_PRS0_ASYNCH7ROUTE RW ASYNCH7 port/pin select 0x558 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select 0x55C GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUT RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select 0x568 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select 0x56C GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x575 GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC2 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x54C | GPIO_PRS0_ASYNCH5ROUTE | RW | ASYNCH5 port/pin select | | 0x558 GPIO_PRS0_ASYNCH8ROUTE RW ASYNCH8 port/pin select 0x55C GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUT RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select 0x568 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select 0x560 GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH3 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x570 GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x570 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select 0x580 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x584 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x550 | GPIO_PRS0_ASYNCH6ROUTE | RW | ASYNCH6 port/pin select | | 0x55C GPIO_PRS0_ASYNCH9ROUTE RW ASYNCH9 port/pin select 0x560 GPIO_PRS0_ASYNCH10ROUT RW ASYNCH10 port/pin select 0x564 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select 0x568 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select 0x56C GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x554 | GPIO_PRS0_ASYNCH7ROUTE | RW | ASYNCH7 port/pin select | | Ox560 GPIO_PRS0_ASYNCH10ROUT RW ASYNCH11 port/pin select Ox564 GPIO_PRS0_ASYNCH11ROUT RW SYNCH0 port/pin select Ox568 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select Ox56C GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select Ox570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select Ox574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select Ox57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable Ox580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select Ox584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select Ox588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x558 | GPIO_PRS0_ASYNCH8ROUTE | RW | ASYNCH8 port/pin select | | E Ox564 GPIO_PRS0_ASYNCH11ROUT RW ASYNCH11 port/pin select Ox568 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select Ox56C GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select Ox570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select Ox574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select Ox57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable Ox580 GPIO_TIMER0_CCOROUTE RW CC0 port/pin select Ox584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select Ox588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x55C | GPIO_PRS0_ASYNCH9ROUTE | RW | ASYNCH9 port/pin select | | E Ox568 GPIO_PRS0_SYNCH0ROUTE RW SYNCH0 port/pin select Ox56C GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select Ox570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select Ox574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select Ox57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable Ox580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select Ox584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select Ox588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x560 | | RW | ASYNCH10 port/pin select | | 0x56C GPIO_PRS0_SYNCH1ROUTE RW SYNCH1 port/pin select 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x564 | | RW | ASYNCH11 port/pin select | | 0x570 GPIO_PRS0_SYNCH2ROUTE RW SYNCH2 port/pin select 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x568 | GPIO_PRS0_SYNCH0ROUTE | RW | SYNCH0 port/pin select | | 0x574 GPIO_PRS0_SYNCH3ROUTE RW SYNCH3 port/pin select 0x57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x56C | GPIO_PRS0_SYNCH1ROUTE | RW | SYNCH1 port/pin select | | 0x57C GPIO_TIMER0_ROUTEEN RW TIMER0 pin enable 0x580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x570 | GPIO_PRS0_SYNCH2ROUTE | RW | SYNCH2 port/pin select | | 0x580 GPIO_TIMER0_CC0ROUTE RW CC0 port/pin select 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x574 | GPIO_PRS0_SYNCH3ROUTE | RW | SYNCH3 port/pin select | | 0x584 GPIO_TIMER0_CC1ROUTE RW CC1 port/pin select 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x57C | GPIO_TIMER0_ROUTEEN | RW | TIMER0 pin enable | | 0x588 GPIO_TIMER0_CC2ROUTE RW CC2 port/pin select | 0x580 | GPIO_TIMER0_CC0ROUTE | RW | CC0 port/pin select | | | 0x584 | GPIO_TIMER0_CC1ROUTE | RW | CC1 port/pin select | | 0x58C GPIO_TIMER0_CCC0ROUTE RW CCC0 port/pin select | 0x588 | GPIO_TIMER0_CC2ROUTE | RW | CC2 port/pin select | | | 0x58C | GPIO_TIMER0_CCC0ROUTE | RW | CCC0 port/pin select | | Offset | Name | Туре | Description | |--------|-----------------------|------|----------------------| | 0x590 | GPIO_TIMER0_CCC1ROUTE | RW | CCC1 port/pin select | | 0x594 | GPIO_TIMER0_CCC2ROUTE | RW | CCC2 port/pin select | | 0x59C | GPIO_TIMER1_ROUTEEN | RW | TIMER1 pin enable | | 0x5A0 | GPIO_TIMER1_CC0ROUTE | RW | CC0 port/pin select | | 0x5A4 | GPIO_TIMER1_CC1ROUTE | RW | CC1 port/pin select | | 0x5A8 | GPIO_TIMER1_CC2ROUTE | RW | CC2 port/pin select | | 0x5AC | GPIO_TIMER1_CCC0ROUTE | RW | CCC0 port/pin select | | 0x5B0 | GPIO_TIMER1_CCC1ROUTE | RW | CCC1 port/pin select | | 0x5B4 | GPIO_TIMER1_CCC2ROUTE | RW | CCC2 port/pin select | | 0x5BC | GPIO_TIMER2_ROUTEEN | RW | TIMER2 pin enable | | 0x5C0 | GPIO_TIMER2_CC0ROUTE | RW | CC0 port/pin select | | 0x5C4 | GPIO_TIMER2_CC1ROUTE | RW | CC1 port/pin select | | 0x5C8 | GPIO_TIMER2_CC2ROUTE | RW | CC2 port/pin select | | 0x5CC | GPIO_TIMER2_CCC0ROUTE | RW | CCC0 port/pin select | | 0x5D0 | GPIO_TIMER2_CCC1ROUTE | RW | CCC1 port/pin select | | 0x5D4 | GPIO_TIMER2_CCC2ROUTE | RW | CCC2 port/pin select | | 0x5DC | GPIO_TIMER3_ROUTEEN | RW | TIMER3 pin enable | | 0x5E0 | GPIO_TIMER3_CC0ROUTE | RW | CC0 port/pin select | | 0x5E4 | GPIO_TIMER3_CC1ROUTE | RW | CC1 port/pin select | | 0x5E8 | GPIO_TIMER3_CC2ROUTE | RW | CC2 port/pin select | | 0x5EC | GPIO_TIMER3_CCC0ROUTE | RW | CCC0 port/pin select | | 0x5F0 | GPIO_TIMER3_CCC1ROUTE | RW | CCC1 port/pin select | | 0x5F4 | GPIO_TIMER3_CCC2ROUTE | RW | CCC2 port/pin select | | 0x5FC | GPIO_TIMER4_ROUTEEN | RW | TIMER4 pin enable | | 0x600 | GPIO_TIMER4_CC0ROUTE | RW | CC0 port/pin select | | 0x604 | GPIO_TIMER4_CC1ROUTE | RW | CC1 port/pin select | | 0x608 | GPIO_TIMER4_CC2ROUTE | RW | CC2 port/pin select | | 0x60C | GPIO_TIMER4_CCC0ROUTE | RW | CCC0 port/pin select | | 0x610 | GPIO_TIMER4_CCC1ROUTE | RW | CCC1 port/pin select | | 0x614 | GPIO_TIMER4_CCC2ROUTE | RW | CCC2 port/pin select | | 0x61C | GPIO_USARTO_ROUTEEN | RW | USART0 pin enable | | 0x620 | GPIO_USARTO_CSROUTE | RW | CS port/pin select | | 0x624 | GPIO_USART0_CTSROUTE | RW | CTS port/pin select | | 0x628 | GPIO_USART0_RTSROUTE | RW | RTS port/pin select | | 0x62C | GPIO_USART0_RXROUTE | RW | RX port/pin select | | 0x630 | GPIO_USART0_CLKROUTE | RW | SCLK port/pin select | | 0x634 | GPIO_USART0_TXROUTE | RW | TX port/pin select | | Offset | Name | Туре | Description | |--------|-------------------------|-------------|-----------------------------------------| | 0x63C | GPIO_USART1_ROUTEEN | RW | USART1 pin enable | | 0x640 | GPIO_USART1_CSROUTE | RW | CS port/pin select | | 0x644 | GPIO_USART1_CTSROUTE | RW | CTS port/pin select | | 0x648 | GPIO_USART1_RTSROUTE | RW | RTS port/pin select | | 0x64C | GPIO_USART1_RXROUTE | RW | RX port/pin select | | 0x650 | GPIO_USART1_CLKROUTE | RW | SCLK port/pin select | | 0x654 | GPIO_USART1_TXROUTE | RW | TX port/pin select | | 0x1000 | GPIO_PORTA_CTRL_SET | RW | Port control | | 0x1004 | GPIO_PORTA_MODEL_SET | RW | mode low | | 0x100C | GPIO_PORTA_MODEH_SET | RW | mode high | | 0x1010 | GPIO_PORTA_DOUT_SET | RW | data out | | 0x1014 | GPIO_PORTA_DIN_SET | RH | data in | | 0x1030 | GPIO_PORTB_CTRL_SET | RW | Port control | | 0x1034 | GPIO_PORTB_MODEL_SET | RW | mode low | | 0x1040 | GPIO_PORTB_DOUT_SET | RW | data out | | 0x1044 | GPIO_PORTB_DIN_SET | RH | data in | | 0x1060 | GPIO_PORTC_CTRL_SET | RW | Port control | | 0x1064 | GPIO_PORTC_MODEL_SET | RW | mode low | | 0x1070 | GPIO_PORTC_DOUT_SET | RW | data out | | 0x1074 | GPIO_PORTC_DIN_SET | RH | data in | | 0x1090 | GPIO_PORTD_CTRL_SET | RW | Port control | | 0x1094 | GPIO_PORTD_MODEL_SET | RW | mode low | | 0x10A0 | GPIO_PORTD_DOUT_SET | RW | data out | | 0x10A4 | GPIO_PORTD_DIN_SET | RH | data in | | 0x1300 | GPIO_LOCK_SET | W | Lock Register | | 0x1310 | GPIO_GPIOLOCKSTATUS_SET | RH | Lock Status | | 0x1320 | GPIO_ABUSALLOC_SET | RW | A Bus allocation | | 0x1324 | GPIO_BBUSALLOC_SET | RW | B Bus allocation | | 0x1328 | GPIO_CDBUSALLOC_SET | RW | CD Bus allocation | | 0x1400 | GPIO_EXTIPSELL_SET | RW | External Interrupt Port Select Low | | 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_EXTIFALL_SET | RW | External Interrupt Falling Edge Trigger | | 0x1420 | GPIO_IF_SET | RWH INTFLAG | Interrupt Flag | | 0x1424 | GPIO_IEN_SET | RW | Interrupt Enable | | Offset | Name | Туре | Description | |--------|----------------------------------|------|---------------------------| | 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_CMU_ROUTEEN_SET | RW | CMU pin enable | | 0x1454 | GPIO_CMU_CLKIN0ROUTE_SE T | RW | CLKIN0 port/pin select | | 0x1458 | GPIO_CMU_CLKOUT0ROUTE_<br>SET | RW | CLKOUT0 port/pin select | | 0x145C | GPIO_CMU_CLKOUT1ROUTE_<br>SET | RW | CLKOUT1 port/pin select | | 0x1460 | GPIO_CMU_CLKOUT2ROUTE_<br>SET | RW | CLKOUT2 port/pin select | | 0x146C | GPIO_DCDC_ROUTEEN_SET | RW | DCDC pin enable | | 0x147C | GPIO_FRC_ROUTEEN_SET | RW | FRC pin enable | | 0x1480 | GPIO_FRC_DCLKROUTE_SET | RW | DCLK port/pin select | | 0x1484 | GPIO_FRC_DFRAME-<br>ROUTE_SET | RW | DFRAME port/pin select | | 0x1488 | GPIO_FRC_DOUTROUTE_SET | RW | DOUT port/pin select | | 0x1490 | GPIO_I2C0_ROUTEEN_SET | RW | I2C0 pin enable | | 0x1494 | GPIO_I2C0_SCLROUTE_SET | RW | SCL port/pin select | | 0x1498 | GPIO_I2C0_SDAROUTE_SET | RW | SDA port/pin select | | 0x14A0 | GPIO_I2C1_ROUTEEN_SET | RW | I2C1 pin enable | | 0x14A4 | GPIO_I2C1_SCLROUTE_SET | RW | SCL port/pin select | | 0x14A8 | GPIO_I2C1_SDAROUTE_SET | RW | SDA port/pin select | | 0x14B0 | GPIO_LETIMER0_ROU-<br>TEEN_SET | RW | LETIMER pin enable | | 0x14B4 | GPIO_LETIM-<br>ER0_OUT0ROUTE_SET | RW | OUT0 port/pin select | | 0x14B8 | GPIO_LETIM-<br>ER0_OUT1ROUTE_SET | RW | OUT1 port/pin select | | 0x14C0 | GPIO_EUART0_ROU-<br>TEEN_SET | RW | EUART pin enable | | 0x14C4 | GPIO_EU-<br>ART0_CTSROUTE_SET | RW | CTS port/pin select | | 0x14C8 | GPIO_EU-<br>ART0_RTSROUTE_SET | RW | RTS port/pin select | | 0x14CC | GPIO_EU-<br>ART0_RXROUTE_SET | RW | RX port/pin select | | 0x14D0 | GPIO_EUART0_TXROUTE_SET | RW | TX port/pin select | | 0x14D8 | GPIO_MODEM_ROUTEEN_SET | RW | MODEM pin enable | | Offset | Name | Туре | Description | |--------|--------------------------------------|------|-----------------------------| | 0x14DC | GPIO_MO-<br>DEM_ANT0ROUTE_SET | RW | ANT0 port/pin select | | 0x14E0 | GPIO_MO-<br>DEM_ANT1ROUTE_SET | RW | ANT1 port/pin select | | 0x14E4 | GPIO_MODEM_ANTROLLO-<br>VERROUTE_SET | RW | ANTROLLOVER port/pin select | | 0x14E8 | GPIO_MO-<br>DEM_ANTRR0ROUTE_SET | RW | ANTRR0 port/pin select | | 0x14EC | GPIO_MO-<br>DEM_ANTRR1ROUTE_SET | RW | ANTRR1 port/pin select | | 0x14F0 | GPIO_MO-<br>DEM_ANTRR2ROUTE_SET | RW | ANTRR2 port/pin select | | 0x14F4 | GPIO_MO-<br>DEM_ANTRR3ROUTE_SET | RW | ANTRR3 port/pin select | | 0x14F8 | GPIO_MO-<br>DEM_ANTRR4ROUTE_SET | RW | ANTRR4 port/pin select | | 0x14FC | GPIO_MO-<br>DEM_ANTRR5ROUTE_SET | RW | ANTRR5 port/pin select | | 0x1500 | GPIO_MODEM_ANTSWEN-<br>ROUTE_SET | RW | ANTSWEN port/pin select | | 0x1504 | GPIO_MODEM_ANTSWUS-<br>ROUTE_SET | RW | ANTSWUS port/pin select | | 0x1508 | GPIO_MODEM_ANTTRIG-<br>ROUTE_SET | RW | ANTTRIG port/pin select | | 0x150C | GPIO_MODEM_ANTTRIGSTOP-<br>ROUTE_SET | RW | ANTTRIGSTOP port/pin select | | 0x1510 | GPIO_MO-<br>DEM_DCLKROUTE_SET | RW | DCLK port/pin select | | 0x1514 | GPIO_MODEM_DIN-<br>ROUTE_SET | RW | DIN port/pin select | | 0x1518 | GPIO_MODEM_DOUT-<br>ROUTE_SET | RW | DOUT port/pin select | | 0x1520 | GPIO_PDM_ROUTEEN_SET | RW | PDM pin enable | | 0x1524 | GPIO_PDM_CLKROUTE_SET | RW | CLK port/pin select | | 0x1528 | GPIO_PDM_DAT0ROUTE_SET | RW | DAT0 port/pin select | | 0x152C | GPIO_PDM_DAT1ROUTE_SET | RW | DAT1 port/pin select | | 0x1534 | GPIO_PRS0_ROUTEEN_SET | RW | PRS0 pin enable | | 0x1538 | GPIO_PRS0_ASYNCH0ROUTE _SET | RW | ASYNCH0 port/pin select | | 0x153C | GPIO_PRS0_ASYNCH1ROUTE _SET | RW | ASYNCH1 port/pin select | | 0x1540 | GPIO_PRS0_ASYNCH2ROUTE _SET | RW | ASYNCH2 port/pin select | | 0x1544 | GPIO_PRS0_ASYNCH3ROUTE _SET | RW | ASYNCH3 port/pin select | | Offset | Name | Туре | Description | |--------|---------------------------------|------|--------------------------| | 0x1548 | GPIO_PRS0_ASYNCH4ROUTE<br>_SET | RW | ASYNCH4 port/pin select | | 0x154C | GPIO_PRS0_ASYNCH5ROUTE<br>_SET | RW | ASYNCH5 port/pin select | | 0x1550 | GPIO_PRS0_ASYNCH6ROUTE<br>_SET | RW | ASYNCH6 port/pin select | | 0x1554 | GPIO_PRS0_ASYNCH7ROUTE<br>_SET | RW | ASYNCH7 port/pin select | | 0x1558 | GPIO_PRS0_ASYNCH8ROUTE<br>_SET | RW | ASYNCH8 port/pin select | | 0x155C | GPIO_PRS0_ASYNCH9ROUTE _SET | RW | ASYNCH9 port/pin select | | 0x1560 | GPIO_PRS0_ASYNCH10ROUT<br>E_SET | RW | ASYNCH10 port/pin select | | 0x1564 | GPIO_PRS0_ASYNCH11ROUT<br>E_SET | RW | ASYNCH11 port/pin select | | 0x1568 | GPIO_PRS0_SYNCH0ROUTE_<br>SET | RW | SYNCH0 port/pin select | | 0x156C | GPIO_PRS0_SYNCH1ROUTE_<br>SET | RW | SYNCH1 port/pin select | | 0x1570 | GPIO_PRS0_SYNCH2ROUTE_<br>SET | RW | SYNCH2 port/pin select | | 0x1574 | GPIO_PRS0_SYNCH3ROUTE_<br>SET | RW | SYNCH3 port/pin select | | 0x157C | GPIO_TIMERO_ROUTEEN_SET | RW | TIMER0 pin enable | | 0x1580 | GPIO_TIM-<br>ER0_CC0ROUTE_SET | RW | CC0 port/pin select | | 0x1584 | GPIO_TIM-<br>ER0_CC1ROUTE_SET | RW | CC1 port/pin select | | 0x1588 | GPIO_TIM-<br>ER0_CC2ROUTE_SET | RW | CC2 port/pin select | | 0x158C | GPIO_TIM-<br>ER0_CCC0ROUTE_SET | RW | CCC0 port/pin select | | 0x1590 | GPIO_TIM-<br>ER0_CCC1ROUTE_SET | RW | CCC1 port/pin select | | 0x1594 | GPIO_TIM-<br>ER0_CCC2ROUTE_SET | RW | CCC2 port/pin select | | 0x159C | GPIO_TIMER1_ROUTEEN_SET | RW | TIMER1 pin enable | | 0x15A0 | GPIO_TIM-<br>ER1_CC0ROUTE_SET | RW | CC0 port/pin select | | 0x15A4 | GPIO_TIM-<br>ER1_CC1ROUTE_SET | RW | CC1 port/pin select | | 0x15A8 | GPIO_TIM-<br>ER1_CC2ROUTE_SET | RW | CC2 port/pin select | | 0x15AC | GPIO_TIM-<br>ER1_CCC0ROUTE_SET | RW | CCC0 port/pin select | | Offset | Name | Туре | Description | |--------|--------------------------------|------|----------------------| | 0x15B0 | GPIO_TIM-<br>ER1_CCC1ROUTE_SET | RW | CCC1 port/pin select | | 0x15B4 | GPIO_TIM-<br>ER1_CCC2ROUTE_SET | RW | CCC2 port/pin select | | 0x15BC | GPIO_TIMER2_ROUTEEN_SET | RW | TIMER2 pin enable | | 0x15C0 | GPIO_TIM-<br>ER2_CC0ROUTE_SET | RW | CC0 port/pin select | | 0x15C4 | GPIO_TIM-<br>ER2_CC1ROUTE_SET | RW | CC1 port/pin select | | 0x15C8 | GPIO_TIM-<br>ER2_CC2ROUTE_SET | RW | CC2 port/pin select | | 0x15CC | GPIO_TIM-<br>ER2_CCC0ROUTE_SET | RW | CCC0 port/pin select | | 0x15D0 | GPIO_TIM-<br>ER2_CCC1ROUTE_SET | RW | CCC1 port/pin select | | 0x15D4 | GPIO_TIM-<br>ER2_CCC2ROUTE_SET | RW | CCC2 port/pin select | | 0x15DC | GPIO_TIMER3_ROUTEEN_SET | RW | TIMER3 pin enable | | 0x15E0 | GPIO_TIM-<br>ER3_CC0ROUTE_SET | RW | CC0 port/pin select | | 0x15E4 | GPIO_TIM-<br>ER3_CC1ROUTE_SET | RW | CC1 port/pin select | | 0x15E8 | GPIO_TIM-<br>ER3_CC2ROUTE_SET | RW | CC2 port/pin select | | 0x15EC | GPIO_TIM-<br>ER3_CCC0ROUTE_SET | RW | CCC0 port/pin select | | 0x15F0 | GPIO_TIM-<br>ER3_CCC1ROUTE_SET | RW | CCC1 port/pin select | | 0x15F4 | GPIO_TIM-<br>ER3_CCC2ROUTE_SET | RW | CCC2 port/pin select | | 0x15FC | GPIO_TIMER4_ROUTEEN_SET | RW | TIMER4 pin enable | | 0x1600 | GPIO_TIM-<br>ER4_CC0ROUTE_SET | RW | CC0 port/pin select | | 0x1604 | GPIO_TIM-<br>ER4_CC1ROUTE_SET | RW | CC1 port/pin select | | 0x1608 | GPIO_TIM-<br>ER4_CC2ROUTE_SET | RW | CC2 port/pin select | | 0x160C | GPIO_TIM-<br>ER4_CCC0ROUTE_SET | RW | CCC0 port/pin select | | 0x1610 | GPIO_TIM-<br>ER4_CCC1ROUTE_SET | RW | CCC1 port/pin select | | 0x1614 | GPIO_TIM-<br>ER4_CCC2ROUTE_SET | RW | CCC2 port/pin select | | 0x161C | GPIO_USART0_ROU-<br>TEEN_SET | RW | USART0 pin enable | | Offset | Name | Туре | Description | |--------|------------------------------|------|----------------------| | 0x1620 | GPIO_USART0_CSROUTE_SE | RW | CS port/pin select | | 0x1624 | GPIO_USART0_CTSROUTE_S<br>ET | RW | CTS port/pin select | | 0x1628 | GPIO_USART0_RTSROUTE_S<br>ET | RW | RTS port/pin select | | 0x162C | GPIO_USART0_RXROUTE_SE<br>T | RW | RX port/pin select | | 0x1630 | GPIO_USART0_CLKROUTE_SE<br>T | RW | SCLK port/pin select | | 0x1634 | GPIO_USARTO_TXROUTE_SET | RW | TX port/pin select | | 0x163C | GPIO_USART1_ROU-<br>TEEN_SET | RW | USART1 pin enable | | 0x1640 | GPIO_USART1_CSROUTE_SE T | RW | CS port/pin select | | 0x1644 | GPIO_USART1_CTSROUTE_S<br>ET | RW | CTS port/pin select | | 0x1648 | GPIO_USART1_RTSROUTE_S<br>ET | RW | RTS port/pin select | | 0x164C | GPIO_USART1_RXROUTE_SE<br>T | RW | RX port/pin select | | 0x1650 | GPIO_USART1_CLKROUTE_SE<br>T | RW | SCLK port/pin select | | 0x1654 | GPIO_USART1_TXROUTE_SET | RW | TX port/pin select | | 0x2000 | GPIO_PORTA_CTRL_CLR | RW | Port control | | 0x2004 | GPIO_PORTA_MODEL_CLR | RW | mode low | | 0x200C | GPIO_PORTA_MODEH_CLR | RW | mode high | | 0x2010 | GPIO_PORTA_DOUT_CLR | RW | data out | | 0x2014 | GPIO_PORTA_DIN_CLR | RH | data in | | 0x2030 | GPIO_PORTB_CTRL_CLR | RW | Port control | | 0x2034 | GPIO_PORTB_MODEL_CLR | RW | mode low | | 0x2040 | GPIO_PORTB_DOUT_CLR | RW | data out | | 0x2044 | GPIO_PORTB_DIN_CLR | RH | data in | | 0x2060 | GPIO_PORTC_CTRL_CLR | RW | Port control | | 0x2064 | GPIO_PORTC_MODEL_CLR | RW | mode low | | 0x2070 | GPIO_PORTC_DOUT_CLR | RW | data out | | 0x2074 | GPIO_PORTC_DIN_CLR | RH | data in | | 0x2090 | GPIO_PORTD_CTRL_CLR | RW | Port control | | 0x2094 | GPIO_PORTD_MODEL_CLR | RW | mode low | | 0x20A0 | GPIO_PORTD_DOUT_CLR | RW | data out | | 0x20A4 | GPIO_PORTD_DIN_CLR | RH | data in | | 0x2300 | GPIO_LOCK_CLR | W | Lock Register | | Offset | Name | Туре | Description | |--------|--------------------------------|-------------|-----------------------------------------| | 0x2310 | GPIO_GPIOLOCKSTATUS_CLR | RH | Lock Status | | 0x2320 | GPIO_ABUSALLOC_CLR | RW | A Bus allocation | | 0x2324 | GPIO_BBUSALLOC_CLR | RW | B Bus allocation | | 0x2328 | GPIO_CDBUSALLOC_CLR | RW | CD Bus allocation | | 0x2400 | GPIO_EXTIPSELL_CLR | RW | External Interrupt Port Select Low | | 0x2404 | GPIO_EXTIPSELH_CLR | RW | External interrupt Port Select High | | 0x2408 | GPIO_EXTIPINSELL_CLR | RW | External Interrupt Pin Select Low | | 0x240C | GPIO_EXTIPINSELH_CLR | RW | External Interrupt Pin Select High | | 0x2410 | GPIO_EXTIRISE_CLR | RW | External Interrupt Rising Edge Trigger | | 0x2414 | GPIO_EXTIFALL_CLR | RW | External Interrupt Falling Edge Trigger | | 0x2420 | GPIO_IF_CLR | RWH INTFLAG | Interrupt Flag | | 0x2424 | GPIO_IEN_CLR | RW | Interrupt Enable | | 0x242C | GPIO_EM4WUEN_CLR | RW | EM4 wakeup enable | | 0x2430 | GPIO_EM4WUPOL_CLR | RW | EM4 wakeup polarity | | 0x2440 | GPIO_DBGROUTEPEN_CLR | RW | Debugger Route Pin enable | | 0x2444 | GPIO_TRACEROUTEPEN_CLR | RW | Trace Route Pin Enable | | 0x2450 | GPIO_CMU_ROUTEEN_CLR | RW | CMU pin enable | | 0x2454 | GPIO_CMU_CLKIN0ROUTE_CLR | RW | CLKIN0 port/pin select | | 0x2458 | GPIO_CMU_CLKOUT0ROUTE_<br>CLR | RW | CLKOUT0 port/pin select | | 0x245C | GPIO_CMU_CLKOUT1ROUTE_<br>CLR | RW | CLKOUT1 port/pin select | | 0x2460 | GPIO_CMU_CLKOUT2ROUTE_<br>CLR | RW | CLKOUT2 port/pin select | | 0x246C | GPIO_DCDC_ROUTEEN_CLR | RW | DCDC pin enable | | 0x247C | GPIO_FRC_ROUTEEN_CLR | RW | FRC pin enable | | 0x2480 | GPIO_FRC_DCLKROUTE_CLR | RW | DCLK port/pin select | | 0x2484 | GPIO_FRC_DFRAME-<br>ROUTE_CLR | RW | DFRAME port/pin select | | 0x2488 | GPIO_FRC_DOUTROUTE_CLR | RW | DOUT port/pin select | | 0x2490 | GPIO_I2C0_ROUTEEN_CLR | RW | I2C0 pin enable | | 0x2494 | GPIO_I2C0_SCLROUTE_CLR | RW | SCL port/pin select | | 0x2498 | GPIO_I2C0_SDAROUTE_CLR | RW | SDA port/pin select | | 0x24A0 | GPIO_I2C1_ROUTEEN_CLR | RW | I2C1 pin enable | | 0x24A4 | GPIO_I2C1_SCLROUTE_CLR | RW | SCL port/pin select | | 0x24A8 | GPIO_I2C1_SDAROUTE_CLR | RW | SDA port/pin select | | 0x24B0 | GPIO_LETIMER0_ROU-<br>TEEN_CLR | RW | LETIMER pin enable | | Offset | Name | Туре | Description | |--------|--------------------------------------|------|-----------------------------| | 0x24B4 | GPIO_LETIM-<br>ER0_OUT0ROUTE_CLR | RW | OUT0 port/pin select | | 0x24B8 | GPIO_LETIM-<br>ER0_OUT1ROUTE_CLR | RW | OUT1 port/pin select | | 0x24C0 | GPIO_EUART0_ROU-<br>TEEN_CLR | RW | EUART pin enable | | 0x24C4 | GPIO_EU-<br>ART0_CTSROUTE_CLR | RW | CTS port/pin select | | 0x24C8 | GPIO_EU-<br>ART0_RTSROUTE_CLR | RW | RTS port/pin select | | 0x24CC | GPIO_EU-<br>ART0_RXROUTE_CLR | RW | RX port/pin select | | 0x24D0 | GPIO_EUART0_TXROUTE_CLR | RW | TX port/pin select | | 0x24D8 | GPIO_MODEM_ROUTEEN_CLR | RW | MODEM pin enable | | 0x24DC | GPIO_MO-<br>DEM_ANT0ROUTE_CLR | RW | ANT0 port/pin select | | 0x24E0 | GPIO_MO-<br>DEM_ANT1ROUTE_CLR | RW | ANT1 port/pin select | | 0x24E4 | GPIO_MODEM_ANTROLLO-<br>VERROUTE_CLR | RW | ANTROLLOVER port/pin select | | 0x24E8 | GPIO_MO-<br>DEM_ANTRR0ROUTE_CLR | RW | ANTRR0 port/pin select | | 0x24EC | GPIO_MO-<br>DEM_ANTRR1ROUTE_CLR | RW | ANTRR1 port/pin select | | 0x24F0 | GPIO_MO-<br>DEM_ANTRR2ROUTE_CLR | RW | ANTRR2 port/pin select | | 0x24F4 | GPIO_MO-<br>DEM_ANTRR3ROUTE_CLR | RW | ANTRR3 port/pin select | | 0x24F8 | GPIO_MO-<br>DEM_ANTRR4ROUTE_CLR | RW | ANTRR4 port/pin select | | 0x24FC | GPIO_MO-<br>DEM_ANTRR5ROUTE_CLR | RW | ANTRR5 port/pin select | | 0x2500 | GPIO_MODEM_ANTSWEN-<br>ROUTE_CLR | RW | ANTSWEN port/pin select | | 0x2504 | GPIO_MODEM_ANTSWUS-<br>ROUTE_CLR | RW | ANTSWUS port/pin select | | 0x2508 | GPIO_MODEM_ANTTRIG-<br>ROUTE_CLR | RW | ANTTRIG port/pin select | | 0x250C | GPIO_MODEM_ANTTRIGSTOP-<br>ROUTE_CLR | RW | ANTTRIGSTOP port/pin select | | 0x2510 | GPIO_MO-<br>DEM_DCLKROUTE_CLR | RW | DCLK port/pin select | | 0x2514 | GPIO_MODEM_DIN-<br>ROUTE_CLR | RW | DIN port/pin select | | 0x2518 | GPIO_MODEM_DOUT-<br>ROUTE_CLR | RW | DOUT port/pin select | | Offset | Name | Туре | Description | |--------|---------------------------------|------|--------------------------| | 0x2520 | GPIO_PDM_ROUTEEN_CLR | RW | PDM pin enable | | 0x2524 | GPIO_PDM_CLKROUTE_CLR | RW | CLK port/pin select | | 0x2528 | GPIO_PDM_DAT0ROUTE_CLR | RW | DAT0 port/pin select | | 0x252C | GPIO_PDM_DAT1ROUTE_CLR | RW | DAT1 port/pin select | | 0x2534 | GPIO_PRS0_ROUTEEN_CLR | RW | PRS0 pin enable | | 0x2538 | GPIO_PRS0_ASYNCH0ROUTE<br>_CLR | RW | ASYNCH0 port/pin select | | 0x253C | GPIO_PRS0_ASYNCH1ROUTE<br>_CLR | RW | ASYNCH1 port/pin select | | 0x2540 | GPIO_PRS0_ASYNCH2ROUTE<br>_CLR | RW | ASYNCH2 port/pin select | | 0x2544 | GPIO_PRS0_ASYNCH3ROUTE<br>_CLR | RW | ASYNCH3 port/pin select | | 0x2548 | GPIO_PRS0_ASYNCH4ROUTE<br>_CLR | RW | ASYNCH4 port/pin select | | 0x254C | GPIO_PRS0_ASYNCH5ROUTE<br>_CLR | RW | ASYNCH5 port/pin select | | 0x2550 | GPIO_PRS0_ASYNCH6ROUTE<br>_CLR | RW | ASYNCH6 port/pin select | | 0x2554 | GPIO_PRS0_ASYNCH7ROUTE<br>_CLR | RW | ASYNCH7 port/pin select | | 0x2558 | GPIO_PRS0_ASYNCH8ROUTE<br>_CLR | RW | ASYNCH8 port/pin select | | 0x255C | GPIO_PRS0_ASYNCH9ROUTE<br>_CLR | RW | ASYNCH9 port/pin select | | 0x2560 | GPIO_PRS0_ASYNCH10ROUT<br>E_CLR | RW | ASYNCH10 port/pin select | | 0x2564 | GPIO_PRS0_ASYNCH11ROUT<br>E_CLR | RW | ASYNCH11 port/pin select | | 0x2568 | GPIO_PRS0_SYNCH0ROUTE_<br>CLR | RW | SYNCH0 port/pin select | | 0x256C | GPIO_PRS0_SYNCH1ROUTE_<br>CLR | RW | SYNCH1 port/pin select | | 0x2570 | GPIO_PRS0_SYNCH2ROUTE_<br>CLR | RW | SYNCH2 port/pin select | | 0x2574 | GPIO_PRS0_SYNCH3ROUTE_<br>CLR | RW | SYNCH3 port/pin select | | 0x257C | GPIO_TIMER0_ROUTEEN_CLR | RW | TIMER0 pin enable | | 0x2580 | GPIO_TIM-<br>ER0_CC0ROUTE_CLR | RW | CC0 port/pin select | | 0x2584 | GPIO_TIM-<br>ER0_CC1ROUTE_CLR | RW | CC1 port/pin select | | 0x2588 | GPIO_TIM-<br>ER0_CC2ROUTE_CLR | RW | CC2 port/pin select | | Offset | Name | Туре | Description | |--------|--------------------------------|------|----------------------| | 0x258C | GPIO_TIM-<br>ER0_CCC0ROUTE_CLR | RW | CCC0 port/pin select | | 0x2590 | GPIO_TIM-<br>ER0_CCC1ROUTE_CLR | RW | CCC1 port/pin select | | 0x2594 | GPIO_TIM-<br>ER0_CCC2ROUTE_CLR | RW | CCC2 port/pin select | | 0x259C | GPIO_TIMER1_ROUTEEN_CLR | RW | TIMER1 pin enable | | 0x25A0 | GPIO_TIM-<br>ER1_CC0ROUTE_CLR | RW | CC0 port/pin select | | 0x25A4 | GPIO_TIM-<br>ER1_CC1ROUTE_CLR | RW | CC1 port/pin select | | 0x25A8 | GPIO_TIM-<br>ER1_CC2ROUTE_CLR | RW | CC2 port/pin select | | 0x25AC | GPIO_TIM-<br>ER1_CCC0ROUTE_CLR | RW | CCC0 port/pin select | | 0x25B0 | GPIO_TIM-<br>ER1_CCC1ROUTE_CLR | RW | CCC1 port/pin select | | 0x25B4 | GPIO_TIM-<br>ER1_CCC2ROUTE_CLR | RW | CCC2 port/pin select | | 0x25BC | GPIO_TIMER2_ROUTEEN_CLR | RW | TIMER2 pin enable | | 0x25C0 | GPIO_TIM-<br>ER2_CC0ROUTE_CLR | RW | CC0 port/pin select | | 0x25C4 | GPIO_TIM-<br>ER2_CC1ROUTE_CLR | RW | CC1 port/pin select | | 0x25C8 | GPIO_TIM-<br>ER2_CC2ROUTE_CLR | RW | CC2 port/pin select | | 0x25CC | GPIO_TIM-<br>ER2_CCC0ROUTE_CLR | RW | CCC0 port/pin select | | 0x25D0 | GPIO_TIM-<br>ER2_CCC1ROUTE_CLR | RW | CCC1 port/pin select | | 0x25D4 | GPIO_TIM-<br>ER2_CCC2ROUTE_CLR | RW | CCC2 port/pin select | | 0x25DC | GPIO_TIMER3_ROUTEEN_CLR | RW | TIMER3 pin enable | | 0x25E0 | GPIO_TIM-<br>ER3_CC0ROUTE_CLR | RW | CC0 port/pin select | | 0x25E4 | GPIO_TIM-<br>ER3_CC1ROUTE_CLR | RW | CC1 port/pin select | | 0x25E8 | GPIO_TIM-<br>ER3_CC2ROUTE_CLR | RW | CC2 port/pin select | | 0x25EC | GPIO_TIM-<br>ER3_CCC0ROUTE_CLR | RW | CCC0 port/pin select | | 0x25F0 | GPIO_TIM-<br>ER3_CCC1ROUTE_CLR | RW | CCC1 port/pin select | | 0x25F4 | GPIO_TIM-<br>ER3_CCC2ROUTE_CLR | RW | CCC2 port/pin select | | 0x25FC | GPIO_TIMER4_ROUTEEN_CLR | RW | TIMER4 pin enable | | Offset | Name | Туре | Description | | | | | | | | | |--------|--------------------------------|------|----------------------|--|--|--|--|--|--|--|--| | 0x2600 | GPIO_TIM-<br>ER4_CC0ROUTE_CLR | RW | CC0 port/pin select | | | | | | | | | | 0x2604 | GPIO_TIM-<br>ER4_CC1ROUTE_CLR | RW | CC1 port/pin select | | | | | | | | | | 0x2608 | GPIO_TIM-<br>ER4_CC2ROUTE_CLR | RW | CC2 port/pin select | | | | | | | | | | 0x260C | GPIO_TIM-<br>ER4_CCC0ROUTE_CLR | RW | CCC0 port/pin select | | | | | | | | | | 0x2610 | GPIO_TIM-<br>ER4_CCC1ROUTE_CLR | RW | CCC1 port/pin select | | | | | | | | | | 0x2614 | GPIO_TIM-<br>ER4_CCC2ROUTE_CLR | RW | CCC2 port/pin select | | | | | | | | | | 0x261C | GPIO_USART0_ROU-<br>TEEN_CLR | RW | USART0 pin enable | | | | | | | | | | 0x2620 | GPIO_USARTO_CSROUTE_CL<br>R | RW | CS port/pin select | | | | | | | | | | 0x2624 | GPIO_USART0_CTSROUTE_CLR | RW | CTS port/pin select | | | | | | | | | | 0x2628 | GPIO_USART0_RTSROUTE_CL<br>R | RW | RTS port/pin select | | | | | | | | | | 0x262C | GPIO_USART0_RXROUTE_CLR | RW | RX port/pin select | | | | | | | | | | 0x2630 | GPIO_USART0_CLKROUTE_CLR | RW | SCLK port/pin select | | | | | | | | | | 0x2634 | GPIO_USART0_TXROUTE_CLR | RW | TX port/pin select | | | | | | | | | | 0x263C | GPIO_USART1_ROU-<br>TEEN_CLR | RW | USART1 pin enable | | | | | | | | | | 0x2640 | GPIO_USART1_CSROUTE_CLR | RW | CS port/pin select | | | | | | | | | | 0x2644 | GPIO_USART1_CTSROUTE_CLR | RW | CTS port/pin select | | | | | | | | | | 0x2648 | GPIO_USART1_RTSROUTE_CL<br>R | RW | RTS port/pin select | | | | | | | | | | 0x264C | GPIO_USART1_RXROUTE_CL<br>R | RW | RX port/pin select | | | | | | | | | | 0x2650 | GPIO_USART1_CLKROUTE_CLR | RW | SCLK port/pin select | | | | | | | | | | 0x2654 | GPIO_USART1_TXROUTE_CLR | RW | TX port/pin select | | | | | | | | | | 0x3000 | GPIO_PORTA_CTRL_TGL | RW | Port control | | | | | | | | | | 0x3004 | GPIO_PORTA_MODEL_TGL | RW | mode low | | | | | | | | | | 0x300C | GPIO_PORTA_MODEH_TGL | RW | mode high | | | | | | | | | | 0x3010 | GPIO_PORTA_DOUT_TGL | RW | data out | | | | | | | | | | 0x3014 | GPIO_PORTA_DIN_TGL | RH | data in | | | | | | | | | | 0x3030 | GPIO_PORTB_CTRL_TGL | RW | Port control | | | | | | | | | | Offset | Name | Туре | Description | | | | | | | |--------|-------------------------------|-------------|-----------------------------------------|--|--|--|--|--|--| | 0x3034 | GPIO_PORTB_MODEL_TGL | RW | mode low | | | | | | | | 0x3040 | GPIO_PORTB_DOUT_TGL | RW | data out | | | | | | | | 0x3044 | GPIO_PORTB_DIN_TGL | RH | data in | | | | | | | | 0x3060 | GPIO_PORTC_CTRL_TGL | RW | Port control | | | | | | | | 0x3064 | GPIO_PORTC_MODEL_TGL | RW | mode low | | | | | | | | 0x3070 | GPIO_PORTC_DOUT_TGL | RW | data out | | | | | | | | 0x3074 | GPIO_PORTC_DIN_TGL | RH | data in | | | | | | | | 0x3090 | GPIO_PORTD_CTRL_TGL | RW | Port control | | | | | | | | 0x3094 | GPIO_PORTD_MODEL_TGL | RW | mode low | | | | | | | | 0x30A0 | GPIO_PORTD_DOUT_TGL | RW | data out | | | | | | | | 0x30A4 | 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 | | | | | | | | 0x3328 | GPIO_CDBUSALLOC_TGL | RW | CD Bus allocation | | | | | | | | 0x3400 | GPIO_EXTIPSELL_TGL | RW | External Interrupt Port Select Low | | | | | | | | 0x3404 | GPIO_EXTIPSELH_TGL | RW | External interrupt Port Select High | | | | | | | | 0x3408 | GPIO_EXTIPINSELL_TGL | RW | External Interrupt Pin Select Low | | | | | | | | 0x340C | GPIO_EXTIPINSELH_TGL | RW | External Interrupt Pin Select High | | | | | | | | 0x3410 | GPIO_EXTIRISE_TGL | RW | External Interrupt Rising Edge Trigger | | | | | | | | 0x3414 | GPIO_EXTIFALL_TGL | RW | External Interrupt Falling Edge Trigger | | | | | | | | 0x3420 | GPIO_IF_TGL | RWH INTFLAG | Interrupt Flag | | | | | | | | 0x3424 | GPIO_IEN_TGL | RW | Interrupt Enable | | | | | | | | 0x342C | GPIO_EM4WUEN_TGL | RW | EM4 wakeup enable | | | | | | | | 0x3430 | GPIO_EM4WUPOL_TGL | RW | EM4 wakeup polarity | | | | | | | | 0x3440 | GPIO_DBGROUTEPEN_TGL | RW | Debugger Route Pin enable | | | | | | | | 0x3444 | GPIO_TRACEROUTEPEN_TGL | RW | Trace Route Pin Enable | | | | | | | | 0x3450 | GPIO_CMU_ROUTEEN_TGL | RW | CMU pin enable | | | | | | | | 0x3454 | GPIO_CMU_CLKIN0ROUTE_TG<br>L | RW | CLKIN0 port/pin select | | | | | | | | 0x3458 | GPIO_CMU_CLKOUT0ROUTE_<br>TGL | RW | CLKOUT0 port/pin select | | | | | | | | 0x345C | GPIO_CMU_CLKOUT1ROUTE_<br>TGL | RW | CLKOUT1 port/pin select | | | | | | | | 0x3460 | GPIO_CMU_CLKOUT2ROUTE_<br>TGL | RW | CLKOUT2 port/pin select | | | | | | | | 0x346C | GPIO_DCDC_ROUTEEN_TGL | RW | DCDC pin enable | | | | | | | | 0x347C | GPIO_FRC_ROUTEEN_TGL | RW | FRC pin enable | | | | | | | | Offset | Name | Туре | Description | | | | | | | | | |--------|--------------------------------------|------|-----------------------------|--|--|--|--|--|--|--|--| | 0x3480 | GPIO_FRC_DCLKROUTE_TGL | RW | DCLK port/pin select | | | | | | | | | | 0x3484 | GPIO_FRC_DFRAME-<br>ROUTE_TGL | RW | DFRAME port/pin select | | | | | | | | | | 0x3488 | GPIO_FRC_DOUTROUTE_TGL | RW | DOUT port/pin select | | | | | | | | | | 0x3490 | GPIO_I2C0_ROUTEEN_TGL | RW | I2C0 pin enable | | | | | | | | | | 0x3494 | GPIO_I2C0_SCLROUTE_TGL | RW | SCL port/pin select | | | | | | | | | | 0x3498 | GPIO_I2C0_SDAROUTE_TGL | RW | SDA port/pin select | | | | | | | | | | 0x34A0 | GPIO_I2C1_ROUTEEN_TGL | RW | I2C1 pin enable | | | | | | | | | | 0x34A4 | GPIO_I2C1_SCLROUTE_TGL | RW | SCL port/pin select | | | | | | | | | | 0x34A8 | GPIO_I2C1_SDAROUTE_TGL | RW | SDA port/pin select | | | | | | | | | | 0x34B0 | GPIO_LETIMER0_ROU-<br>TEEN_TGL | RW | LETIMER pin enable | | | | | | | | | | 0x34B4 | GPIO_LETIM-<br>ER0_OUT0ROUTE_TGL | RW | OUT0 port/pin select | | | | | | | | | | 0x34B8 | GPIO_LETIM-<br>ER0_OUT1ROUTE_TGL | RW | OUT1 port/pin select | | | | | | | | | | 0x34C0 | GPIO_EUART0_ROU-<br>TEEN_TGL | RW | EUART pin enable | | | | | | | | | | 0x34C4 | GPIO_EU-<br>ART0_CTSROUTE_TGL | RW | CTS port/pin select | | | | | | | | | | 0x34C8 | GPIO_EU-<br>ART0_RTSROUTE_TGL | RW | RTS port/pin select | | | | | | | | | | 0x34CC | GPIO_EU-<br>ART0_RXROUTE_TGL | RW | RX port/pin select | | | | | | | | | | 0x34D0 | GPIO_EUART0_TXROUTE_TGL | RW | TX port/pin select | | | | | | | | | | 0x34D8 | GPIO_MODEM_ROUTEEN_TGL | RW | MODEM pin enable | | | | | | | | | | 0x34DC | GPIO_MO-<br>DEM_ANT0ROUTE_TGL | RW | ANT0 port/pin select | | | | | | | | | | 0x34E0 | GPIO_MO-<br>DEM_ANT1ROUTE_TGL | RW | ANT1 port/pin select | | | | | | | | | | 0x34E4 | GPIO_MODEM_ANTROLLO-<br>VERROUTE_TGL | RW | ANTROLLOVER port/pin select | | | | | | | | | | 0x34E8 | GPIO_MO-<br>DEM_ANTRR0ROUTE_TGL | RW | ANTRR0 port/pin select | | | | | | | | | | 0x34EC | GPIO_MO-<br>DEM_ANTRR1ROUTE_TGL | RW | ANTRR1 port/pin select | | | | | | | | | | 0x34F0 | GPIO_MO-<br>DEM_ANTRR2ROUTE_TGL | RW | ANTRR2 port/pin select | | | | | | | | | | 0x34F4 | GPIO_MO-<br>DEM_ANTRR3ROUTE_TGL | RW | ANTRR3 port/pin select | | | | | | | | | | 0x34F8 | GPIO_MO-<br>DEM_ANTRR4ROUTE_TGL | RW | ANTRR4 port/pin select | | | | | | | | | | 0x34FC | GPIO_MO-<br>DEM_ANTRR5ROUTE_TGL | RW | ANTRR5 port/pin select | | | | | | | | | | Offset | Name | Туре | Description | | | | | | | | |--------|--------------------------------------|------|-----------------------------|--|--|--|--|--|--|--| | 0x3500 | GPIO_MODEM_ANTSWEN-<br>ROUTE_TGL | RW | ANTSWEN port/pin select | | | | | | | | | 0x3504 | GPIO_MODEM_ANTSWUS-<br>ROUTE_TGL | RW | ANTSWUS port/pin select | | | | | | | | | 0x3508 | GPIO_MODEM_ANTTRIG-<br>ROUTE_TGL | RW | ANTTRIG port/pin select | | | | | | | | | 0x350C | GPIO_MODEM_ANTTRIGSTOP-<br>ROUTE_TGL | RW | ANTTRIGSTOP port/pin select | | | | | | | | | 0x3510 | GPIO_MO-<br>DEM_DCLKROUTE_TGL | RW | DCLK port/pin select | | | | | | | | | 0x3514 | GPIO_MODEM_DIN-<br>ROUTE_TGL | RW | DIN port/pin select | | | | | | | | | 0x3518 | GPIO_MODEM_DOUT-<br>ROUTE_TGL | RW | DOUT port/pin select | | | | | | | | | 0x3520 | GPIO_PDM_ROUTEEN_TGL | RW | PDM pin enable | | | | | | | | | 0x3524 | GPIO_PDM_CLKROUTE_TGL | RW | CLK port/pin select | | | | | | | | | 0x3528 | GPIO_PDM_DAT0ROUTE_TGL | RW | DAT0 port/pin select | | | | | | | | | 0x352C | GPIO_PDM_DAT1ROUTE_TGL | RW | DAT1 port/pin select | | | | | | | | | 0x3534 | GPIO_PRS0_ROUTEEN_TGL | RW | PRS0 pin enable | | | | | | | | | 0x3538 | GPIO_PRS0_ASYNCH0ROUTE<br>_TGL | RW | ASYNCH0 port/pin select | | | | | | | | | 0x353C | GPIO_PRS0_ASYNCH1ROUTE<br>_TGL | RW | ASYNCH1 port/pin select | | | | | | | | | 0x3540 | GPIO_PRS0_ASYNCH2ROUTE<br>_TGL | RW | ASYNCH2 port/pin select | | | | | | | | | 0x3544 | GPIO_PRS0_ASYNCH3ROUTE<br>_TGL | RW | ASYNCH3 port/pin select | | | | | | | | | 0x3548 | GPIO_PRS0_ASYNCH4ROUTE<br>_TGL | RW | ASYNCH4 port/pin select | | | | | | | | | 0x354C | GPIO_PRS0_ASYNCH5ROUTE<br>_TGL | RW | ASYNCH5 port/pin select | | | | | | | | | 0x3550 | GPIO_PRS0_ASYNCH6ROUTE<br>_TGL | RW | ASYNCH6 port/pin select | | | | | | | | | 0x3554 | GPIO_PRS0_ASYNCH7ROUTE<br>_TGL | RW | ASYNCH7 port/pin select | | | | | | | | | 0x3558 | GPIO_PRS0_ASYNCH8ROUTE<br>_TGL | RW | ASYNCH8 port/pin select | | | | | | | | | 0x355C | GPIO_PRS0_ASYNCH9ROUTE<br>_TGL | RW | ASYNCH9 port/pin select | | | | | | | | | 0x3560 | GPIO_PRS0_ASYNCH10ROUT<br>E_TGL | RW | ASYNCH10 port/pin select | | | | | | | | | 0x3564 | GPIO_PRS0_ASYNCH11ROUT<br>E_TGL | RW | ASYNCH11 port/pin select | | | | | | | | | 0x3568 | GPIO_PRS0_SYNCH0ROUTE_<br>TGL | RW | SYNCH0 port/pin select | | | | | | | | | Offset | Name | Туре | Description | | | | | | | | | | |--------|--------------------------------|------|------------------------|--|--|--|--|--|--|--|--|--| | 0x356C | GPIO_PRS0_SYNCH1ROUTE_<br>TGL | RW | SYNCH1 port/pin select | | | | | | | | | | | 0x3570 | GPIO_PRS0_SYNCH2ROUTE_<br>TGL | RW | SYNCH2 port/pin select | | | | | | | | | | | 0x3574 | GPIO_PRS0_SYNCH3ROUTE_<br>TGL | RW | SYNCH3 port/pin select | | | | | | | | | | | 0x357C | GPIO_TIMER0_ROUTEEN_TGL | RW | TIMER0 pin enable | | | | | | | | | | | 0x3580 | GPIO_TIM-<br>ER0_CC0ROUTE_TGL | RW | CC0 port/pin select | | | | | | | | | | | 0x3584 | GPIO_TIM-<br>ER0_CC1ROUTE_TGL | RW | CC1 port/pin select | | | | | | | | | | | 0x3588 | GPIO_TIM-<br>ER0_CC2ROUTE_TGL | RW | CC2 port/pin select | | | | | | | | | | | 0x358C | GPIO_TIM-<br>ER0_CCC0ROUTE_TGL | RW | CCC0 port/pin select | | | | | | | | | | | 0x3590 | GPIO_TIM-<br>ER0_CCC1ROUTE_TGL | RW | CCC1 port/pin select | | | | | | | | | | | 0x3594 | GPIO_TIM-<br>ER0_CCC2ROUTE_TGL | RW | CCC2 port/pin select | | | | | | | | | | | 0x359C | GPIO_TIMER1_ROUTEEN_TGL | RW | TIMER1 pin enable | | | | | | | | | | | 0x35A0 | GPIO_TIM-<br>ER1_CC0ROUTE_TGL | RW | CC0 port/pin select | | | | | | | | | | | 0x35A4 | GPIO_TIM-<br>ER1_CC1ROUTE_TGL | RW | CC1 port/pin select | | | | | | | | | | | 0x35A8 | GPIO_TIM-<br>ER1_CC2ROUTE_TGL | RW | CC2 port/pin select | | | | | | | | | | | 0x35AC | GPIO_TIM-<br>ER1_CCC0ROUTE_TGL | RW | CCC0 port/pin select | | | | | | | | | | | 0x35B0 | GPIO_TIM-<br>ER1_CCC1ROUTE_TGL | RW | CCC1 port/pin select | | | | | | | | | | | 0x35B4 | GPIO_TIM-<br>ER1_CCC2ROUTE_TGL | RW | CCC2 port/pin select | | | | | | | | | | | 0x35BC | GPIO_TIMER2_ROUTEEN_TGL | RW | TIMER2 pin enable | | | | | | | | | | | 0x35C0 | GPIO_TIM-<br>ER2_CC0ROUTE_TGL | RW | CC0 port/pin select | | | | | | | | | | | 0x35C4 | GPIO_TIM-<br>ER2_CC1ROUTE_TGL | RW | CC1 port/pin select | | | | | | | | | | | 0x35C8 | GPIO_TIM-<br>ER2_CC2ROUTE_TGL | RW | CC2 port/pin select | | | | | | | | | | | 0x35CC | GPIO_TIM-<br>ER2_CCC0ROUTE_TGL | RW | CCC0 port/pin select | | | | | | | | | | | 0x35D0 | GPIO_TIM-<br>ER2_CCC1ROUTE_TGL | RW | CCC1 port/pin select | | | | | | | | | | | 0x35D4 | GPIO_TIM-<br>ER2_CCC2ROUTE_TGL | RW | CCC2 port/pin select | | | | | | | | | | | 0x35DC | GPIO_TIMER3_ROUTEEN_TGL | RW | TIMER3 pin enable | | | | | | | | | | | Offset | Name | Туре | Description | |--------|--------------------------------|------|----------------------| | 0x35E0 | GPIO_TIM-<br>ER3_CC0ROUTE_TGL | RW | CC0 port/pin select | | 0x35E4 | GPIO_TIM-<br>ER3_CC1ROUTE_TGL | RW | CC1 port/pin select | | 0x35E8 | GPIO_TIM-<br>ER3_CC2ROUTE_TGL | RW | CC2 port/pin select | | 0x35EC | GPIO_TIM-<br>ER3_CCC0ROUTE_TGL | RW | CCC0 port/pin select | | 0x35F0 | GPIO_TIM-<br>ER3_CCC1ROUTE_TGL | RW | CCC1 port/pin select | | 0x35F4 | GPIO_TIM-<br>ER3_CCC2ROUTE_TGL | RW | CCC2 port/pin select | | 0x35FC | GPIO_TIMER4_ROUTEEN_TGL | RW | TIMER4 pin enable | | 0x3600 | GPIO_TIM-<br>ER4_CC0ROUTE_TGL | RW | CC0 port/pin select | | 0x3604 | GPIO_TIM-<br>ER4_CC1ROUTE_TGL | RW | CC1 port/pin select | | 0x3608 | GPIO_TIM-<br>ER4_CC2ROUTE_TGL | RW | CC2 port/pin select | | 0x360C | GPIO_TIM-<br>ER4_CCC0ROUTE_TGL | RW | CCC0 port/pin select | | 0x3610 | GPIO_TIM-<br>ER4_CCC1ROUTE_TGL | RW | CCC1 port/pin select | | 0x3614 | GPIO_TIM-<br>ER4_CCC2ROUTE_TGL | RW | CCC2 port/pin select | | 0x361C | GPIO_USART0_ROU-<br>TEEN_TGL | RW | USART0 pin enable | | 0x3620 | GPIO_USART0_CSROUTE_TG | RW | CS port/pin select | | 0x3624 | GPIO_USART0_CTSROUTE_T<br>GL | RW | CTS port/pin select | | 0x3628 | GPIO_USART0_RTSROUTE_T<br>GL | RW | RTS port/pin select | | 0x362C | GPIO_USART0_RXROUTE_TG | RW | RX port/pin select | | 0x3630 | GPIO_USART0_CLKROUTE_T<br>GL | RW | SCLK port/pin select | | 0x3634 | GPIO_USART0_TXROUTE_TGL | RW | TX port/pin select | | 0x363C | GPIO_USART1_ROU-<br>TEEN_TGL | RW | USART1 pin enable | | 0x3640 | GPIO_USART1_CSROUTE_TG | RW | CS port/pin select | | 0x3644 | GPIO_USART1_CTSROUTE_T<br>GL | RW | CTS port/pin select | | 0x3648 | GPIO_USART1_RTSROUTE_T<br>GL | RW | RTS port/pin select | | Offset | Name | Туре | Description | |--------|------------------------------|------|----------------------| | 0x364C | GPIO_USART1_RXROUTE_TG | RW | RX port/pin select | | 0x3650 | GPIO_USART1_CLKROUTE_T<br>GL | RW | SCLK port/pin select | | 0x3654 | GPIO_USART1_TXROUTE_TGL | RW | TX port/pin select | #### 25.6 GPIO Register Description ## 25.6.1 GPIO\_PORTA\_CTRL - Port control | Offset | | | | | | | | | | | | | | | Ві | t Po | ositi | on | | | | | | | | | | | | | | | |--------|----|----|----|-----------|----|----|----|----|----|----|-------------|----|----|---|----|------|-------|----|----|-------------|---|----|---|---|---|---|----------|---|---|---|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | 000 | | | | | | | 0x4 | | | | | | | | | 0<br>0<br>0 | | | | | | | 0×4 | | | | | | | Access | | | | ₩<br>M | | | | | | | R<br>M | | | | | | | | | \<br>S | | | | | | | S.<br>N | | | | | | | Name | | | | DINDISALT | | | | | | | SLEWRATEALT | | | | | | | | | DINDIS | | | | | | | SLEWRATE | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|-----------------|--------------------|----------------------------------------------------------------------| | | Name | Reset | A00033 | Description | | 31:29 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 28 | DINDISALT | 0x0 | RW | Data In Disable Alt | | | Data input disable for po | rt pins using a | alternate modes. | | | 27:23 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 22:20 | SLEWRATEALT | 0x4 | RW | Slew Rate Alt | | | Slewrate limit for port pin | s using altern | ate modes. High | ner values provide faster slew rates. | | 19:13 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 12 | DINDIS | 0x0 | RW | Data In Disable | | | Data input disable for po | rt pins not usi | ng alternate mo | des. | | 11:7 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 6:4 | SLEWRATE | 0x4 | RW | Slew Rate | | | Slewrate limit for port pin | s not using al | ternate modes. | Higher values provide faster slew rates. | | 3:0 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | ## 25.6.2 GPIO\_PORTA\_MODEL - mode low | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|-------|--------------|----|----|------|-------|---------|----|----|------------|----|-------|----|----------|----|----|----|----------|----|----|-----------|----------|---|----|------|---|---|---|---|---|---|---| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | 2 | 2 | • | | 2 | OX<br>O | • | | 000 | | | 2 | OX<br>O | • | | 2 | OXO | | | | OX<br>O | | | 2 | 2 | • | | 2 | 2 | | | | Access | | 2 | 2 | | | WR WR | | | 20 | <u>}</u> | | | 2 | <u>}</u> | | | 2 | <u>}</u> | | | 2 | <u>}</u> | | RW | | | | | | | | | | Name | MODE7 | | | | 3000 | | | | | MODIN<br>4 | | МОБЕЗ | | | | | | NODEA | | | MON<br>FI | | | | MODE | | | | | | | | | 3it | Name | Reset | Access | Description | | | | | | | | |-------|--------|-------------------|--------------|-------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:28 | MODE7 | 0x0 | RW | MODE n | | | | | | | | | | MODE n | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 0 | DISABLE | D | Input disabled. Pullup if DOUT is set. | | | | | | | | | | 1 | INPUT | | Input enabled. Filter if DOUT is set. | | | | | | | | | | 2 | INPUTPU | LL | Input enabled. DOUT determines pull direction. | | | | | | | | | | 3 | INPUTPU | LLFILTER | Input enabled with filter. DOUT determines pull direction. | | | | | | | | | | 4 | PUSHPU | LL | Push-pull output. | | | | | | | | | | 5 | PUSHPU | LLALT | Push-pull using alternate control. | | | | | | | | | | 6 | WIREDO | ₹ | Wired-or output. | | | | | | | | | | 7 | WIREDO | RPULLDOWN | Wired-or output with pull-down. | | | | | | | | | | 8 | WIREDAN | ND | Open-drain output. | | | | | | | | | | 9 | WIREDA | NDFILTER | Open-drain output with filter. | | | | | | | | | | 10 | WIREDA | NDPULLUP | Open-drain output with pullup. | | | | | | | | | | 11 | WIREDAN<br>TER | NDPULLUPFIL- | Open-drain output with filter and pullup. | | | | | | | | | | 12 | WIREDA | NDALT | Open-drain output using alternate control. | | | | | | | | | | 13 | WIREDA | NDALTFILTER | Open-drain output using alternate control with filter. | | | | | | | | | | 14 | WIREDAN | NDALTPULLUP | Open-drain output using alternate control with pullup. | | | | | | | | | | 15 | WIREDAI<br>FILTER | NDALTPULLUP- | Open-drain output using alternate control with filter and pullup. | | | | | | | | | 7:24 | MODE6 | 0x0 | RW | MODE n | | | | | | | | | | MODE n | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 0 | DISABLE | D | Input disabled. Pullup if DOUT is set. | | | | | | | | | | 1 | INPUT | | Input enabled. Filter if DOUT is set. | | | | | | | | | | 2 | INPUTPU | LL | Input enabled. DOUT determines pull direction. | | | | | | | | | | 3 | INPUTPU | LLFILTER | Input enabled with filter. DOUT determines pull direction. | | | | | | | | | Bit | Name | Reset Acc | ess | Description | | | | | | | |-------|-----------------|------------------------|---------|-------------------------------------------------------------------|--|--|--|--|--|--| | | 4 | PUSHPULL | | Push-pull output. | | | | | | | | | 5 | PUSHPULLALT | | Push-pull using alternate control. | | | | | | | | | 6 | WIREDOR | | Wired-or output. | | | | | | | | | 7 | WIREDORPULLI | OOWN | Wired-or output with pull-down. | | | | | | | | | 8 | WIREDAND | | Open-drain output. | | | | | | | | | 9 | WIREDANDFILT | ER | Open-drain output with filter. | | | | | | | | | 10 | WIREDANDPUL | LUP | Open-drain output with pullup. | | | | | | | | | 11 | WIREDANDPUL<br>TER | LUPFIL- | Open-drain output with filter and pullup. | | | | | | | | | 12 | WIREDANDALT | | Open-drain output using alternate control. | | | | | | | | | 13 | WIREDANDALTI | FILTER | Open-drain output using alternate control with filter. | | | | | | | | | 14 | WIREDANDALTI | PULLUP | Open-drain output using alternate control with pullup. | | | | | | | | | 15 | WIREDANDALTI<br>FILTER | PULLUP- | Open-drain output using alternate control with filter and pullup | | | | | | | | 23:20 | MODE5<br>MODE n | 0x0 RW | | 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 | INPUTPULLFILT | ER | 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 | WIREDORPULL | OOWN | Wired-or output with pull-down. | | | | | | | | | 8 | WIREDAND | | Open-drain output. | | | | | | | | | 9 | WIREDANDFILT | ER | Open-drain output with filter. | | | | | | | | | 10 | WIREDANDPUL | LUP | Open-drain output with pullup. | | | | | | | | | 11 | WIREDANDPUL<br>TER | LUPFIL- | 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 | WIREDANDALTI | PULLUP | Open-drain output using alternate control with pullup. | | | | | | | | | 15 | WIREDANDALTI<br>FILTER | PULLUP- | P- Open-drain output using alternate control with filter and pull | | | | | | | | 9:16 | MODE4 | 0x0 RW | | MODE n | | | | | | | | .5.15 | MODE n | | | | | | | | | | | Bit | Name | Reset Access | Description | |-------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | | | | | | 15:12 | MODE3 | 0x0 RW | MODE n | | 15:12 | MODE3<br>MODE n | 0x0 RW | MODE n | | 15:12 | | 0x0 RW Mode | MODE n Description | | 15:12 | MODE n | | | | 15:12 | MODE n | Mode | Description | | 15:12 | MODE n Value | Mode<br>DISABLED | Description Input disabled. Pullup if DOUT is set. | | 15:12 | MODE n Value 0 1 | Mode DISABLED INPUT | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. | | 15:12 | MODE n Value 0 1 2 | Mode DISABLED INPUT INPUTPULL | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. | | 15:12 | MODE n Value 0 1 2 3 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. | | 15:12 | MODE n Value 0 1 2 3 4 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. | | 15:12 | MODE n Value 0 1 2 3 4 5 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. | | 15:12 | MODE n Value 0 1 2 3 4 5 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND WIREDANDFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output with filter. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 9 10 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND WIREDANDFILTER WIREDANDPULLUPFIL- | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output with filter. Open-drain output with pullup. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 9 10 11 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDAND WIREDAND WIREDANDFILTER WIREDANDPULLUP WIREDANDPULLUPFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output. Open-drain output with filter. Open-drain output with pullup. Open-drain output with filter and pullup. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 9 10 11 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND WIREDANDFILTER WIREDANDPULLUPFILTER WIREDANDPULLUPFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output with filter. Open-drain output with pullup. Open-drain output with filter and pullup. Open-drain output using alternate control. | | Bit | Name | Reset Access | Description | |------|--------|------------------------------|-------------------------------------------------------------------| | | 15 | WIREDANDALTPULLUP-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 11:8 | MODE2 | 0x0 RW | MODE n | | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 7:4 | MODE1 | 0x0 RW | MODE n | | | 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. | | | • | WIREDOR | Wired-or output. | | | 6 | | • | | | 7 | WIREDORPULLDOWN | Wired-or output with pull-down. | | | | | · | | | 7 | WIREDORPULLDOWN | Wired-or output with pull-down. | | Bit | Name | Reset Access | Description | |-----|-----------------|------------------------------|-------------------------------------------------------------------| | | 11 | WIREDANDPULLUPFIL-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 3:0 | MODE0<br>MODE n | 0x0 RW | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | | | | | ## 25.6.3 GPIO\_PORTA\_MODEH - mode high | Offset | Bit Position | | | | | | | | | | | | | | | |--------|----------------------------------------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--| | 0x00C | 30 30 50 50 50 50 50 50 50 50 50 50 50 50 50 | 0 7 7 3 | | | | | | | | | | | | | | | Reset | | 0×0 | | | | | | | | | | | | | | | Access | | RW | | | | | | | | | | | | | | | Name | | МОБЕО | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|----------|--------------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | MODE0 | 0x0 | RW | MODE n | | | MODE n | | | | | | Value | Mode | | Description | | | 0 | DISABLED | | Input disabled. Pullup if DOUT is set. | | | 1 | INPUT | | Input enabled. Filter if DOUT is set. | | | 2 | INPUTPUL | L | Input enabled. DOUT determines pull direction. | | | 3 | INPUTPUL | LFILTER | Input enabled with filter. DOUT determines pull direction. | | | 4 | PUSHPULL | _ | Push-pull output. | | | 5 | PUSHPULL | _ALT | Push-pull using alternate control. | | | 6 | WIREDOR | | Wired-or output. | | | 7 | WIREDORI | PULLDOWN | Wired-or output with pull-down. | | | 8 | WIREDANI | ) | Open-drain output. | | | 9 | WIREDANI | OFILTER | Open-drain output with filter. | | | 10 | WIREDANI | OPULLUP | Open-drain output with pullup. | | | 11 | WIREDANI<br>TER | OPULLUPFIL- | Open-drain output with filter and pullup. | | | 12 | WIREDANI | DALT | Open-drain output using alternate control. | | | 13 | WIREDANI | DALTFILTER | Open-drain output using alternate control with filter. | | | 14 | WIREDANI | DALTPULLUP | Open-drain output using alternate control with pullup. | | | 15 | WIREDANI<br>FILTER | DALTPULLUP- | Open-drain output using alternate control with filter and pullup. | ### 25.6.4 GPIO\_PORTA\_DOUT - data out | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|---|----|----|----|---|----|----|---|----|---|---|---|---|---|------|---|---|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | | • | | | | • | | • | • | | • | | • | | | | | | | | | | 0×0 | • | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ΑW | | | | - | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | DOUT | | | | | | Bit | Name | Reset | Access | Description | |------|-------------|-------------|--------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | DOUT | 0x0 | RW | Data output | | | Data output | | | | ### 25.6.5 GPIO\_PORTA\_DIN - data in | Offset | Bit Position | | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------| | 0x014 | 33 34 35 36 37 38 39 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>8</th> | 8 | | Reset | | 0×0 | | Access | | α | | Name | | Z<br>O | | Bit | Name | Reset | Access | Description | |------|------------|-------------|-------------------|------------------------------------------------------------------------| | 31:9 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 8:0 | DIN | 0x0 | R | Data input | | | Data input | | | | # 25.6.6 GPIO\_PORTB\_CTRL - Port control | Offset | | Bit Position OXO A C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C C | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----------|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|--------|---|----|---|---|---|---|----------|---|---|---|---|---| | 0x030 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | 3 | 2 | 1 | 0 | | Reset | | ' | | 0x0 | | | | | ' | | 0x4 | | | | | | | • | | 0×0 | | | | | | | 0x4 | | | | | | | Access | | | | RW | | | | | | | ₩<br>M | | | | | | | | | R<br>W | | | | | | | S.<br>S. | | | | | | | Name | | | | DINDISALT | | | | | | | SLEWRATEALT | | | | | | | | | DINDIS | | | | | | | SLEWRATE | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|----------------------|-------------------|----------------------------------------------------------------------| | 31:29 | Reserved | To ensure coventions | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 28 | DINDISALT | 0x0 | RW | Data In Disable Alt | | | Data input disable for por | t pins using a | Iternate modes. | | | 27:23 | Reserved | To ensure co | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 22:20 | SLEWRATEALT | 0x4 | RW | Slew Rate Alt | | | Slewrate limit for port pin | s using alterna | ate modes. High | er values representer faster slewrates. | | 19:13 | Reserved | To ensure coventions | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 12 | DINDIS | 0x0 | RW | Data In Disable | | | Data input disable for por | t pins not usir | ng alternate mod | des. | | 11:7 | Reserved | To ensure c | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 6:4 | SLEWRATE | 0x4 | RW | Slew Rate | | | Slewrate limit for port pin | s using not all | ternate modes. I | Higher values representer faster slewrates. | | 3:0 | Reserved | To ensure co | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | ## 25.6.7 GPIO\_PORTB\_MODEL - mode low | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | | | |--------|----------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|----|----|------------------|------|------|-----------|----------|----|-----|----------|----------|---|---|----------|----------|---|---|----------|---|---|--|--| | 0x034 | 24 25 27 28 29 29 29 29 29 29 29 29 29 29 29 29 29 | | | | | | | | | | | | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | | | Reset | 22 23 24 25 26 27 28 28 28 28 28 28 28 28 28 28 28 28 28 | | | | | | | | | | | | | 2 | 2 | | | 2 | 2 | | 0x0 | | | | | 2 | OX O | | | 0x0 | | | | | | Access | | | | | | | | | | | | | RW | | | | | <u> </u> | <u>}</u> | | | <u> </u> | <u>}</u> | | | <u> </u> | <u>}</u> | | | <u> </u> | 2 | | | | | Name | | | | | | | | | | | | | | | 2<br>7<br>7<br>4 | | | Z I C C I | MODES | | | MODE2 | MODE 1 | | | נים כו | NO N | | | OD CON | | | | | | Bit | Name | Reset Access | Description | |-------|----------|----------------------------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure compatibility wi<br>ventions | th future devices, always write bits to 0. More information in 1.2 Con | | 19:16 | MODE4 | 0x0 RW | MODE n | | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 15:12 | MODE3 | 0x0 RW | MODE n | | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 1:8 | MODE2 | 0x0 RW | MODE n | | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | ː4 | MODE1 | 0x0 RW | MODE n | | | MODE n | | | | Bit | Name | Reset Access | Description | |-----|--------|------------------------------|-------------------------------------------------------------------| | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 3:0 | MODE0 | 0x0 RW | MODE n | | | 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-<br>TER | Open-drain output with filter and pullup. | | | | | | | | 12 | WIREDANDALT | Open-drain output using alternate control. | | Bit | Name | Reset | Access | Description | |-----|------|--------------------|------------|-------------------------------------------------------------------| | | 14 | WIREDAND | ALTPULLUP | Open-drain output using alternate control with pullup. | | | 15 | WIREDAND<br>FILTER | ALTPULLUP- | Open-drain output using alternate control with filter and pullup. | ## 25.6.8 GPIO\_PORTB\_DOUT - data out | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|--------|---|---| | 0x040 | 31 | 30 | 53 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0×0 | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ŋ<br>N | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DOUT | | | | Bit | Name | Reset | Access | Description | |------|-------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:5 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 4:0 | DOUT | 0x0 | RW | Data output | | | Data output | | | | ## 25.6.9 GPIO\_PORTB\_DIN - data in | Offset | | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|----|---|---|---|---|---|----------|---|---| | 0x044 | 3 | 5 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | • | • | | | | | • | | | | | • | | • | | | | | | | | | | • | • | | | 0x0 | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u>~</u> | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N<br>O | | | | Bit | Name | Reset | Access | Description | |------|------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:5 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 4:0 | DIN | 0x0 | R | Data input | | | Data input | | | | # 25.6.10 GPIO\_PORTC\_CTRL - Port control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|-----------|----|----|----|----|----|----|-------------|----|----|----|----|------|------|----|----|--------|---|----|---|---|---|---|----------|---|---|---|---|---| | 0x060 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | 0x0 | | • | • | | | | 0x4 | • | | | | • | | • | | 0×0 | | | | • | | | 0x4 | | | | | | | Access | | | | ₩<br>M | | | | | | | R<br>M | | | | | | | | | Z. | | | | | | | R<br>M | | | | | | | Name | | | | DINDISALT | | | | | | | SLEWRATEALT | | | | | | | | | DINDIS | | | | | | | SLEWRATE | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|-----------------|--------------------|------------------------------------------------------------------------| | 31:29 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 28 | DINDISALT | 0x0 | RW | Data In Disable Alt | | | Data input disable for po | rt pins using a | alternate modes | | | 27:23 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 22:20 | SLEWRATEALT | 0x4 | RW | Slew Rate Alt | | | Slewrate limit for port pin | s using altern | ate modes. Hig | ner values representer faster slewrates. | | 19:13 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 12 | DINDIS | 0x0 | RW | Data In Disable | | | Data input disable for po | rt pins not usi | ng alternate mo | des. | | 11:7 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 6:4 | SLEWRATE | 0x4 | RW | Slew Rate | | | Slewrate limit for port pin | s using not a | ternate modes. | Higher values representer faster slewrates. | | 3:0 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | ### 25.6.11 GPIO\_PORTC\_MODEL - mode low | Offset | | | | | | | | | | | | | | | Ві | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|-------|-------|----|----|----|----------|----|-----------------------------------------|---------|-------|----|----|-----|-------|------|-------|----|-----------------|----|---|-------|---|---|---|----------|----------|---|---|---|---|---| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | 2 | 2 | | | 2 | e<br>X | | | \$W 0X0 | | | | | Š | | | 2 | OX O | | | 2 | 2 | | | > | 2 | • | | 2 | 3 | | | Access | | 2 | 2 | | | 2 | <u>}</u> | | RW 0x0 RW 0x0 | | | | | | 7 | 2 | | | | | | | | | | | | | | | | | | Name | | 71007 | NO PL | | | | MODE | | | _ | MODES | | | , L | MODE4 | | | | NOUN<br>CHOOLES | | | MODES | ) | | | MON<br>T | <u> </u> | | | | | | | 3it | Name | Reset | Access | Description | |-------|--------|-------------------|--------------|-------------------------------------------------------------------| | 31:28 | MODE7 | 0x0 | RW | MODE n | | | MODE n | | | | | | Value | Mode | | Description | | | 0 | DISABLE | D | Input disabled. Pullup if DOUT is set. | | | 1 | INPUT | | Input enabled. Filter if DOUT is set. | | | 2 | INPUTPU | LL | Input enabled. DOUT determines pull direction. | | | 3 | INPUTPU | LLFILTER | Input enabled with filter. DOUT determines pull direction. | | | 4 | PUSHPU | LL | Push-pull output. | | | 5 | PUSHPU | LLALT | Push-pull using alternate control. | | | 6 | WIREDO | ₹ | Wired-or output. | | | 7 | WIREDO | RPULLDOWN | Wired-or output with pull-down. | | | 8 | WIREDAN | ND | Open-drain output. | | | 9 | WIREDA | NDFILTER | Open-drain output with filter. | | | 10 | WIREDA | NDPULLUP | Open-drain output with pullup. | | | 11 | WIREDAN<br>TER | NDPULLUPFIL- | Open-drain output with filter and pullup. | | | 12 | WIREDA | NDALT | Open-drain output using alternate control. | | | 13 | WIREDA | NDALTFILTER | Open-drain output using alternate control with filter. | | | 14 | WIREDAN | NDALTPULLUP | Open-drain output using alternate control with pullup. | | | 15 | WIREDAI<br>FILTER | NDALTPULLUP- | Open-drain output using alternate control with filter and pullup. | | 7:24 | MODE6 | 0x0 | RW | MODE n | | | MODE n | | | | | | Value | Mode | | Description | | | 0 | DISABLE | D | Input disabled. Pullup if DOUT is set. | | | 1 | INPUT | | Input enabled. Filter if DOUT is set. | | | 2 | INPUTPU | LL | Input enabled. DOUT determines pull direction. | | | 3 | INPUTPU | LLFILTER | Input enabled with filter. DOUT determines pull direction. | | Bit | Name | Reset Acc | ess | Description | |-------|-----------------|------------------------------------------|---------|---------------------------------------------------------------------------------------| | | 4 | PUSHPULL | | Push-pull output. | | | 5 | PUSHPULLALT | | Push-pull using alternate control. | | | 6 | WIREDOR | | Wired-or output. | | | 7 | WIREDORPULL | OOWN | Wired-or output with pull-down. | | | 8 | WIREDAND | | Open-drain output. | | | 9 | WIREDANDFILT | ER | Open-drain output with filter. | | | 10 | WIREDANDPULI | _UP | Open-drain output with pullup. | | | 11 | WIREDANDPULI<br>TER | UPFIL- | Open-drain output with filter and pullup. | | | 12 | WIREDANDALT | | Open-drain output using alternate control. | | | 13 | WIREDANDALTF | FILTER | Open-drain output using alternate control with filter. | | | 14 | WIREDANDALTF | PULLUP | Open-drain output using alternate control with pullup. | | | 15 | WIREDANDALTF<br>FILTER | PULLUP- | Open-drain output using alternate control with filter and pullup | | 23:20 | MODE5<br>MODE n | 0x0 RW | | 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 | INPUTPULLFILT | ER | 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-<br>TER<br>WIREDANDALT | | Open-drain output with filter and pullup. Open-drain output using alternate control. | | | 12 | | | | | | 13 | WIREDANDALTF | FILTER | Open-drain output using alternate control with filter. | | | 14 | WIREDANDALTE | PULLUP | Open-drain output using alternate control with pullup. | | | 15 | WIREDANDALTF<br>FILTER | PULLUP- | Open-drain output using alternate control with filter and pullup | | 19:16 | MODE4 | 0x0 RW | | MODE n | | | MODE n | | | | | Bit | Name | Reset Access | Description | |-------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 15:12 | | | | | 15:12 | MODE3 | 0x0 RW | MODE n | | 15:12 | MODE3<br>MODE n | 0x0 RW | MODE n | | 15:12 | | 0x0 RW Mode | MODE n Description | | 15:12 | MODE n | | | | 15:12 | MODE n | Mode | Description | | 15:12 | MODE n Value | Mode<br>DISABLED | Description Input disabled. Pullup if DOUT is set. | | 15:12 | MODE n Value 0 1 | Mode DISABLED INPUT | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. | | 15:12 | MODE n Value 0 1 2 | Mode DISABLED INPUT INPUTPULL | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. | | 15:12 | MODE n Value 0 1 2 3 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. | | 15:12 | MODE n Value 0 1 2 3 4 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. | | 15:12 | MODE n Value 0 1 2 3 4 5 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. | | 15:12 | MODE n Value 0 1 2 3 4 5 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND WIREDANDFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output with filter. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 9 10 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND WIREDANDFILTER WIREDANDPULLUPFIL- | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output with filter. Open-drain output with pullup. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 9 10 11 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDAND WIREDAND WIREDANDFILTER WIREDANDPULLUP WIREDANDPULLUPFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output with filter. Open-drain output with pullup. Open-drain output with filter and pullup. | | 15:12 | MODE n Value 0 1 2 3 4 5 6 7 8 9 10 11 | Mode DISABLED INPUT INPUTPULL INPUTPULLFILTER PUSHPULL PUSHPULLALT WIREDOR WIREDORPULLDOWN WIREDAND WIREDANDFILTER WIREDANDPULLUPFILTER WIREDANDPULLUPFILTER | Description Input disabled. Pullup if DOUT is set. Input enabled. Filter if DOUT is set. Input enabled. DOUT determines pull direction. Input enabled with filter. DOUT determines pull direction. Push-pull output. Push-pull using alternate control. Wired-or output. Wired-or output with pull-down. Open-drain output with filter. Open-drain output with pullup. Open-drain output with filter and pullup. Open-drain output using alternate control. | | Bit | Name | Reset Access | Description | |------|--------|------------------------------|-------------------------------------------------------------------| | | 15 | WIREDANDALTPULLUP-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 11:8 | MODE2 | 0x0 RW | MODE n | | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 7:4 | MODE1 | 0x0 RW | MODE n | | | 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. | | | • | | · | | Bit | Name | Reset Access | Description | |-----|-----------------|------------------------------|-------------------------------------------------------------------| | | 11 | WIREDANDPULLUPFIL-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 3:0 | MODE0<br>MODE n | 0x0 RW | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | ### 25.6.12 GPIO\_PORTC\_DOUT - data out | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---------|---|---|---|---| | 0x070 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - | 0 | | Reset | | | | • | • | | • | | | • | | • | | • | | • | | • | • | | | | | | | | • | OX<br>O | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8 | 2 | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | TITOL | - | | | | | Bit | Name | Reset | Access | Description | |------|-------------|-------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | DOUT | 0x0 | RW | Data output | | | Data output | | | | ### 25.6.13 GPIO\_PORTC\_DIN - data in | Offset | Bit Position | | |--------|--------------|-----------------| | 0x074 | 1 | - 0 r 4 w 7 - 0 | | Reset | | 0×0 | | Access | | <u>«</u> | | Name | | N<br>Q | | Bit | Name | Reset | Access | Description | |------|------------|-------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | DIN | 0x0 | R | Data input | | | Data input | | | | # 25.6.14 GPIO\_PORTD\_CTRL - Port control | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|-----------|----|----|----|----|----|----|-------------|----|----|----|----|------|------|----|----|--------|---|----|---|---|---|---|----------|---|---|---|---|---| | 0x090 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | 0x0 | | • | | | | | 0x4 | • | | • | | | | | | 0×0 | | | | • | • | | 0x4 | | | | | | | Access | | | | ₩<br>M | | | | | | | ₩<br>M | | | | | | | | | W. | | | | | | | Z. | | | | | | | Name | | | | DINDISALT | | | | | | | SLEWRATEALT | | | | | | | | | DINDIS | | | | | | | SLEWRATE | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------------|-----------------|--------------------|----------------------------------------------------------------------| | 31:29 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 28 | DINDISALT | 0x0 | RW | Data In Disable Alt | | | Data input disable for po | rt pins using a | alternate modes. | | | 27:23 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 22:20 | SLEWRATEALT | 0x4 | RW | Slew Rate Alt | | | Slewrate limit for port pir | s using altern | ate modes. High | ner values representer faster slewrates. | | 19:13 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 12 | DINDIS | 0x0 | RW | Data In Disable | | | Data input disable for po | rt pins not usi | ng alternate mod | des. | | 11:7 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 6:4 | SLEWRATE | 0x4 | RW | Slew Rate | | | Slewrate limit for port pir | s using not al | ternate modes. | Higher values representer faster slewrates. | | 3:0 | Reserved | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | ### 25.6.15 GPIO\_PORTD\_MODEL - mode low | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|-----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|-------|----|---|-------|---|---|---|----------|----------|---|---|---|-------|---| | 0x094 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | • | | | | | • | | • | | • | | Š | Š | | | Š | ! | | | 2 | 2 | | | 2 | 2 | | | Access | MA WA WA WA OX OX | | | | | | | | | | | | | | 2 | Ž | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | MODES | | | MODE2 | | | | בח מיס א | <u> </u> | | | | NOD I | | | Bit | Name | Reset Access | Description | |-------|----------|----------------------------------------|------------------------------------------------------------------------| | 31:16 | Reserved | To ensure compatibility wi<br>ventions | th future devices, always write bits to 0. More information in 1.2 Con | | 15:12 | MODE3 | 0x0 RW | MODE n | | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup. | | 11:8 | MODE2 | 0x0 RW | MODE n | | | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup | | 7:4 | MODE1<br>MODE n | 0x0 RW | 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-<br>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-<br>FILTER | Open-drain output using alternate control with filter and pullup | | -0 | MODE0 | 0x0 RW | MODE n | | 3:0 | | • | | | Bit | Name | Reset | Access | Description | |-----|-------|---------------------|------------|-------------------------------------------------------------------| | | 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 | INPUTPULL | FILTER | Input enabled with filter. DOUT determines pull direction. | | | 4 | PUSHPULL | | Push-pull output. | | | 5 | PUSHPULL | ALT | Push-pull using alternate control. | | | 6 | WIREDOR | | Wired-or output. | | | 7 | WIREDORP | ULLDOWN | Wired-or output with pull-down. | | | 8 | WIREDAND | | Open-drain output. | | | 9 | WIREDAND | FILTER | Open-drain output with filter. | | | 10 | WIREDAND | PULLUP | Open-drain output with pullup. | | | 11 | WIREDAND<br>TER | PULLUPFIL- | Open-drain output with filter and pullup. | | | 12 | WIREDAND | ALT | Open-drain output using alternate control. | | | 13 | WIREDAND | ALTFILTER | Open-drain output using alternate control with filter. | | | 14 | WIREDAND | ALTPULLUP | Open-drain output using alternate control with pullup. | | | 15 | WIREDAND.<br>FILTER | ALTPULLUP- | Open-drain output using alternate control with filter and pullup. | ## 25.6.16 GPIO\_PORTD\_DOUT - data out | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|---|-----|---|---| | 0x0A0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ∞ | 7 | 9 | 2 | 4 | က | 7 | _ | 0 | | Reset | | • | • | • | • | | • | • | • | • | | • | | | | | | ' | • | • | | | | | ' | • | ' | • | | 2 | 3 | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | × | 2 | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TIO | 5 | | | Bit | Name | Reset | Access | Description | | | | | | | |------|-------------|--------------------|---------------------------|---------------------------------------------------------------------------|--|--|--|--|--|--| | 31:4 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | 3:0 | DOUT | 0x0 | 0x0 RW <b>Data output</b> | | | | | | | | | | Data output | | | | | | | | | | # 25.6.17 GPIO\_PORTD\_DIN - data in | Offset | Bit Position | | |--------|-------------------------------------------------------------------|----------| | 0x0A4 | 31 31 32 33 33 34 35 35 35 36 36 36 36 36 36 36 36 36 36 36 36 36 | 0 7 7 3 | | Reset | | 0x0 | | Access | | <b>C</b> | | Name | | N<br>O | | Bit | Name | Reset | Access | Description | |------|------------|-------------|--------------------|------------------------------------------------------------------------| | 31:4 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | DIN | 0x0 | R | Data input | | | Data input | | | | # 25.6.18 GPIO\_LOCK - Lock Register | Offset | Bit Posi | ition | |--------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x300 | 30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>3 | 5 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Reset | | 0xA534 | | Access | | > | | Name | | LOCKKEY | | Bit | Name | Reset | Access | Description | | | | | | | | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------|------------------------|--|--|--|--|--|--|--| | 31:16 | Reserved | To ensure ventions | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 15:0 | LOCKKEY | 0xA534 | W | Configuration Lock Key | | | | | | | | | | Write any other value than the unlock code to lock configuration registers. Write the unlock code to unlock (See t detailed list of configuration registers.) | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | 42292 | UNLOCK | | Unlock code | | | | | | | | ### 25.6.19 GPIO\_GPIOLOCKSTATUS - Lock Status | Offset | Bit Position | | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | 0x310 | 33 4 4 5 6 6 6 7 7 8 8 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 0 | | Reset | | 0x0 | | Access | | œ | | Name | | LOCK | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|-------------------------------------------------|--------------------|-----------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:1 | Reserved | To ensure ventions | compatibility v | ith future devices, always write bits to 0. More information in 1.2 Co | | | | | | | | | | 0 | LOCK | 0x0 | R | GPIO LOCK status | | | | | | | | | | | Indicates current lock status of GPIO registers | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | 0 | UNLOCKE | ΞD | Registers are unlocked | | | | | | | | | | | 1 | LOCKED | | Registers are locked | | | | | | | | | | | | | | | | | | | | | | | ### 25.6.20 GPIO\_ABUSALLOC - A Bus allocation | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|-------|----------------------------------------------------------|--|--|--|-----|--|----|----|---------|----|----|----------|-----|----|----|----|---------------------------------------------------|---------|----------|-----------|--|--|---|---|--------|--------|---|---|---|---|---| | 0x320 | 31 | 31<br>30<br>30<br>29<br>27<br>27<br>26<br>27<br>27<br>27 | | | | | | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 4 1 2 1 2 2 | | | 2 0 0 8 m | | | ω | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | 0x0 | | | | | 0×0 | | | | | | | | 0×0 | | | | | | | | | | | • | | > | 3 | | | | | | Access | | RW | | | | | | | | | | 2 | <u>}</u> | | | | | | | <u> </u> | 2 | | | | | | A<br>W | | | | | | | Name | AODD1 | | | | | | | | | AODD0 F | | | | | | | | | AEVEN14 | | | | | | | AEVENO | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | |-------|-----------------------|--------------------|-----------------|---------------------------------------------------------------------------|--|--|--|--|--| | 31:28 | Reserved | To ensure ventions | compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 27:24 | AODD1 | 0x0 | RW | A Bus Odd 1 | | | | | | | | peripheral allocati | on to A Bus Odd 1 | | | | | | | | | | Value | Mode | | Description | | | | | | | | 0 | TRISTATE | | The bus is not allocated | | | | | | | | 1 | ADC0 | | The bus is allocated to ADC0 | | | | | | | 23:20 | Reserved | To ensure ventions | compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 19:16 | AODD0 | 0x0 | RW | A Bus Odd 0 | | | | | | | | peripheral allocation | on to A Bus Odd 0 | | | | | | | | | | Value | Mode | | Description | | | | | | | | 0 | TRISTATE | | The bus is not allocated | | | | | | | | 1 | ADC0 | | The bus is allocated to ADC0 | | | | | | | 15:12 | Reserved | To ensure ventions | compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 11:8 | AEVEN1 | 0x0 | RW | A Bus Even 1 | | | | | | | | peripheral allocati | on to A Bus Even 1 | | | | | | | | | | Value | Mode | | Description | | | | | | | | 0 | TRISTATE | | The bus is not allocated | | | | | | | | 1 | ADC0 | | The bus is allocated to ADC0 | | | | | | | 7:4 | Reserved | To ensure ventions | compatibility w | rith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | 3:0 | AEVEN0 | 0x0 | RW | A Bus Even 0 | | | | | | | | peripheral allocation | on to A Bus Even 0 | | | | | | | | | | Value | Mode | | Description | | | | | | | | 0 | TRISTATE | | The bus is not allocated | | | | | | | | 1 | ADC0 | | The bus is allocated to ADC0 | | | | | | GPIO - General Purpose Input/Output | Bit Name Reset Access | |-----------------------| |-----------------------| ### 25.6.21 GPIO\_BBUSALLOC - B Bus allocation | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|-------|----------------------------------------------------------|--|--|-------|-----|----|----|----|----|--------|----|----|-----|----|----|---|----|----|----------|----|---|---|--------|---|-----|----------|----------|---|---|---| | 0x324 | 31 | 31<br>30<br>29<br>28<br>27<br>27<br>26<br>26<br>27<br>27 | | | | | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 19 | 6 | œ | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | Reset | 0x0 | | | | | 0×0 | | | | | | | | 0×0 | | | | | | | | | | | | 0×0 | | | | | | | Access | RW | | | | | | | | | | ₩<br>M | | | | | | | | 2 | <u>}</u> | | | | | | | <u> </u> | <u>}</u> | | | | | Name | BODD1 | | | | ВОРРО | | | | | | | | | | | | | | | | | | | BEVENO | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------|-----------------------|-----------------|---------------------------------------------------------------------------| | 31:28 | Reserved | To ensure<br>ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 27:24 | BODD1 | 0x0 | RW | B Bus Odd 1 | | | peripheral allocati | on to B Bus Odd 1 | | | | | Value | Mode | | Description | | | 0 | TRISTATE | Ξ | The bus is not allocated | | | 1 | ADC0 | | The bus is allocated to ADC0 | | 23:20 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | BODD0 | 0x0 | RW | B Bus Odd 0 | | | peripheral allocati | on to B Bus Odd 0 | | | | | Value | Mode | | Description | | | 0 | TRISTATE | Ξ | The bus is not allocated | | | 1 | ADC0 | | The bus is allocated to ADC0 | | 15:12 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 11:8 | BEVEN1 | 0x0 | RW | B Bus Even 1 | | | peripheral allocati | on to B Bus Even 1 | I | | | | Value | Mode | | Description | | | 0 | TRISTATE | Ē | The bus is not allocated | | | 1 | ADC0 | | The bus is allocated to ADC0 | | 7:4 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | BEVEN0 | 0x0 | RW | B Bus Even 0 | | | peripheral allocati | on to B Bus Even ( | ) | | | | Value | Mode | | Description | | | 0 | TRISTATE | Ξ | The bus is not allocated | | | 1 | ADC0 | | The bus is allocated to ADC0 | Bit Name Reset Access Description ### 25.6.22 GPIO\_CDBUSALLOC - CD Bus allocation | Offset | | | | Bit Po | sition | | | | |--------|----------|----------------------|----------------|-------------|-----------------------------------------------|---------|-------|---------| | 0x328 | 30 29 28 | 27<br>26<br>25<br>24 | 23 22 21 20 20 | 18 19 19 19 | 5 4 5 7 4 5 5 6 | 11 0 8 | 7 6 7 | 0 7 8 | | Reset | | 0x0 | | 0x0 | | 0x0 | | 0x0 | | Access | | RW | | RW | | RW | | RW | | Name | | CDODD1 | | свовво | | CDEVEN1 | | CDEVENO | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:28 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 27:24 | CDODD1 | 0x0 | RW | CD Bus Odd 1 | | | peripheral allocation | on to CD Bus Odd | 1 | | | | Value | Mode | | Description | | | 0 | TRISTATI | Ξ | The bus is not allocated | | | 1 | ADC0 | | The bus is allocated to ADC0 | | 23:20 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | CDODD0 | 0x0 | RW | CD Bus Odd 0 | | | peripheral allocation | on to CD Bus Odd | 0 | | | | Value | Mode | | Description | | | 0 | TRISTATI | Ē | The bus is not allocated | | | 1 | ADC0 | | The bus is allocated to ADC0 | | 15:12 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 11:8 | CDEVEN1 | 0x0 | RW | CD Bus Even 1 | | | peripheral allocation | on to CD Bus Ever | า 1 | | | | Value | Mode | | Description | | | 0 | TRISTATI | Ē | The bus is not allocated | | | 1 | ADC0 | | The bus is allocated to ADC0 | | 7:4 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | CDEVEN0 | 0x0 | RW | CD Bus Even 0 | | | peripheral allocation | on to CD Bus Ever | 0 ח | | | | Value | Mode | | Description | | | 0 | TRISTATI | Ξ | The bus is not allocated | | Bit | Name | Reset | Access | Description | |-----|------|-------|--------|------------------------------| | | 1 | ADC0 | | The bus is allocated to ADC0 | ### 25.6.23 GPIO\_EXTIPSELL - External Interrupt Port Select Low | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|------------|----------|----|----|----|-----------|----|----|-------------|------|----|----|------------|------|------|----|-----|-----------|---|----|---|-----------|---|---|-------------|----------|---|---|-----------|---------| | 0x400 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | 5 | e e | | | 2 | Š | | | 5 | OX O | | • | 2 | 2 | | • | 6 | Š | | | ç | Š | | | 5 | e e | | | 0 | 25 | | Access | | | ک<br>م | <u>}</u> | | | 2 | <u>}</u> | | | 2 | Ž | | | 2 | 2 | | | Š | <b>≩</b> | | | Š | <b>≩</b> | | | 2 | <u>}</u> | | | /\0 | ^<br>Y | | Name | | | EVTIDOE! 7 | III | | | | EXIIPSELO | | | A I I OCITY | | | | EVTIDOE! 4 | 7 | | | I C | EXIIPSELS | | | | EXIIPSELZ | | | 1 I I I I I | | | | EXTIDOELO | VIITOEL | | Bit | Name | Reset | Access | Description | |-------|----------------------|---------------------|-----------------|--------------------------------------------------------------------------| | 31:30 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 29:28 | EXTIPSEL7 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 7 (E | XTI7). | | | | 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 | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 25:24 | EXTIPSEL6 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 6 (E | XTI6). | | | | 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 | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 21:20 | EXTIPSEL5 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 5 (E | XTI5). | | | | 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 | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 17:16 | EXTIPSEL4 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 4 (E) | KTI4). | | | | 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 | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 13:12 | EXTIPSEL3 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 3 (E) | KTI3). | | | | 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 ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | EXTIPSEL2 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 2 (E) | KTI2). | | | | 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 ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | EXTIPSEL1 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 1 (E) | KTI1). | | | | 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 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | EXTIPSEL0 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal interrupt 0 (E | XTI0). | | | | 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 | ### 25.6.24 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 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | | | ' | | ' | | | | | | | • | ' | | | | Š | S<br>S | | | Š | )<br>X | | | Š | )<br>X | | | Š | OXO | | Access | | NA N | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | EXIIPSEL3 | | | | IFVE | | | 1 I I I I I | 73EL | | | | | | Bit | Name | Reset | Access | Description | |-------|----------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:14 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 13:12 | EXTIPSEL3 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal 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 ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | EXTIPSEL2 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal 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 ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | EXTIPSEL1 | 0x0 | RW | External Interrupt Port Select | | | Port select for exte | rnal 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 | | | Reserved EXTIPSEL0 | To ensure coventions | ompatibility with | future devices, always write bits to 0. More information in 1.2 Con- | |---|------------------------------|----------------------|-------------------|----------------------------------------------------------------------| | | EXTIPSEL0 | ۸۷۸ | | | | | | UXU | RW | External Interrupt Port Select | | | Port select for external int | errupt 0+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 | ### 25.6.25 GPIO\_EXTIPINSELL - External Interrupt Pin Select Low | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | |--------|----|----|---------------|----|----|----|----------------|------------|----|----|----|-------------|----|----|---------------|------|-------|----|----------|----------|---|----|---|----------|---|---|---|----------|---|---|-------------| | 0x408 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | 2 | 3 | | • | Ş | OX<br>O | | • | Š | e<br>S | | • | 2 | 2 | | • | Š | e<br>X | | | ç | e<br>S | | • | 2 | OXO | | | 0x0 | | Access | | | <u> </u> | 2 | | | ٤ | <u>}</u> | | | 2 | ₩. | | | ٥ | 2 | | | 2 | <u>}</u> | | | Š | <u>}</u> | | | Š | <u>}</u> | | | RW | | Name | | | EXTIDINICEI 7 | 1 | | | I I O NI O I E | EVILLIANCE | | | | EXTIPINSEL5 | | | EXTIBINISE! 4 | | | | C HOMBIE | PINSEL | | | | | | | ₽ | | | | EXTIPINSELO | | Bit | Name | Reset | Access | Description | |-------|------------------------|------------------|--------------------|----------------------------------------------------------------------| | 31:30 | Reserved | To ensure c | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 29:28 | EXTIPINSEL7 | 0x0 | RW | External Interrupt Pin select | | | OFFSET select for Exte | rnal Interrupt 7 | ' (EXTI7). | | | | Value | Mode | | Description | | | 0 | OFFSET0 | | OFFSET=0 | | | 1 | OFFSET1 | | OFFSET=1 | | | 2 | OFFSET2 | | OFFSET=2 | | | 3 | OFFSET3 | | OFFSET=3 | | 27:26 | Reserved | To ensure c | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 25:24 | EXTIPINSEL6 | 0x0 | RW | External Interrupt Pin select | | | OFFSET select for Exte | rnal Interrupt 6 | 6 (EXTI6). | | | | Value | Mode | | Description | | | 0 | OFFSET0 | | OFFSET=0 | | | 1 | OFFSET1 | | OFFSET=1 | | | 2 | OFFSET2 | | OFFSET=2 | | | 3 | OFFSET3 | | OFFSET=3 | | 23:22 | Reserved | To ensure c | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 21:20 | EXTIPINSEL5 | 0x0 | RW | External Interrupt Pin select | | | OFFSET select for Exte | rnal Interrupt 5 | 5 (EXTI5). | | | | Value | Mode | | Description | | | 0 | OFFSET0 | | OFFSET=0 | | | 1 | OFFSET1 | | OFFSET=1 | | | 2 | OFFSET2 | | OFFSET=2 | | | 3 | OFFSET3 | | OFFSET=3 | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | | |-------|------------------------|--------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 19:18 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 17:16 | EXTIPINSEL4 | 0x0 | RW | External Interrupt Pin select | | | | | | | | | | | | | OFFSET select for Exte | ernal Interrupt | 4 (EXTI4). | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | 0 | OFFSET0 | | OFFSET=0 | | | | | | | | | | | | | 1 | OFFSET1 | | OFFSET=1 | | | | | | | | | | | | | 2 | OFFSET2 | | OFFSET=2 | | | | | | | | | | | | | 3 | OFFSET3 | | OFFSET=3 | | | | | | | | | | | | 15:14 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 13:12 | EXTIPINSEL3 | 0x0 | RW | External Interrupt Pin select | | | | | | | | | | | | | OFFSET select for Exte | ernal Interrupt | 3 (EXTI3). | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | 0 | OFFSET0 | | OFFSET=0 | | | | | | | | | | | | | 1 | OFFSET1 | | OFFSET=1 | | | | | | | | | | | | | 2 | OFFSET2 | | OFFSET=2 | | | | | | | | | | | | | 3 | OFFSET3 | | OFFSET=3 | | | | | | | | | | | | 11:10 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 9:8 | EXTIPINSEL2 | 0x0 | RW | External Interrupt Pin select | | | | | | | | | | | | | OFFSET select for Exte | ernal Interrupt | 2 (EXTI2). | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | 0 | OFFSET0 | | OFFSET=0 | | | | | | | | | | | | | 1 | OFFSET1 | | OFFSET=1 | | | | | | | | | | | | | 2 | OFFSET2 | | OFFSET=2 | | | | | | | | | | | | | 3 | OFFSET3 | | OFFSET=3 | | | | | | | | | | | | 7:6 | Reserved | To ensure ventions | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 5:4 | EXTIPINSEL1 | 0x0 | RW | External Interrupt Pin select | | | | | | | | | | | | | OFFSET select for Exte | ernal Interrupt | 1 (EXTI1). | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | 0 | OFFSET0 | | OFFSET=0 | | | | | | | | | | | | | 1 | OFFSET1 | | OFFSET=1 | | | | | | | | | | | | | 2 | OFFSET2 | | OFFSET=2 | | | | | | | | | | | | | 3 | OFFSET3 | | OFFSET=3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-----|---------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 3:2 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | EXTIPINSEL0 | 0x0 | RW | External Interrupt Pin select | | | OFFSET select for E | External Interrup | t 0 (EXTI0). | | | | Value | Mode | | Description | | | 0 | OFFSET | ) | OFFSET=0 | | | 1 | OFFSET1 | | OFFSET=1 | | | 2 | OFFSET2 | 2 | OFFSET=2 | | | 3 | OFFSET3 | 3 | OFFSET=3 | ### 25.6.26 GPIO\_EXTIPINSELH - External Interrupt Pin Select High | Offset | Bit Position | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | 0x40C | 33 34 36 37 38 39 30 30 30 31 32 33 34 36 37 38 39 30 30 30 30 30 30 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1</th> | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Reset | | 000000000000000000000000000000000000000 | | Access | | X X X XX | | Name | | EXTIPINSEL2 EXTIPINSEL1 EXTIPINSEL1 EXTIPINSEL0 | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:14 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 13:12 | EXTIPINSEL3 | 0x0 | RW | External Interrupt Pin select | | | OFFSET select for E | External Interrupt | t {b+8} (EXTI{b | +8}). | | | Value | Mode | | Description | | | 0 | OFFSET8 | | OFFSET=8 | | | 1 | OFFSET9 | | OFFSET=9 | | | 2 | OFFSET1 | 0 | OFFSET=10 | | | 3 | OFFSET1 | 1 | OFFSET=11 | | 11:10 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 9:8 | EXTIPINSEL2 | 0x0 | RW | External Interrupt Pin select | | | OFFSET select for E | External Interrup | t {b+8} (EXTI{b | +8}). | | | Value | Mode | | Description | | | 0 | OFFSET8 | | OFFSET=8 | | | 1 | OFFSET9 | | OFFSET=9 | | | 2 | OFFSET1 | 0 | OFFSET=10 | | | 3 | OFFSET1 | 1 | OFFSET=11 | | 7:6 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 5:4 | EXTIPINSEL1 | 0x0 | RW | External Interrupt Pin select | | | OFFSET select for E | External Interrupt | t {b+8} (EXTI{b | +8}). | | | Value | Mode | | Description | | | 0 | OFFSET8 | | OFFSET=8 | | | 1 | OFFSET9 | | OFFSET=9 | | | 2 | OFFSET1 | 0 | OFFSET=10 | | | 3 | OFFSET1 | 1 | OFFSET=11 | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | | |-----|---------------------|--------------------|-----------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 3:2 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | | 1:0 | EXTIPINSEL0 | 0x0 | RW | External Interrupt Pin select | | | | | | | | | | | | | OFFSET select for I | External Interrup | t {b+8} (EXTI{b | I{b+8}). | | | | | | | | | | | | | Value | Mode | | Description | | | | | | | | | | | | | 0 | OFFSET8 | | OFFSET=8 | | | | | | | | | | | | | 1 | OFFSET9 | | OFFSET=9 | | | | | | | | | | | | | 2 | OFFSET1 | 0 | OFFSET=10 | | | | | | | | | | | | | 3 OFFS | | 1 | OFFSET=11 | | | | | | | | | | | | | | | | | | | | | | | | | | | ## 25.6.27 GPIO\_EXTIRISE - External Interrupt Rising Edge Trigger | Offset | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----|---|---|---|---|---------|---|---|---|---|---| | 0x410 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | ' | | • | | • | | | | • | ' | • | • | • | • | • | | | | | • | | ( | OX<br>O | | | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | Ž | ≩ | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | Ē | EXIMINE | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |-------|----------------------------|----------------------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:12 | Reserved | To ensure o | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 11:0 | EXTIRISE | 0x0 | RW | EXT Int Rise | | | | | | | | | | | | External Interrupt n Risin | Rising Edge Trigger Enable | | | | | | | | | | | | ## 25.6.28 GPIO\_EXTIFALL - External Interrupt Falling Edge Trigger | Offset | Bit Position | | | | | | | | | | | | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x414 | 33 34 35 36 37 38 39 30 30 31 32 33 34 35 36 37 38 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</th> | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | | | | | Reset | | 0×0 | | | | | | | | | | | | | Access | | X<br>N | | | | | | | | | | | | | Name | | EXTIFALL | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |-------|----------------------------|-----------------------|-------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:12 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 11:0 | EXTIFALL | 0x0 | RW | EXT Int FALL | | | | | | | | | | | | External Interrupt n Falli | g Edge Trigger Enable | | | | | | | | | | | | # 25.6.29 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 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | 000 | 0x0 | 000 | 0x0 | 000 | 0x0 | 000 | 000 | 000 | 000 | 000 | 000 | | | • | • | 000 | 000 | 000 | 000 | 0x0 | 000 | 000 | 000 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | ₩<br>N | W. | S. | ₩. | W. | RW | ₩<br>N | W. | ₩<br>N | S. | W. | Z. | | | | | RW | W. | W. | ₩<br>N | R<br>M | RW | S. | W. | ₩<br>M | RW | W. | RW | | Name | | | | | EM4WUIF11 | EM4WUIF10 | EM4WUIF9 | EM4WUIF8 | EM4WUIF7 | EM4WUIF6 | EM4WUIF5 | EM4WUIF4 | EM4WUIF3 | EM4WUIF2 | EM4WUIF1 | EM4WUIF0 | | | | | EXTIF11 | EXTIF10 | EXTIF9 | EXTIF8 | EXTIF7 | EXTIF6 | EXTIF5 | EXTIF4 | EXTIF3 | EXTIF2 | EXTIF1 | EXTIF0 | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|--------------------|----------------------------------------------------------------------| | 31:28 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 27 | EM4WUIF11 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 26 | EM4WUIF10 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 25 | EM4WUIF9 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 24 | EM4WUIF8 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 23 | EM4WUIF7 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 22 | EM4WUIF6 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 21 | EM4WUIF5 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 20 | EM4WUIF4 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 19 | EM4WUIF3 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 18 | EM4WUIF2 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 17 | EM4WUIF1 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 16 | EM4WUIF0 | 0x0 | RW | EM4 wake up | | | EM4 wakeup interrupt fl | ag | | | | 15:12 | Reserved | To ensure ventions | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | Bit | Name | Reset | Access | Description | |-----|--------------------------|-------|--------|-------------------| | 11 | EXTIF11 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 10 | EXTIF10 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 9 | EXTIF9 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 8 | EXTIF8 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | flag | | | | 7 | EXTIF7 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 6 | EXTIF6 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 5 | EXTIF5 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 4 | EXTIF4 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 3 | EXTIF3 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 2 | EXTIF2 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 1 | EXTIF1 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | 0 | EXTIF0 | 0x0 | RW | External Pin Flag | | | External Pin interrupt f | lag | | | | | | | | | ### 25.6.30 GPIO\_IEN - Interrupt Enable | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|------|----|----|----|----------|----------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------| | 0x424 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | 000 | 0x0 | 000 | 0x0 | 0×0 | 0x0 | 000 | 0x0 | 000 | 0X0 | 0x0 | 0×0 | | ' | • | ' | 0x0 | 0X0 | 0x0 | 0X0 | 0X0 | 0X0 | 000 | 0x0 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | S. | W. | ₩<br>M | W. | Z. | RW | ₩<br>M | W. | W. | ₩. | W. | W. | | | | | RW | W. | RW | W. | RW | ₩<br>M | W. | W. | ₩<br>M | ₽ | RW | W. | | 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 | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:28 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 27 | EM4WUIEN11 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 26 | EM4WUIEN10 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 25 | EM4WUIEN9 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 24 | EM4WUIEN8 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 23 | EM4WUIEN7 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 22 | EM4WUIEN6 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 21 | EM4WUIEN5 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 20 | EM4WUIEN4 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 19 | EM4WUIEN3 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 18 | EM4WUIEN2 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 17 | EM4WUIEN1 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 16 | EM4WUIEN0 | 0x0 | RW | EM4 Wake Up Interrupt En | | | EM4 wakeup interrup | t enable | | | | 15:12 | Reserved | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | Bit | Name | Reset | Access | Description | |-----|------------------------|--------|--------|---------------------| | 11 | EXTIEN11 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 10 | EXTIEN10 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 9 | EXTIEN9 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 8 | EXTIEN8 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 7 | EXTIEN7 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 6 | EXTIEN6 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 5 | EXTIEN5 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 4 | EXTIEN4 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 3 | EXTIEN3 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 2 | EXTIEN2 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 1 | EXTIEN1 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | 0 | EXTIEN0 | 0x0 | RW | External Pin Enable | | | External Pin interrupt | enable | | | | | | | | | ### 25.6.31 GPIO\_EM4WUEN - EM4 wakeup enable | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|--------------------------------------|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x42C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | 80 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | W | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | 7<br>7<br>1<br>1<br>1<br>1<br>1<br>1 | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|--------------------|--------------------------------------------------------------------------| | 31:28 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 27:16 | EM4WUEN | 0x0 | RW | EM4 wake up enable | | | Write 1 to enable EM4 | wake up reque | est, write 0 to di | sable EM4 wake up request | | 15:0 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | ## 25.6.32 GPIO\_EM4WUPOL - EM4 wakeup polarity | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|-------------|----|----|----|----|------|------|----|----|----|---|----|---|----|---|---|---|---|---|---|---|---| | 0x430 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 000 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | \text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tin}\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tint{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tin\tint{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tin}\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\texi}\tint{\text{\text{\text{\text{\text{\text{\text{\text{\text{\ti}\tint{\text{\text{\text{\texi}\tint{\text{\text{\texi}\text{\ti}\tint{\text{\text{\text{\text{\text{\texi}\text{\texit{\titil\titil\titt{\titil\titil\titt{\titil\titil\titt{\titil\titt{ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | EINI4 WOROL | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------|-------------------------|-------------------|------------------------------------------------------------------------| | 31:28 | Reserved | To ensure c<br>ventions | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 27:16 | EM4WUPOL | 0x0 | RW | EM4 Wake-Up Polarity | | | EM4 Wakeup Polarity | | | | | 15:0 | Reserved | To ensure c | ompatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | ## 25.6.33 GPIO\_DBGROUTEPEN - Debugger Route Pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|--------|--------|-------------|-------------| | 0x440 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - | 0 | | Reset | | • | • | | • | • | • | | • | | | | | • | | • | | | | | | | | • | | • | • | | )X | 0x1 | 0x1 | 0×1 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | W. | RW | ZW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TDIPEN | TDOPEN | SWDIOTMSPEN | SWCLKTCKPEN | | Bit | Name | Reset | Access | Description | |------|-----------------------------------------------|-----------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:4 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 3 | TDIPEN | 0x1 | RW | JTAG Test Debug Input Pin Enable | | | Enable JTAG TDI conne | ection to pin. | | | | 2 | TDOPEN | 0x1 | RW | JTAG Test Debug Output Pin Enable | | | Enable JTAG TDO con | nection to pin. | | | | 1 | SWDIOTMSPEN | 0x1 | RW | Route Location 0 | | | can no longer be acces pin, make sure you hav | sed by a debu<br>e at least a 3 s | gger. A reset wi | connection to pin. WARNING: When the pin is disabled, the device II set the pin back to a default state as enabled. If you disable this at the start of your program code before you disable the pin. This ter a reset before the pin is disabled. | | 0 | SWCLKTCKPEN | 0x1 | RW | Route Pin Enable | | | be accessed by a debu | gger. A reset vecond timeout | will set the pin ba<br>at the start of yo | n. WARNING: When the pin is disabled, the device can no longer ack to a default state as enabled. If you disable this pin, make sure our program code before you disable the pin. This way, the debugre the pin is disabled. | ### 25.6.34 GPIO\_TRACEROUTEPEN - Trace Route Pin Enable | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|----|----|----|---|----|---|---|---|---|---|---|---|---------------|-------------|--------| | 0x444 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | | | • | | | | • | | | • | • | • | | | | • | • | | • | | | • | | | • | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R<br>M | ₩<br>M | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TRACEDATA0PEN | TRACECLKPEN | SWVPEN | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:3 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 2 | TRACEDATA0PEN | 0x0 | RW | Trace Data0 Pin Enable | | | Trace Data0 Pin Enable | • | | | | 1 | TRACECLKPEN | 0x0 | RW | Trace Clk Pin Enable | | | Trace Clk Pin Enable | | | | | 0 | SWVPEN | 0x0 | RW | Serial Wire Viewer Output Pin Enable | | | Serial Wire Viewer Outp | out Pin Enab | le | | ### 25.6.35 GPIO\_CMU\_ROUTEEN - CMU pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|----|---|---|---|---|---|------------|------------|------------| | 0x450 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | • | • | | | | • | | | | • | | | • | | | | • | • | | | | | • | | • | • | • | • | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | ₩<br>M | R<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CLKOUT2PEN | CLKOUT1PEN | CLKOUT0PEN | | Bit | Name | Reset | Access | Description | |------|--------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:3 | Reserved | To ensure ventions | compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 2 | CLKOUT2PEN | 0x0 | RW | CLKOUT2 pin enable control bit | | | CLKOUT2 pin enable | control bit | | | | 1 | CLKOUT1PEN | 0x0 | RW | CLKOUT1 pin enable control bit | | | CLKOUT1 pin enable | control bit | | | | 0 | CLKOUT0PEN | 0x0 | RW | CLKOUT0 pin enable control bit | | | CLKOUT0 pin enable | control bit | | | ### 25.6.36 GPIO\_CMU\_CLKIN0ROUTE - CLKIN0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|------|------|----|----|----|---|----|---|---|---|---|---|----------|---|---|------| | 0x454 | 31 | 30 | 53 | 78 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 2 | 4 | က | 7 | - 0 | | Reset | | | • | | ' | | • | | • | · | | | | 2 | 2 | | | • | | | | | | | | | | <u>'</u> | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | Ž | | | | | | | | | | | | | | | | A.W. | | Name | | | | | | | | | | | | | | 2 | <b>≟</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-----------------------|-------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CLKIN0 pin select register | | | CLKIN0 pin select reg | jister | | | | 15:2 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CLKIN0 port select register | | | CLKIN0 port select re | gister | | | ### 25.6.37 GPIO\_CMU\_CLKOUT0ROUTE - CLKOUT0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x458 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | | | | | | • | | | Š | e<br>X | | | | | | | | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CLKOUT0 pin select register | | | CLKOUT0 pin select reg | ister | | | | 15:2 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CLKOUT0 port select register | | | CLKOUT0 port select re | gister | | | ## 25.6.38 GPIO\_CMU\_CLKOUT1ROUTE - CLKOUT1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x45C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | • | | • | • | | | Š | Š | • | | | • | • | | | | | • | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------|-----------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CLKOUT1 pin select register | | | CLKOUT1 pin sele | ect register | | | | 15:2 | Reserved | To ensure<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CLKOUT1 port select register | | | CLKOUT1 port se | lect register | | | ### 25.6.39 GPIO\_CMU\_CLKOUT2ROUTE - CLKOUT2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x460 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | ' | • | ' | | | ' | | • | | | Š | e<br>S | | | | | | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | Š | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CLKOUT2 pin select register | | | CLKOUT2 pin select reg | ister | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CLKOUT2 port select register | | | CLKOUT2 port select re | gister | | | ## 25.6.40 GPIO\_DCDC\_ROUTEEN - DCDC pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|-------------------| | 0x46C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 000 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DCDCCOREHIDDENPEN | | Bit | Name | Reset | Access | Description | |------|------------------------|---------------|--------------------|------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 0 | DCDCCOREHIDDENP-<br>EN | 0x0 | RW | DCDCCOREHIDDEN pin enable control bit | | | DCDCCOREHIDDEN pir | n enable cont | rol bit | | ### 25.6.41 GPIO\_FRC\_ROUTEEN - FRC pin enable | Offset | Bit Position | | | |--------|--------------|-------|-----------| | 0x47C | 31 | 2 | - 0 | | Reset | | 0x0 | 000 | | Access | | AN N | R S | | Name | | UTPEN | DFRAMEPEN | | Bit | Name | Reset | Access | Description | |------|---------------------|-------------------|-----------------|---------------------------------------------------------------------------| | 31:3 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 2 | DOUTPEN | 0x0 | RW | DOUT pin enable control bit | | | DOUT pin enable co | ntrol bit | | | | 1 | DFRAMEPEN | 0x0 | RW | DFRAME pin enable control bit | | | DFRAME pin enable | control bit | | | | 0 | DCLKPEN | 0x0 | RW | DCLK pin enable control bit | | | DCLK pin enable cor | ntrol bit | | | ## 25.6.42 GPIO\_FRC\_DCLKROUTE - DCLK port/pin select | Offset | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|-----------------------------------------|--|--|--|--|--|--|--|----|-----|----|----|----|----|----------|----|----|---|----|---|---|---|---|---|-----|---|---|---|--------|--|------|---| | 0x480 | 2 2 2 2 2 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | | | | | | | | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | | | | Reset | | | | | | | | | | 0x0 | | | | | | | | | | | | | | | 0x0 | | | | | | | | | Access | | | | | | | | | | RW | | | | | | | | | | | | | | | | | | 3 | ≥<br>Y | | | | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | Taca | 5 | | Bit | Name | Reset | Access | Description | | | | | | | | |-------|---------------------------|-------------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--| | 31:20 | Reserved | To ensure compatibility with future devices, always write bits to 0. More information in 1.2 ventions | | | | | | | | | | | 19:16 | PIN | 0x0 | RW | DCLK pin select register | | | | | | | | | | DCLK pin select register | | | | | | | | | | | | 15:2 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | 1:0 | PORT | 0x0 | RW | DCLK port select register | | | | | | | | | | DCLK port select register | | | | | | | | | | | ## 25.6.43 GPIO\_FRC\_DFRAMEROUTE - DFRAME port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x484 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | • | • | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | DFRAME pin select register | | | DFRAME pin select regi | ster | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | DFRAME port select register | | | DFRAME port select reg | gister | | | ## 25.6.44 GPIO\_FRC\_DOUTROUTE - DOUT port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x488 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | ' | • | | | • | • | | • | | | Š | S<br>S | • | | | • | • | | • | | | | | ' | | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | DOUT pin select register | | | DOUT pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | DOUT port select register | | | DOUT port select registe | r | | | ## 25.6.45 GPIO\_I2C0\_ROUTEEN - I2C0 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------|--------| | 0x490 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | | | | | | | | • | | | | • | | | | | | | | | | • | | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | ₩<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | SDAPEN | SCLPEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | SDAPEN | 0x0 | RW | SDA pin enable control bit | | | SDA pin enable control b | oit | | | | 0 | SCLPEN | 0x0 | RW | SCL pin enable control bit | | | SCL pin enable control b | it | | | ## 25.6.46 GPIO\_I2C0\_SCLROUTE - SCL port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|--------|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------| | 0x494 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | | | | ć | e<br>S | • | | • | | | | | | | • | • | • | • | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | ≥<br>Y | | | | | | | | | | | | | | | | A<br>W<br>W | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SCL pin select register | | | SCL pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SCL port select register | | | SCL port select register | | | | ## 25.6.47 GPIO\_I2C0\_SDAROUTE - SDA port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x498 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | • | | | | • | | | | | | | | 2 | OX<br>O | | | • | | | | | | | | • | | | | | 0x0 | | Access | | | | | | | | | | | | | | 20 | <u>}</u> | | | | | | | | | | | | | | | | A.W. | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|---------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SDA pin select register | | | SDA pin select register | | | | | 15:2 | Reserved | To ensure oventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SDA port select register | | | SDA port select register | | | | ## 25.6.48 GPIO\_I2C1\_ROUTEEN - I2C1 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------|--------| | 0x4A0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | | | | | • | • | • | • | • | | | | | | • | | | | • | ' | | • | | | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | SDAPEN | SCLPEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1 | SDAPEN | 0x0 | RW | SDA pin enable control bit | | | SDA pin enable control I | oit | | | | 0 | SCLPEN | 0x0 | RW | SCL pin enable control bit | | | SCL pin enable control b | oit | | | ## 25.6.49 GPIO\_I2C1\_SCLROUTE - SCL port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x4A4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | • | | | • | | | 2 | e e | | | • | • | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SCL pin select register | | | SCL pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SCL port select register | | | SCL port select register | | | | ## 25.6.50 GPIO\_I2C1\_SDAROUTE - SDA port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x4A8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | | | • | • | | | Š | S<br>S | • | | | • | • | | • | | | | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SDA pin select register | | | SDA pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SDA port select register | | | SDA port select register | | | | ## 25.6.51 GPIO\_LETIMER0\_ROUTEEN - LETIMER pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------|---------| | 0x4B0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | | ' | 1 | ' | | | | | | ' | ' | | | | ' | • | ' | | | | | | | ' | • | | | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | ₩<br>M | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | OUT1PEN | OUTOPEN | | Bit | Name | Reset | Access | Description | |------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | OUT1PEN | 0x0 | RW | OUT1 pin enable control bit | | | OUT1 pin enable control | bit | | | | 0 | OUT0PEN | 0x0 | RW | OUT0 pin enable control bit | | | OUT0 pin enable control | bit | | | ## 25.6.52 GPIO\_LETIMER0\_OUT0ROUTE - OUT0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x4B4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | • | • | • | • | • | | • | | 2 | 2 | • | | • | • | | • | | | | | | • | | | • | 0x0 | | Access | | | | | | | | | | | | | | <u> </u> | 2 | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | OUT0 pin select register | | | OUT0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | OUT0 port select register | | | OUT0 port select registe | r | | | ## 25.6.53 GPIO\_LETIMER0\_OUT1ROUTE - OUT1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|------| | 0x4B8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | တ | 8 | 7 | 9 | 2 | 4 | က | 2 | 1 0 | | Reset | | | • | | • | | • | • | | | • | | | 2 | e e | | | | | | • | | | • | | | • | | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | OUT1 pin select register | | | OUT1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | OUT1 port select register | | | OUT1 port select registe | r | | | ## 25.6.54 GPIO\_EUART0\_ROUTEEN - EUART pin enable | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-------|--------| | 0x4C0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | ' | | | | • | ' | • | | ' | • | ' | • | | | ' | • | ' | | • | • | • | • | | ' | • | | • | ' | | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | ΑM | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TXPEN | RTSPEN | | Bit | Name | Reset | Access | Description | |------|---------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | TXPEN | 0x0 | RW | TX pin enable control bit | | | TX pin enable control bit | | | | | 0 | RTSPEN | 0x0 | RW | RTS pin enable control bit | | | RTS pin enable control b | oit | | | ## 25.6.55 GPIO\_EUART0\_CTSROUTE - CTS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x4C4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | • | | | • | | | 2 | e e | | | • | • | | | | | • | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CTS pin select register | | | CTS pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CTS port select register | | | CTS port select register | | | | ## 25.6.56 GPIO\_EUART0\_RTSROUTE - RTS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x4C8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | | | ' | • | | • | • | | | Š | S<br>S | • | | | | • | | • | | | | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | RTS pin select register | | | RTS pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | RTS port select register | | | RTS port select register | | | | ## 25.6.57 GPIO\_EUART0\_RXROUTE - RX port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x4CC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | • | • | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 20 | <u>}</u> | | | | | | | | | | | | | | | | AW. | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | RX pin select register | | | RX pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | RX port select register | | | RX port select register | | | | ## 25.6.58 GPIO\_EUART0\_TXROUTE - TX port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x4D0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | - c | _<br>> | | Reset | | | | | | | | | | | | | | 2 | 3 | | | • | | | | • | | • | | | | • | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <b>=</b> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | TX pin select register | | | TX pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | TX port select register | | | TX port select register | | | | ## 25.6.59 GPIO\_MODEM\_ROUTEEN - MODEM pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|---------|---------|----------------|------------|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|----------------|---------|---------| | 0x4D8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - | 0 | | Reset | | | • | | • | | | • | | • | | | | | • | | | 0x0 | 0x0 | 0X0 | 0x0 | 0×0 | 0x0 | 0x0 | 0X0 | 000 | 0x0 | 000 | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | Z. | ₩ | ¥<br>M | RW | W. | RW | Z. | RW<br>W | ₩<br>M | RW | RW | S. | RW | Z. | RW | | Name | | | | | | | | | | | | | | | | | | DOUTPEN | DCLKPEN | ANTTRIGSTOPPEN | ANTTRIGPEN | ANTSWUSPEN | ANTSWENPEN | ANTRRSPEN | ANTRR4PEN | ANTRR3PEN | ANTRR2PEN | ANTRR1PEN | ANTRROPEN | ANTROLLOVERPEN | ANT1PEN | ANTOPEN | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:15 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 14 | DOUTPEN | 0x0 | RW | DOUT pin enable control bit | | | DOUT pin enable contr | ol bit | | | | 13 | DCLKPEN | 0x0 | RW | DCLK pin enable control bit | | | DCLK pin enable contro | ol bit | | | | 12 | ANTTRIGSTOPPEN | 0x0 | RW | ANTTRIGSTOP pin enable control bit | | | ANTTRIGSTOP pin en | able control bi | t | | | 11 | ANTTRIGPEN | 0x0 | RW | ANTTRIG pin enable control bit | | | ANTTRIG pin enable co | ontrol bit | | | | 10 | ANTSWUSPEN | 0x0 | RW | ANTSWUS pin enable control bit | | | ANTSWUS pin enable | control bit | | | | 9 | ANTSWENPEN | 0x0 | RW | ANTSWEN pin enable control bit | | | ANTSWEN pin enable | control bit | | | | 8 | ANTRR5PEN | 0x0 | RW | ANTRR5 pin enable control bit | | | ANTRR5 pin enable co | ntrol bit | | | | 7 | ANTRR4PEN | 0x0 | RW | ANTRR4 pin enable control bit | | | ANTRR4 pin enable co | ntrol bit | | | | 6 | ANTRR3PEN | 0x0 | RW | ANTRR3 pin enable control bit | | | ANTRR3 pin enable co | ntrol bit | | | | 5 | ANTRR2PEN | 0x0 | RW | ANTRR2 pin enable control bit | | | ANTRR2 pin enable co | ntrol bit | | | | 4 | ANTRR1PEN | 0x0 | RW | ANTRR1 pin enable control bit | | | ANTRR1 pin enable co | ntrol bit | | | | 3 | ANTRR0PEN | 0x0 | RW | ANTRR0 pin enable control bit | | | ANTRR0 pin enable co | ntrol bit | | | | Bit | Name | Reset | Access | Description | |-----|------------------------|--------------|--------|------------------------------------| | 2 | ANTROLLOVERPEN | 0x0 | RW | ANTROLLOVER pin enable control bit | | | ANTROLLOVER pin en | able control | bit | | | 1 | ANT1PEN | 0x0 | RW | ANT1 pin enable control bit | | | ANT1 pin enable contro | l bit | | | | 0 | ANT0PEN | 0x0 | RW | ANT0 pin enable control bit | | | ANT0 pin enable contro | l bit | | | ## 25.6.60 GPIO\_MODEM\_ANT0ROUTE - ANT0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|------| | 0x4DC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | • | • | | | • | | • | | 2 | OXO | • | | • | | | • | • | | • | | | • | • | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | ≦ | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|---------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANT0 pin select register | | | ANT0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANT0 port select register | | | ANT0 port select register | - | | | ## 25.6.61 GPIO\_MODEM\_ANT1ROUTE - ANT1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|----------| | 0x4E0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | | • | | | | | | | 2 | OX<br>O | • | | • | | | | | | | • | | • | | • | | ç | 2 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | 2 | <u>}</u> | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | FOCO | 7<br>X | | Bit | Name | Reset | Access | Description | |-------|---------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANT1 pin select register | | | ANT1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANT1 port select register | | | ANT1 port select register | r | | | ## 25.6.62 GPIO\_MODEM\_ANTROLLOVERROUTE - ANTROLLOVER port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x4E4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - c | _<br>> | | Reset | | | | • | | | | | | • | | | | 2 | S<br>S | • | | | | | | • | | | | | | | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | ≥<br>Y | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|---------------------|----------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTROLLOVER pin select register | | | ANTROLLOVER pin sel | ect register | | | | 15:2 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTROLLOVER port select register | | | ANTROLLOVER port se | elect register | | | ## 25.6.63 GPIO\_MODEM\_ANTRR0ROUTE - ANTRR0 port/pin select | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x4E8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | | | | Š | Š | | | | | | | • | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTRR0 pin select register | | | ANTRR0 pin select regis | ster | | | | 15:2 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTRR0 port select register | | | ANTRR0 port select reg | ister | | | ## 25.6.64 GPIO\_MODEM\_ANTRR1ROUTE - ANTRR1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|--------| | 0x4EC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | • | | • | • | | | 2 | S<br>S | • | | | • | • | | | | | | | | • | • | | 0x0 | | Access | | | | | | | | | | | | | | <u> </u> | ><br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-------------------|-----------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTRR1 pin select register | | | ANTRR1 pin selec | t register | | | | 15:2 | Reserved | To ensure<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTRR1 port select register | | | ANTRR1 port selec | ct register | | | ## 25.6.65 GPIO\_MODEM\_ANTRR2ROUTE - ANTRR2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x4F0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | တ | 8 | 7 | 9 | 2 | 4 | က | 2 | 1 0 | | Reset | | | • | • | • | | | • | | | • | | | 2 | e e | • | | | | | | | | • | | | • | | • | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTRR2 pin select register | | | ANTRR2 pin select regi | ster | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTRR2 port select register | | | ANTRR2 port select reg | ister | | | ## 25.6.66 GPIO\_MODEM\_ANTRR3ROUTE - ANTRR3 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|----------| | 0x4F4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - c | <u> </u> | | Reset | | | • | • | • | | | | | • | | • | | 5 | Š | | | | | | | • | | | | | | | • | • | 0×0 | _ | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTRR3 pin select register | | | ANTRR3 pin select reg | ister | | | | 15:2 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTRR3 port select register | | | ANTRR3 port select reg | gister | | | ## 25.6.67 GPIO\_MODEM\_ANTRR4ROUTE - ANTRR4 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x4F8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | • | | | 2 | e e | | | | | | | | | • | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTRR4 pin select register | | | ANTRR4 pin select r | egister | | | | 15:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTRR4 port select register | | | ANTRR4 port select | register | | | # 25.6.68 GPIO\_MODEM\_ANTRR5ROUTE - ANTRR5 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x4FC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | | | • | | | | | | | 2 | Š | • | | | | | | • | | | | | | | • | | 0x0 | | | Access | | | | | | | | | | | | | | 7 | ≥<br>Y | | | | | | | | | | | | | | | | RW | | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTRR5 pin select register | | | ANTRR5 pin select regis | ster | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTRR5 port select register | | | ANTRR5 port select reg | ister | | | ## 25.6.69 GPIO\_MODEM\_ANTSWENROUTE - ANTSWEN port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x500 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | ' | | | | | | • | | | Š | Š | | | | | | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | Š | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTSWEN pin select register | | | ANTSWEN pin selec | t register | | | | 15:2 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTSWEN port select register | | | ANTSWEN port sele | ct register | | | ## 25.6.70 GPIO\_MODEM\_ANTSWUSROUTE - ANTSWUS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------| | 0x504 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | 8 | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | ' | • | | | • | • | • | • | | | ć | S<br>S | | | ' | | | | | | | | | • | • | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | ≥<br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u>Z</u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-----------------|--------------------|---------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTSWUS pin select register | | | ANTSWUS pin se | lect register | | | | 15:2 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTSWUS port select register | | | ANTSWUS port se | elect register | | | ## 25.6.71 GPIO\_MODEM\_ANTTRIGROUTE - ANTTRIG port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x508 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | | | | | | • | | | 2 | e e | | | | | | | • | | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTTRIG pin select register | | | ANTTRIG pin select | register | | | | 15:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTTRIG port select register | | | ANTTRIG port select | register | | | ## 25.6.72 GPIO\_MODEM\_ANTTRIGSTOPROUTE - ANTTRIGSTOP port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------| | 0x50C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | | • | • | | | | | | | | | 2 | 3 | | | | | | | • | | • | • | | • | • | • | • | 0x0 | | Access | | | | | | | | | | | | | | <u> </u> | <u> </u> | | | | | | | | | | | | | | | | X<br>X | | Name | | | | | | | | | | | | | | 2 | Ē | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|---------------|---------------------|---------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ANTTRIGSTOP pin select register | | | ANTTRIGSTOP p | in select register | | | | 15:2 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ANTTRIGSTOP port select register | | | ANTTRIGSTOP p | ort select register | | | ## 25.6.73 GPIO\_MODEM\_DCLKROUTE - DCLK port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x510 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | | | | Š | e<br>X | | | | | | | | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | DCLK pin select register | | | DCLK pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | DCLK port select register | | | DCLK port select registe | r | | | ## 25.6.74 GPIO\_MODEM\_DINROUTE - DIN port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x514 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | | | | | | | | | | 2 | 3 | | | • | | | | • | | • | | | • | | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <b>=</b> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | DIN pin select register | | | DIN pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | DIN port select register | | | DIN port select register | | | | ## 25.6.75 GPIO\_MODEM\_DOUTROUTE - DOUT port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x518 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 0 | | Reset | | | • | | • | | | | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | DOUT pin select register | | | DOUT pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | DOUT port select register | | | DOUT port select registe | er | | | ## 25.6.76 GPIO\_PDM\_ROUTEEN - PDM pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|----------|---|---|---|---|--------| | 0x520 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | <u>'</u> | • | | | | | | | • | • | | | • | ' | | ' | • | | | | | • | • | | <u>'</u> | | ' | | | 0×0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | X<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CLKPEN | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:1 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 0 | CLKPEN | 0x0 | RW | CLK pin enable control bit | | | CLK pin enable control | bit | | | ## 25.6.77 GPIO\_PDM\_CLKROUTE - CLK port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x524 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | • | | | 2 | e e | | | • | • | | | | | • | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CLK pin select register | | | CLK pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CLK port select register | | | CLK port select register | | | | ## 25.6.78 GPIO\_PDM\_DAT0ROUTE - DAT0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------| | 0x528 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | ' | • | • | | | • | | • | • | | | 2 | S<br>S | • | | ' | | • | | • | ' | ' | • | | ' | ' | • | | 0x0 | | Access | | | | | | | | | | | | | | > | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|---------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | DAT0 pin select register | | | DAT0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | DAT0 port select register | | | DAT0 port select register | | | | ## 25.6.79 GPIO\_PDM\_DAT1ROUTE - DAT1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------| | 0x52C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | • | • | | | • | | | 2 | e e | | | • | • | | | | | • | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|---------------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | DAT1 pin select register | | | DAT1 pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | DAT1 port select register | | | DAT1 port select register | - | | | ## 25.6.80 GPIO\_PRS0\_ROUTEEN - PRS0 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----------|-----------|-----------|-----------|-------------|-------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------| | 0x534 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | • | | • | | | | • | | | | | 0x0 | 0x0 | 0x0 | 000 | 0x0 | 000 | 0x0 | 000 | 0x0 | 000 | 0×0 | 0x0 | 000 | 0x0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | W. | Z. | RW | Z<br>N | RW | ₩<br>N | W. | ₩<br>N | Z. | W. | W. | W. | S. | ₩. | ₩<br>M | RW | | Name | | | | | | | | | | | | | | | | | SYNCH3PEN | SYNCH2PEN | SYNCH1PEN | SYNCHOPEN | ASYNCH11PEN | ASYNCH10PEN | ASYNCH9PEN | ASYNCH8PEN | ASYNCH7PEN | ASYNCH6PEN | ASYNCH5PEN | ASYNCH4PEN | ASYNCH3PEN | ASYNCH2PEN | ASYNCH1PEN | ASYNCH0PEN | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 15 | SYNCH3PEN | 0x0 | RW | SYNCH3 pin enable control bit | | | SYNCH3 pin enable cor | ntrol bit | | | | 14 | SYNCH2PEN | 0x0 | RW | SYNCH2 pin enable control bit | | | SYNCH2 pin enable cor | ntrol bit | | | | 13 | SYNCH1PEN | 0x0 | RW | SYNCH1 pin enable control bit | | | SYNCH1 pin enable cor | ntrol bit | | | | 12 | SYNCH0PEN | 0x0 | RW | SYNCH0 pin enable control bit | | | SYNCH0 pin enable cor | ntrol bit | | | | 11 | ASYNCH11PEN | 0x0 | RW | ASYNCH11 pin enable control bit | | | ASYNCH11 pin enable | control bit | | | | 10 | ASYNCH10PEN | 0x0 | RW | ASYNCH10 pin enable control bit | | | ASYNCH10 pin enable | control bit | | | | 9 | ASYNCH9PEN | 0x0 | RW | ASYNCH9 pin enable control bit | | | ASYNCH9 pin enable c | ontrol bit | | | | 8 | ASYNCH8PEN | 0x0 | RW | ASYNCH8 pin enable control bit | | | ASYNCH8 pin enable c | ontrol bit | | | | 7 | ASYNCH7PEN | 0x0 | RW | ASYNCH7 pin enable control bit | | | ASYNCH7 pin enable c | ontrol bit | | | | 6 | ASYNCH6PEN | 0x0 | RW | ASYNCH6 pin enable control bit | | | ASYNCH6 pin enable c | ontrol bit | | | | 5 | ASYNCH5PEN | 0x0 | RW | ASYNCH5 pin enable control bit | | | ASYNCH5 pin enable c | ontrol bit | | | | 4 | ASYNCH4PEN | 0x0 | RW | ASYNCH4 pin enable control bit | | | ASYNCH4 pin enable c | ontrol bit | | | | 3 | ASYNCH3PEN | 0x0 | RW | ASYNCH3 pin enable control bit | | | | | | | | Bit | Name | Reset | Access | Description | |-----|--------------------|---------------|--------|--------------------------------| | | ASYNCH3 pin enable | e control bit | | | | 2 | ASYNCH2PEN | 0x0 | RW | ASYNCH2 pin enable control bit | | | ASYNCH2 pin enable | e control bit | | | | 1 | ASYNCH1PEN | 0x0 | RW | ASYNCH1 pin enable control bit | | | ASYNCH1 pin enable | e control bit | | | | 0 | ASYNCH0PEN | 0x0 | RW | ASYNCH0 pin enable control bit | | | ASYNCH0 pin enable | e control bit | | | # 25.6.81 GPIO\_PRS0\_ASYNCH0ROUTE - ASYNCH0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|------|------|----|----|----|---|----|---|----|---|---|---|---|---|---|------| | 0x538 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | | • | | | | | | | • | | | 2 | )<br>X | | | ' | • | | | ' | • | | ' | • | | • | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | ≦ | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------|-----------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH0 pin select register | | | ASYNCH0 pin sele | ect register | | | | 15:2 | Reserved | To ensure<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH0 port select register | | | ASYNCH0 port se | lect register | | | ## 25.6.82 GPIO\_PRS0\_ASYNCH1ROUTE - ASYNCH1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x53C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | • | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility ( | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH1 pin select register | | | ASYNCH1 pin select | register | | | | 15:2 | Reserved | To ensure ventions | e compatibility ( | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH1 port select register | | | ASYNCH1 port selec | ct register | | | ## 25.6.83 GPIO\_PRS0\_ASYNCH2ROUTE - ASYNCH2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|---| | 0x540 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | ' | • | • | | ' | | | • | | | | 2 | 2 | • | | ' | | | • | | | | ' | | ' | • | ' | • | 2 | 3 | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | 2 | 2 | | Name | | | | | | | | | | | | | | 2 | <b>≟</b> | | | | | | | | | | | | | | | | TaOa | | | Bit | Name | Reset | Access | Description | |-------|-----------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH2 pin select register | | | ASYNCH2 pin sel | ect register | | | | 15:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH2 port select register | | | ASYNCH2 port se | elect register | | | ## 25.6.84 GPIO\_PRS0\_ASYNCH3ROUTE - ASYNCH3 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------| | 0x544 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | ' | | | | | | | • | | Š | Š | | | | | | | | | | | ' | • | ' | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH3 pin select register | | | ASYNCH3 pin select reg | gister | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH3 port select register | | | ASYNCH3 port select re | gister | | | # 25.6.85 GPIO\_PRS0\_ASYNCH4ROUTE - ASYNCH4 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------| | 0x548 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | | | | | | | | | 2 | e<br>S | | | | | | | • | • | | • | | | | | • | 0x0 | | Access | | | | | | | | | | | | | | 7 | <u>}</u> | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-----------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH4 pin select register | | | ASYNCH4 pin sel | ect register | | | | 15:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH4 port select register | | | ASYNCH4 port se | lect register | | | ## 25.6.86 GPIO\_PRS0\_ASYNCH5ROUTE - ASYNCH5 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------| | 0x54C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | • | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 20 | <u>}</u> | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|------------------|--------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH5 pin select register | | | ASYNCH5 pin select re | egister | | | | 15:2 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH5 port select register | | | ASYNCH5 port select r | egister | | | ## 25.6.87 GPIO\_PRS0\_ASYNCH6ROUTE - ASYNCH6 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------| | 0x550 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | ' | • | • | | | • | | • | • | | | Š | S<br>S | • | | ' | | • | | • | ' | ' | • | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | ><br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-----------------|-----------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH6 pin select register | | | ASYNCH6 pin sel | ect register | | | | 15:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH6 port select register | | | ASYNCH6 port se | lect register | | | ## 25.6.88 GPIO\_PRS0\_ASYNCH7ROUTE - ASYNCH7 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|------| | 0x554 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | ဝ | 8 | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | • | | | 2 | e e | | | | | | • | | | • | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH7 pin select register | | | ASYNCH7 pin select reg | gister | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH7 port select register | | | ASYNCH7 port select re | gister | | | # 25.6.89 GPIO\_PRS0\_ASYNCH8ROUTE - ASYNCH8 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|--------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------| | 0x558 | 33 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | • | | • | ' | | | • | • | • | • | | | Š | S<br>S | | | • | • | • | | • | • | | • | ' | ' | • | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | ≥<br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH8 pin select register | | | ASYNCH8 pin sele | ect register | | | | 15:2 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH8 port select register | | | ASYNCH8 port se | lect register | | | ## 25.6.90 GPIO\_PRS0\_ASYNCH9ROUTE - ASYNCH9 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|-----|----------| | 0x55C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | | • | | | | • | | | 2 | e e | | | • | • | | | | | | | • | • | | • | | ç | 2 | | Access | | | | | | | | | | | | | | 20 | <u>}</u> | | | | | | | | | | | | | | | | Ž | <u>}</u> | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | C C | 7<br>X | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|------------------|--------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH9 pin select register | | | ASYNCH9 pin select re | egister | | | | 15:2 | Reserved | To ensure ventions | compatibility wi | ith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH9 port select register | | | ASYNCH9 port select r | egister | | | ## 25.6.91 GPIO\_PRS0\_ASYNCH10ROUTE - ASYNCH10 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x560 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | • | | | | | | | | | 2 | e<br>S | | | • | | | | • | | | | | | • | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u>}</u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|-----------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH10 pin select register | | | ASYNCH10 pin se | elect register | | | | 15:2 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH10 port select register | | | ASYNCH10 port s | select register | | | ## 25.6.92 GPIO\_PRS0\_ASYNCH11ROUTE - ASYNCH11 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x564 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | • | • | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-----------------------|-----------------------|------------------|-------------------------------------------------------------------------| | 31:20 | Reserved | To ensure<br>ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | ASYNCH11 pin select register | | | ASYNCH11 pin select i | egister | | | | 15:2 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | ASYNCH11 port select register | | | ASYNCH11 port select | register | | | ## 25.6.93 GPIO\_PRS0\_SYNCH0ROUTE - SYNCH0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x568 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | - c | _<br>> | | Reset | | • | | • | | | | | | ' | | | | 2 | e<br>S | • | | | | • | | • | ' | ' | • | | | | ' | • | 0x0 | | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|------------------|-------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SYNCH0 pin select register | | | SYNCH0 pin selec | ct register | | | | 15:2 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SYNCH0 port select register | | | SYNCH0 port sele | ect register | | | ## 25.6.94 GPIO\_PRS0\_SYNCH1ROUTE - SYNCH1 port/pin select | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x56C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | • | • | | • | | | | | Š | Š | | | | | | | • | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|-----------------|--------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SYNCH1 pin select register | | | SYNCH1 pin select reg | ister | | | | 15:2 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SYNCH1 port select register | | | SYNCH1 port select re | gister | | | ## 25.6.95 GPIO\_PRS0\_SYNCH2ROUTE - SYNCH2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x570 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - c | _<br>> | | Reset | | | | | | | | | | | | | | 2 | 3 | | | • | | | | • | | | | | • | | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | <u> </u> | <u>}</u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | Ē | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|------------------|----------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SYNCH2 pin select register | | | SYNCH2 pin sele | ct register | | | | 15:2 | Reserved | To ensur<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SYNCH2 port select register | | | SYNCH2 port sele | ect register | | | ## 25.6.96 GPIO\_PRS0\_SYNCH3ROUTE - SYNCH3 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x574 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | 1 | | Reset | | • | | • | • | | | | | | • | | | 2 | OX<br>O | • | | | | | | • | | • | • | • | • | • | | | 0x0 | | Access | | | | | | | | | | | | | | 20 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|------------------|-----------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SYNCH3 pin select register | | | SYNCH3 pin selec | t register | | | | 15:2 | Reserved | To ensure<br>ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SYNCH3 port select register | | | SYNCH3 port sele | ct register | | | ## 25.6.97 GPIO\_TIMER0\_ROUTEEN - TIMER0 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---------|---------|---------|--------|--------|---------| | 0x57C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | • | | • | | | | | • | | • | • | | | | | • | | | • | | • | | 000 | 000 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | ₹ | W. | ₹ | W<br>M | ₩<br>M | RW<br>W | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | CCC2PEN | CCC1PEN | CCC0PEN | CC2PEN | CC1PEN | CCOPEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | CCC2PEN | 0x0 | RW | CCC2 pin enable control bit | | | CCC2 pin enable control | bit | | | | 4 | CCC1PEN | 0x0 | RW | CCC1 pin enable control bit | | | CCC1 pin enable control | bit | | | | 3 | CCC0PEN | 0x0 | RW | CCC0 pin enable control bit | | | CCC0 pin enable control | bit | | | | 2 | CC2PEN | 0x0 | RW | CC2 pin enable control bit | | | CC2 pin enable control b | oit | | | | 1 | CC1PEN | 0x0 | RW | CC1 pin enable control bit | | | CC1 pin enable control b | oit | | | | 0 | CC0PEN | 0x0 | RW | CC0 pin enable control bit | | | CC0 pin enable control b | oit | | | ## 25.6.98 GPIO\_TIMER0\_CC0ROUTE - CC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x580 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | • | • | | • | | | | • | | • | | | ç | Š | • | | | • | | | | | | | | • | | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <b>≩</b> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u>Z</u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|---------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC0 pin select register | | | CC0 pin select register | | | | | 15:2 | Reserved | To ensure oventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC0 port select register | | | CC0 port select register | | | | ## 25.6.99 GPIO\_TIMER0\_CC1ROUTE - CC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x584 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | ' | • | • | • | • | | | Š | S<br>S | • | | | • | • | | • | | | | | ' | • | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC1 pin select register | | | CC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC1 port select register | | | CC1 port select register | | | | ## 25.6.100 GPIO\_TIMER0\_CC2ROUTE - CC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------| | 0x588 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | æ | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | ' | ' | | | | | | | • | | 2 | Š | | | | | | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC2 pin select register | | | CC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC2 port select register | | | CC2 port select register | | | | ## 25.6.101 GPIO\_TIMER0\_CCC0ROUTE - CCC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|---| | 0x58C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - c | > | | Reset | | | | | | | • | | | | | | | 2 | e<br>S | | | • | | | | • | | | | | • | | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u>}</u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC0 pin select register | | | CCC0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC0 port select register | | | CCC0 port select registe | r | | | ## 25.6.102 GPIO\_TIMER0\_CCC1ROUTE - CCC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------| | 0x590 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | • | | ' | | | • | | | | • | | 2 | Š | | | | | ' | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC1 pin select register | | | CCC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC1 port select register | | | CCC1 port select registe | r | | | ## 25.6.103 GPIO\_TIMER0\_CCC2ROUTE - CCC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------| | 0x594 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | ' | • | • | | • | | | Š | S<br>S | • | | | • | • | | • | ' | ' | • | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC2 pin select register | | | CCC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC2 port select register | | | CCC2 port select registe | r | | | ## 25.6.104 GPIO\_TIMER1\_ROUTEEN - TIMER1 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---------|---------|---------|--------|--------|--------| | 0x59C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | | | • | | • | | • | | | • | • | | | | • | • | | • | | • | | • | | 000 | 0×0 | 000 | 000 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩ | W. | S. | ₽ | ₩ | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | CCC2PEN | CCC1PEN | CCCOPEN | CC2PEN | CC1PEN | CCOPEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | CCC2PEN | 0x0 | RW | CCC2 pin enable control bit | | | CCC2 pin enable control | l bit | | | | 4 | CCC1PEN | 0x0 | RW | CCC1 pin enable control bit | | | CCC1 pin enable control | l bit | | | | 3 | CCC0PEN | 0x0 | RW | CCC0 pin enable control bit | | | CCC0 pin enable control | l bit | | | | 2 | CC2PEN | 0x0 | RW | CC2 pin enable control bit | | | CC2 pin enable control b | oit | | | | 1 | CC1PEN | 0x0 | RW | CC1 pin enable control bit | | | CC1 pin enable control b | oit | | | | 0 | CC0PEN | 0x0 | RW | CC0 pin enable control bit | | - | CC0 pin enable control b | oit | | | ## 25.6.105 GPIO\_TIMER1\_CC0ROUTE - CC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5A0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | ' | ' | | | • | | | | • | | Š | Š | | | | | ' | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC0 pin select register | | | CC0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC0 port select register | | | CC0 port select register | | | | ## 25.6.106 GPIO\_TIMER1\_CC1ROUTE - CC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|----------| | 0x5A4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - c | <u> </u> | | Reset | | | | | | | | | | • | | | | 2 | 3 | | | | | | | • | | | | | | | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | Ē | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC1 pin select register | | | CC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC1 port select register | | | CC1 port select register | | | | ## 25.6.107 GPIO\_TIMER1\_CC2ROUTE - CC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5A8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | ' | | | • | | | | • | | Š | Š | | | | | | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC2 pin select register | | | CC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC2 port select register | | | CC2 port select register | | | | # 25.6.108 GPIO\_TIMER1\_CCC0ROUTE - CCC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x5AC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | | | • | • | | | 2 | Š | • | | | • | • | | • | | | | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | > | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC0 pin select register | | | CCC0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC0 port select register | | | CCC0 port select registe | r | | | ## 25.6.109 GPIO\_TIMER1\_CCC1ROUTE - CCC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5B0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | | | | | | • | | | Š | e<br>X | | | | | | | • | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC1 pin select register | | | CCC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC1 port select register | | | CCC1 port select registe | r | | | # 25.6.110 GPIO\_TIMER1\_CCC2ROUTE - CCC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|--------| | 0x5B4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | ' | • | | | • | | • | • | | | 2 | S<br>S | • | | | • | • | | • | | | | | ' | | • | | 0x0 | | Access | | | | | | | | | | | | | | 7 | ≥<br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC2 pin select register | | | CCC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC2 port select register | | | CCC2 port select registe | r | | | ## 25.6.111 GPIO\_TIMER2\_ROUTEEN - TIMER2 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---------|---------|---------|--------|---------|--------| | 0x5BC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | | | | | • | • | | | • | | | | | | | | | • | • | | | 000 | 0x0 | 000 | 0x0 | 000 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | RW | ₩<br>N | R<br>W | ZW<br>W | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | CCC2PEN | CCC1PEN | CCCOPEN | CC2PEN | CC1PEN | CCOPEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | CCC2PEN | 0x0 | RW | CCC2 pin enable control bit | | | CCC2 pin enable control | bit | | | | 4 | CCC1PEN | 0x0 | RW | CCC1 pin enable control bit | | | CCC1 pin enable control | bit | | | | 3 | CCC0PEN | 0x0 | RW | CCC0 pin enable control bit | | | CCC0 pin enable control | bit | | | | 2 | CC2PEN | 0x0 | RW | CC2 pin enable control bit | | | CC2 pin enable control b | oit | | | | 1 | CC1PEN | 0x0 | RW | CC1 pin enable control bit | | | CC1 pin enable control b | oit | | | | 0 | CC0PEN | 0x0 | RW | CC0 pin enable control bit | | | CC0 pin enable control b | oit | | | ## 25.6.112 GPIO\_TIMER2\_CC0ROUTE - CC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5C0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | • | | | | • | | | Š | Š | | | | | | | | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | Š | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC0 pin select register | | | CC0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC0 port select register | | | CC0 port select register | | | | # 25.6.113 GPIO\_TIMER2\_CC1ROUTE - CC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---------| | 0x5C4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | ω | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | | | • | • | | | Š | Š | • | | | | • | | • | ' | ' | • | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC1 pin select register | | | CC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC1 port select register | | | CC1 port select register | | | | ## 25.6.114 GPIO\_TIMER2\_CC2ROUTE - CC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5C8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | | • | • | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC2 pin select register | | | CC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC2 port select register | | | CC2 port select register | | | | # 25.6.115 GPIO\_TIMER2\_CCC0ROUTE - CCC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|--------| | 0x5CC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | | | • | • | | | 2 | Š | • | | ' | • | • | | • | | | | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | <u> </u> | ><br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC0 pin select register | | | CCC0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC0 port select register | | | CCC0 port select registe | r | | | ## 25.6.116 GPIO\_TIMER2\_CCC1ROUTE - CCC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5D0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | | | | Š | Š | | | | | | | • | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC1 pin select register | | | CCC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC1 port select register | | | CCC1 port select registe | r | | | # 25.6.117 GPIO\_TIMER2\_CCC2ROUTE - CCC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x5D4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | • | | • | • | | | Š | S<br>S | • | | ' | | • | | • | | | | | ' | • | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC2 pin select register | | | CCC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC2 port select register | | | CCC2 port select registe | r | | | # 25.6.118 GPIO\_TIMER3\_ROUTEEN - TIMER3 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---------|---------|---------|--------|---------|--------| | 0x5DC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | 1 | | 1 | | | | | | | | | • | | | • | | • | | • | ' | | • | | | 000 | 0x0 | 0X0 | 000 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | RW | ₩<br>N | ₩<br>M | ZW<br>W | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | CCC2PEN | CCC1PEN | CCCOPEN | CC2PEN | CC1PEN | CCOPEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | CCC2PEN | 0x0 | RW | CCC2 pin enable control bit | | | CCC2 pin enable control | bit | | | | 4 | CCC1PEN | 0x0 | RW | CCC1 pin enable control bit | | | CCC1 pin enable control | bit | | | | 3 | CCC0PEN | 0x0 | RW | CCC0 pin enable control bit | | | CCC0 pin enable control | bit | | | | 2 | CC2PEN | 0x0 | RW | CC2 pin enable control bit | | | CC2 pin enable control b | it | | | | 1 | CC1PEN | 0x0 | RW | CC1 pin enable control bit | | | CC1 pin enable control b | it | | | | 0 | CC0PEN | 0x0 | RW | CC0 pin enable control bit | | | CC0 pin enable control b | it | | | ## 25.6.119 GPIO\_TIMER3\_CC0ROUTE - CC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5E0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 2 | 4 | က | 2 | 1 0 | | Reset | | | • | • | • | | | • | | | • | | | 2 | e e | • | | | | | | | | | | | • | | • | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|-------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC0 pin select register | | | CC0 pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC0 port select register | | | CC0 port select register | | | | # 25.6.120 GPIO\_TIMER3\_CC1ROUTE - CC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|---| | 0x5E4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | 0 | | Reset | | | | | | | | | | | | | | 2 | Š | • | | • | | | | • | | | | | • | • | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | ≥<br>Y | | | | | | | | | | | | | | | | RW | | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC1 pin select register | | | CC1 pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC1 port select register | | | CC1 port select register | | | | ## 25.6.121 GPIO\_TIMER3\_CC2ROUTE - CC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5E8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | • | • | | • | | | | | Š | e<br>X | | | | | | | • | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC2 pin select register | | | CC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC2 port select register | | | CC2 port select register | | | | # 25.6.122 GPIO\_TIMER3\_CCC0ROUTE - CCC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|--------| | 0x5EC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | ' | • | | • | • | | | Š | S<br>S | • | | ' | | • | | • | | | | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | ≥<br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC0 pin select register | | | CCC0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC0 port select register | | | CCC0 port select registe | r | | | ## 25.6.123 GPIO\_TIMER3\_CCC1ROUTE - CCC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x5F0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | • | • | | | | | | | | | Š | e<br>X | | | | | | | • | • | | • | | • | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC1 pin select register | | | CCC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC1 port select register | | | CCC1 port select registe | r | | | # 25.6.124 GPIO\_TIMER3\_CCC2ROUTE - CCC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x5F4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | • | • | | | | | • | • | | | Š | S<br>S | • | | | • | • | | • | | | | | | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC2 pin select register | | | CCC2 pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC2 port select register | | | CCC2 port select registe | r | | | # 25.6.125 GPIO\_TIMER4\_ROUTEEN - TIMER4 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---------|---------|---------|--------|--------|--------| | 0x5FC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | | • | • | | | • | • | • | | • | | | | | | • | • | | | • | | • | • | 0x0 | 000 | 000 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | ₩<br>M | W. | ₽ | ₽ | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | CCC2PEN | CCC1PEN | CCCOPEN | CC2PEN | CC1PEN | CCOPEN | | Bit | Name | Reset | Access | Description | |------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:6 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 5 | CCC2PEN | 0x0 | RW | CCC2 pin enable control bit | | | CCC2 pin enable control | bit | | | | 4 | CCC1PEN | 0x0 | RW | CCC1 pin enable control bit | | | CCC1 pin enable control | bit | | | | 3 | CCC0PEN | 0x0 | RW | CCC0 pin enable control bit | | | CCC0 pin enable control | bit | | | | 2 | CC2PEN | 0x0 | RW | CC2 pin enable control bit | | | CC2 pin enable control b | oit | | | | 1 | CC1PEN | 0x0 | RW | CC1 pin enable control bit | | | CC1 pin enable control b | oit | | | | 0 | CC0PEN | 0x0 | RW | CC0 pin enable control bit | | | CC0 pin enable control b | oit | | | ## 25.6.126 GPIO\_TIMER4\_CC0ROUTE - CC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x600 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | ' | | | | | | | • | | Š | Š | | | | | | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC0 pin select register | | | CC0 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC0 port select register | | | CC0 port select register | | | | # 25.6.127 GPIO\_TIMER4\_CC1ROUTE - CC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x604 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | | | | | | | | | | 2 | 3 | | | • | | | | • | | | | | | | • | | 0x0 | | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | | | Name | | | | | | | | | | | | | | 2 | <b>=</b> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC1 pin select register | | | CC1 pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC1 port select register | | | CC1 port select register | | | | ## 25.6.128 GPIO\_TIMER4\_CC2ROUTE - CC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x608 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 2 | 4 | က | 2 | 1 0 | | Reset | | | | ' | ' | | | | | | • | | | 5 | )<br>X | | | | | ' | | | | ' | | | | | ' | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CC2 pin select register | | | CC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CC2 port select register | | | CC2 port select register | | | | # 25.6.129 GPIO\_TIMER4\_CCC0ROUTE - CCC0 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x60C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | • | | • | | | | | | | 2 | e<br>S | | | • | | | | • | | | | | | • | • | | 0x0 | | | Access | | | | | | | | | | | | | | 7 | <u>}</u> | | | | | | | | | | | | | | | | RW | | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC0 pin select register | | | CCC0 pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC0 port select register | | | CCC0 port select registe | r | | | ## 25.6.130 GPIO\_TIMER4\_CCC1ROUTE - CCC1 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x610 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | | | | Š | e<br>X | | | | | | | • | • | | • | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC1 pin select register | | | CCC1 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC1 port select register | | | CCC1 port select registe | r | | | # 25.6.131 GPIO\_TIMER4\_CCC2ROUTE - CCC2 port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|---| | 0x614 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - c | > | | Reset | | | | | | | | | | | | | | 2 | 3 | | | • | | | | • | | | | | | • | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <b>=</b> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CCC2 pin select register | | | CCC2 pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CCC2 port select register | | | CCC2 port select registe | r | | | # 25.6.132 GPIO\_USART0\_ROUTEEN - USART0 pin enable | Offset | Bit Position | | | | | | |--------|-------------------------------------------------------------------|-------|---------|-------|-----|-------| | 0x61C | 33 33 34 35 36 37 37 38 38 39 39 39 39 39 39 39 39 39 39 39 39 39 | 4 | က | 2 | _ | 0 | | Reset | | 0x0 | 0x0 | 0x0 | 000 | 0×0 | | Access | | RW | ZW<br>W | RW | R | Z. | | Name | | TXPEN | CLKPEN | RXPEN | S | CSPEN | | Bit | Name | Reset | Access | Description | |------|---------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 4 | TXPEN | 0x0 | RW | TX pin enable control bit | | | TX pin enable control bit | t | | | | 3 | CLKPEN | 0x0 | RW | SCLK pin enable control bit | | | SCLK pin enable control | l bit | | | | 2 | RXPEN | 0x0 | RW | RX pin enable control bit | | | RX pin enable control bi | t | | | | 1 | RTSPEN | 0x0 | RW | RTS pin enable control bit | | | RTS pin enable control to | oit | | | | 0 | CSPEN | 0x0 | RW | CS pin enable control bit | | | CS pin enable control bi | t | | | | | | | | | ## 25.6.133 GPIO\_USART0\_CSROUTE - CS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|---|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x620 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 2 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | ' | • | ' | | | • | | | • | | Š | Š | | | | | | | | | | | | ' | | ' | 1 | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CS pin select register | | | CS pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CS port select register | | | CS port select register | | | | # 25.6.134 GPIO\_USART0\_CTSROUTE - CTS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x624 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | | | | | | | | | | 2 | 3 | | | • | | | | • | | | | | | • | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <b>=</b> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CTS pin select register | | | CTS pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CTS port select register | | | CTS port select register | | | | ## 25.6.135 GPIO\_USART0\_RTSROUTE - RTS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x628 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 0 | | Reset | | | • | | • | | | • | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | RTS pin select register | | | RTS pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | RTS port select register | | | RTS port select register | | | | # 25.6.136 GPIO\_USART0\_RXROUTE - RX port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x62C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | | | | | | | | | | 2 | 3 | | | • | | | | • | | | • | | | • | • | | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | _ | | Name | | | | | | | | | | | | | | 2 | <b>=</b> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | RX pin select register | | | RX pin select register | | | | | 15:2 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | RX port select register | | | RX port select register | | | | ## 25.6.137 GPIO\_USART0\_CLKROUTE - SCLK port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|--------| | 0x630 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 1 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | | | ' | | | | | | | • | | | 5 | )<br>X | | | | | | | | | ' | | | | | | | 0×0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | Z<br>S | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SCLK pin select register | | | SCLK pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SCLK port select register | | | SCLK port select registe | r | | | # 25.6.138 GPIO\_USART0\_TXROUTE - TX port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------|--------| | 0x634 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 5 | 4 | က | 2 | - 0 | _<br>> | | Reset | | | | | | | | | | | | | | 2 | Š | • | | | | | | • | | • | | | • | | • | | 0x0 | | | Access | | | | | | | | | | | | | | 7 | ≥<br>Y | | | | | | | | | | | | | | | | RW | | | Name | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | TX pin select register | | | TX pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | TX port select register | | | TX port select register | | | | ## 25.6.139 GPIO\_USART1\_ROUTEEN - USART1 pin enable | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|--------|--------|-------|--------|-------| | 0x63C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | | | ' | | | | | | | | | • | | | | • | | | | • | | | | | | 000 | 0x0 | 0×0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ₩<br>M | W. | RW | RW | R | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | TXPEN | CLKPEN | RXPEN | RTSPEN | CSPEN | | Bit | Name | Reset | Access | Description | |------|---------------------------|-------------|-------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 4 | TXPEN | 0x0 | RW | TX pin enable control bit | | | TX pin enable control bit | | | | | 3 | CLKPEN | 0x0 | RW | SCLK pin enable control bit | | | SCLK pin enable control | bit | | | | 2 | RXPEN | 0x0 | RW | RX pin enable control bit | | | RX pin enable control bit | t | | | | 1 | RTSPEN | 0x0 | RW | RTS pin enable control bit | | | RTS pin enable control b | oit | | | | 0 | CSPEN | 0x0 | RW | CS pin enable control bit | | | CS pin enable control bit | t | | | ## 25.6.140 GPIO\_USART1\_CSROUTE - CS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x640 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 0 | | Reset | | | • | | • | | • | • | | | • | | | 2 | e e | | | • | • | | | | | • | | | • | | | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <b>≧</b> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CS pin select register | | | CS pin select register | | | | | 15:2 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CS port select register | | | CS port select register | | | | # 25.6.141 GPIO\_USART1\_CTSROUTE - CTS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|--------| | 0x644 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 0 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | | ' | • | | ' | • | • | • | • | | | ć | S<br>S | | | ' | | | | | | | • | | | • | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | ≥<br>Y | | | | | | | | | | | | | | | | A<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | CTS pin select register | | | CTS pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | CTS port select register | | | CTS port select register | | | | ## 25.6.142 GPIO\_USART1\_RTSROUTE - RTS port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x648 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 1 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | 1 0 | | Reset | | • | | • | • | | | | | | • | | | 2 | OX<br>O | | | • | • | | | • | | | • | • | • | • | • | • | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | A.W. | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|--------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | RTS pin select register | | | RTS pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | RTS port select register | | | RTS port select register | | | | # 25.6.143 GPIO\_USART1\_RXROUTE - RX port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---------| | 0x64C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | - 0 | | Reset | | • | • | ' | • | | | • | | • | • | | | Š | Š | • | | ' | | • | | • | | | | | ' | • | • | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW<br>W | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | RX pin select register | | | RX pin select register | | | | | 15:2 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | RX port select register | | | RX port select register | | | | ## 25.6.144 GPIO\_USART1\_CLKROUTE - SCLK port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|------| | 0x650 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | • | | • | | | | | | • | | | 2 | e e | | | | | | | • | | | | | • | | | | 0x0 | | Access | | | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | 2 | <u> </u> | | | | | | | | | | | | | | | | PORT | | Bit | Name | Reset | Access | Description | |-------|---------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:20 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | SCLK pin select register | | | SCLK pin select register | | | | | 15:2 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | SCLK port select register | | | SCLK port select register | r | | | # 25.6.145 GPIO\_USART1\_TXROUTE - TX port/pin select | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|------|----|----|----|---|----|---|---|---|---|----------|---|---|---|------|----------| | 0x654 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | <u> </u> | | Reset | | | | • | | | | | | ' | | • | | 5 | 2 | • | | ' | • | | | ' | | | • | | <u>'</u> | • | ' | • | 0x0 | _ | | Access | | | | | | | | | | | | | | 7 | <u> </u> | | | | | | | | | | | | | | | | RW | | | Name | | | | | | | | | | | | | | 2 | <b>=</b> | | | | | | | | | | | | | | | | PORT | | | Bit | Name | Reset | Access | Description | |-------|-------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:20 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PIN | 0x0 | RW | TX pin select register | | | TX pin select register | | | | | 15:2 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | PORT | 0x0 | RW | TX port select register | | | TX port select register | | | | ### 26. 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. #### 26.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. #### 26.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 ### 26.2 Block Diagram An overview of the LDMA and the modules it interacts with is shown in Figure 26.1 LDMA Block Diagram on page 925. Figure 26.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. #### 26.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 24 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 26.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 26.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. ### 26.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. #### 26.3.1.1 DMA Transfer Size A DMA transfer is the smallest unit of data that can be transfered 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. ### 26.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 alligned 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 usefull for accessing peripheral FIFO or data registers. #### 26.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 26.3.6.1 Arbitration Priority for more details. #### 26.3.1.4 Transfer Count The descriptor transfer count defines how many DMA transfers to perform. The number of bytes transferred by the descripter will depend on both the transfer count XFERCNT and the SIZE field settings. TOTAL\_BYTES = XFERCNT \* SIZE ### 26.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\_BYTES of data and then stops. - · Linked Transfer descriptor: Transfers TOTAL\_BYTES of data and then loads the next linked descriptor. - Loop Transfer descriptor: Transfers TOTAL BYTES of data and performs loop control (see 26.3.2.2 Loop Counter). - Sync descriptor: Handle synchronization of the list with other entities (see 26.3.7.2 SYNC descriptor structure). - WRI descriptor: Writes a value to a location in memory (see 26.3.7.3 WRI descriptor structure). #### 26.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. #### 26.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 an 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 26.4.6 2D Copy for an common use of relative addressing. ### 26.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 26.2. Word and Half-Word Endian Byte Swap Examples #### 26.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 26.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 26.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. #### 26.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. #### 26.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. #### 26.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. ### 26.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. SOURCE-SEL selects the peripheral and SIGSEL picks which DMA request signals to use from the selected peripheral. Please refer to 26.5 LDMA Source Selection Details for more information. ### 26.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\_SREQ 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 26.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. SOURCE-SEL selects the peripheral and SIGSEL picks which DMA request signals to use from the selected peripheral. #### 26.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 SREQ's and wait for a full Request (REQ) signal. When the REQ is received the entire descriptor will be executed. 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. #### 26.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. #### 26.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. #### 26.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 26.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, CHNL1, 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, CHNL1, CHNL1, CHNL0, CHNL0, CHNL2, CHNL0, CHNL0, CHNL0, CHNL0, CHNL1, etc. #### 26.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 BLOCK-SIZE 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 26.2 AHB bus transfer arbitration interval on page 934 lists the arbitration rates. Table 26.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 26.3.7.1 XFER descriptor structure for more information about the location of the BLOCKSIZE bits in the data structure. ### 26.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 ### 26.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. | Name | | | | | | | | | | | | | | | Ві | it Po | sitio | on | | | | | | | | | | | | | | | |----------|---------|---------|-----|----|-----|-------------|----|--------|------------|------------|---------|-----------|----|------------|-----|-------|----------|----|----|----|---|---|---------|----|---|---|---|---|-----------|---|------------|----------| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 9 | 6 | 00 | 7 | 9 | 5 | 4 | ဗ | 2 | _ | 0 | | SRC CTRL | DSTMODE | SRCMODE | C I | | 127 | 0<br>1<br>1 | 0 | SKCINC | IGNORESREQ | DECLOOPCNT | REQMODE | DONEIFSEN | | 12 X X X X | | RC/ | BYTESWAP | R | | | | | XFERCNT | | | | | | STRUCTREQ | | STRUCTTYPE | ) | | DST | | | | | | | | | | | | | | | С | STA | ADDI | R | | | | | | | | | | | | | | | | LINK | | | | | | | | | | | | | | L | INK | ADD | R | | | | | | | | | | | | | | LINK | LINKMODE | ### 26.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 (SYNCTRIG & MATCHEN) == (MATCHVAL & 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 | | | | | | | | | | | | | | | Ві | t Po | sitio | n | | | | | | | | | | | | | | |------|----|------------------|---------|---------------|--------------|---------------|--------------|--------------|---------------|---------------|---------------|-----------|---------------|-------|--------------|------|---------------|-------|--------|-------|-------|--------|-------|-------|--------|-------|-------|------|-----|------|----------------------------| | | 31 | 30 | 59 | 28 | 27 | 56 | 25 | 24 | 23 | 22 | 2 | N 20 | 19 | 92 | 17 | 16 | 15 | 4 | 13 | 12 | = | 9 | တ | ω | 7 | 9 | 2 | 4 | က | 2 | л<br>О 1 | | CTRL | | | | | | | | | | | | DONEIFSEN | | | | | | | | | | | | | | | | | | | STRUCTTYPE | | SRC | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DST | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LINK | | | | | | | | | | | | | | L | INK | ADD | R | | | | | | | | | | | | | | LINKMODE | | Bit | | Name Description | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1:0 | | | S | TRU | JCT | TYF | Έ | | | | | D | esc | ripto | or Ty | /pe | | | | | | | | | | | | | | | | | | | | Т | his 1 | field | indi | cate | s w | hich | type | e of c | desc | ripto | r thi | s is. | It m | ust b | e 1 f | or a | SY | NC d | desc | ripto | or. | | | | | | | | | 20 | | | | ON | EIF | SEN | | | | | | D | one | if S | et ir | dic | ator | | | | | | | | | | | | | | | | | | | If | set | the | inte | rrupt | t flaç | g wil | l be | set v | wher | des | scrip | tor o | omp | oletes | S. | | | | | | | | | | | | | | | 15: | 8 | | S | YN( | CCL | R | | | | | | S | ync | Triç | gger | Cle | ar | | | | | | | | | | | | | | | | | | | a<br>a | give<br>re lo | en b<br>ade | it, a<br>ed w | one<br>ith a | sho<br>one | ould<br>e. Th | be lo | oade<br>nc tr | d to | the<br>er cle | corre | espo<br>unct | ndir | ng bit | . Set | t is g | giver | n pri | ority | ove | r cle | ear it | f bot | h co | rres | pon | ding | To clear<br>bits<br>rnate- | | 7:0 | | | S | YNO | CSE | Т | | | | | | S | ync | Triç | gger | Set | | | | | | | | | | | | | | | | | | | | to<br>g | o the | cor<br>et fu | resp<br>Incti | ond | ling<br>an c | bit. | Set i<br>be u | s giv | en p | riori | ty o | ver c | lear | if bo | th co | orres | spor | nding | g bits | are | e loa | ided | with | n a o | ne. | The | syn | loaded<br>c trig-<br>SYN- | | 15: | 8 | | N | /AT | CHE | N | | | | | | S | ync | Triç | gger | Mat | tch E | nab | le | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A syr<br>CHEN | | | | | | | | | | linke | ed D | MA | stru | cture | | 7:0 | | | N | /AT | CHV | /AL | | | | | | S | ync | Triç | gger | Mat | tch V | 'alue | ) | | | | | | | | | | | | | Bit Name Description 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: (SYNCTRIG & MATCHEN) == (MATCHVAL & MATCHEN). ### 26.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 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |------|-----------|--------------|----|----|----|----|----|----|----|----|----|------|----------|----|----|-----|-----|----|----|----|---|----|---|---|---|---|---|-------------|---|---|---|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 19 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | CTRL | DONEIFSEN | | | | | | | | | | | | | | | | | | | | | | | | | | | STELLCTTVEE | _ | | | | | SRC | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | DST | | | | | | | | | | | | | | | С | STA | ADD | R | | | | | | | | | | | | | | | | LINK | | | | | | | | | | | | LINK | LINKMODE | | | | | | | | | | | | | | | | | | | | | Bit | Name | Description | | | | | | | | | | |------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 1:0 | Descriptor Type | | | | | | | | | | | | | This field indicates which type of descriptor this is. It must be 2 for a WRI descriptor. | | | | | | | | | | | | 20 | Done if Set indicator | | | | | | | | | | | | | If set the interrupt flag will be set when descriptor completes. | | | | | | | | | | | | 31:0 | IMMVAL | Immediate Value for Write | | | | | | | | | | | | This bit-field specifies the immediate write occurs for WRI structures. | te data value that is to be written to the address pointed to by DSTADDR. Only one | | | | | | | | | | | 31:0 | DSTADDR | Address to write | | | | | | | | | | | | This bit-field specifies the address the immediate data should be written to. | | | | | | | | | | | ### 26.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. #### 26.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. #### 26.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. ### 26.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. #### 26.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. #### 26.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 26.5 Descriptor Linked List on page 939. 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 26.5 Descriptor Linked List on page 939. Figure 26.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. #### 26.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) - · IGNORESREQ=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 26.4.2 Descriptor Linked List Figure 26.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. #### 26.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 26.7 Descriptor List with Looping on page 942. 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 26.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 #### 26.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 T.TNK T.TNK LINK LINKADDR[29:0]=0x00000004 LINKADDR[29:0]=0x00000008 LINKADDR[29:0]=NA LINK=1 LINK=1 LINK=0 DST MATCHEN=0×80 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=0 SRC SRCCLR=0x0 SRCSET=0x80 (sets SYNCTRIG[7]) ``` Figure 26.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. #### 26.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 26.9 2D copy on page 945. 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 26.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 not 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=0x000000000 (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. #### 26.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 26.10 Infinite Ping-Pong Example on page 947. 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 26.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 = 0xFFFFFF0 (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 = 0xFFFFFF3 - LINKADDR = 0xFFFFFFF0 (previous descriptor) - LINK = 0 (link to previous descriptor) - LINKMD = 1 (relative addressing) #### 26.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 26.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. ### 26.5 LDMA Source Selection Details ### 26.5.1 LDMA Source Selection Details Table 26.3. LDMA Source Selection Details | SOURCESEL | Source Name | SIGSEL | Request Signal Name | |-----------|-------------|--------|-------------------------| | 0x0 | LDMAXBAR | 0x0 | LDMAXBAR_DMA_PRSREQ0 | | | | 0x1 | LDMAXBAR_DMA_PRSREQ1 | | 0x1 | TIMER0 | 0x0 | TIMER0_DMA_CC0 | | | | 0x1 | TIMER0_DMA_CC1 | | | | 0x2 | TIMER0_DMA_CC2 | | | | 0x3 | TIMER0_DMA_UFOF | | 0x2 | TIMER1 | 0x0 | TIMER1_DMA_CC0 | | | | 0x1 | TIMER1_DMA_CC1 | | | | 0x2 | TIMER1_DMA_CC2 | | | | 0x3 | TIMER1_DMA_UFOF | | 0x3 | USART0 | 0x0 | USARTO_DMA_RXDATAV | | | | 0x1 | USARTO_DMA_RXDATAVRIGHT | | | | 0x2 | USARTO_DMA_TXBL | | | | 0x3 | USARTO_DMA_TXBLRIGHT | | | | 0x4 | USARTO_DMA_TXEMPTY | | 0x4 | USART1 | 0x0 | USART1_DMA_RXDATAV | | | | 0x1 | USART1_DMA_RXDATAVRIGHT | | | | 0x2 | USART1_DMA_TXBL | | | | 0x3 | USART1_DMA_TXBLRIGHT | | | | 0x4 | USART1_DMA_TXEMPTY | | 0x5 | I2C0 | 0x0 | I2C0_DMA_RXDATAV | | | | 0x1 | I2C0_DMA_TXBL | | 0x6 | I2C1 | 0x0 | I2C1_DMA_RXDATAV | | | | 0x1 | I2C1_DMA_TXBL | | 0xA | IADC0 | 0x0 | IADC0_DMA_IADC_SCAN | | | | 0x1 | IADC0_DMA_IADC_SINGLE | | 0xB | MSC | 0x0 | MSC_DMA_WDATA | | 0xC | TIMER2 | 0x0 | TIMER2_DMA_CC0 | | | | 0x1 | TIMER2_DMA_CC1 | | | | 0x2 | TIMER2_DMA_CC2 | | | | 0x3 | TIMER2_DMA_UFOF | | SOURCESEL | Source Name | SIGSEL | Request Signal Name | |-----------|-------------|--------|---------------------| | 0xD | TIMER3 | 0x0 | TIMER3_DMA_CC0 | | | | 0x1 | TIMER3_DMA_CC1 | | | | 0x2 | TIMER3_DMA_CC2 | | | | 0x3 | TIMER3_DMA_UFOF | | 0xE | PDM | 0x0 | PDM_DMA_RXDATAV | | 0xF | EUART0 | 0x0 | EUART0_DMA_RXFL | | | | 0x1 | EUART0_DMA_TXFL | | 0x10 | TIMER4 | 0x0 | TIMER4_DMA_CC0 | | | | 0x1 | TIMER4_DMA_CC1 | | | | 0x2 | TIMER4_DMA_CC2 | | | | 0x3 | TIMER4_DMA_UFOF | ## 26.6 LDMA Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|--------------------|-------------|------------------------------------------| | 0x000 | LDMA_IPVERSION | R | DMA Channel Request Clear Register | | 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_SYNCSWSET | W | DMA Sync Trig Sw Set Register | | 0x014 | LDMA_SYNCSWCLR | 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 | DMA Channel Request Clear Register | | 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_SYNCSWSET_SET | W | DMA Sync Trig Sw Set Register | | 0x1014 | LDMA_SYNCSWCLR_SET | W | DMA Sync Trig Sw Clear register | | 0x1018 | LDMA_SYNCHWEN_SET | RW | DMA Sync HW trigger enable register | | Offset | Name | Туре | 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 | DMA Channel Request Clear Register | | 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_SYNCSWSET_CLR | W | DMA Sync Trig Sw Set Register | | 0x2014 | LDMA_SYNCSWCLR_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 | Туре | 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 | DMA Channel Request Clear Register | | 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_SYNCSWSET_TGL | W | DMA Sync Trig Sw Set Register | | 0x3014 | LDMA_SYNCSWCLR_TGL | W | DMA Sync Trig Sw Clear register | | 0x3018 | LDMA_SYNCHWEN_TGL | RW | DMA Sync HW trigger enable register | | 0x301C | LDMA_SYNCHWSEL_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 | Туре | 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 | ## 26.7 LDMA Register Description ## 26.7.1 LDMA\_IPVERSION - DMA Channel Request Clear Register | Offset | | | Bit Position | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------|----|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|---|----|---|---|---|---|---|-------|--------|---|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | Reset | | | • | | • | | | | | | | | | | • | • | | | | | | | | | | | | 2 | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | Δ | ۷ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | NOIVE | 5 | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | )/ED6 | Ź<br>J | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | = | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:8 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 7:0 | IPVERSION | 0x0 | 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. | | | | | | | | | | | | ## 26.7.2 LDMA\_EN - DMA module enable disable Register | Offset | Bit Position | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 0x004 | 33 4 5 6 6 6 7 8 8 8 9 9 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 0 | | Reset | | 0×0 | | Access | | A<br>M | | Name | | Z<br>E<br>N | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:1 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 0 | EN | 0x0 | RW | LDMA module enable and disable register | | | | | | | | | | | 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.7.3 LDMA\_CTRL - DMA Control Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|---------|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | | | | | 0x1E | | | | • | | | | • | • | • | | | | | | | | • | | | | • | | | | | | Access | Z<br>M | | | | | W. | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | CORERST | | | | | NUMFIXED | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|--------------------------|--------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------| | 31 | CORERST | 0x0 | RW | Reset DMA controller | | | Trigger a reset of the L | DMA controlle | er core without I | osing register configuration | | 30:29 | Reserved | To ensure ventions | compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 28:24 | NUMFIXED | 0x1E | RW | Number of Fixed Priority Channels | | | | | • | ation channels. Channels CH0 though CH(n-1) are fixed, and chanthe field value. The reset value will give all fixed channels. | | 23:0 | Reserved | To ensure ventions | compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | ## 26.7.4 LDMA\_STATUS - DMA Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|------------------------------------------|----|----|----|----------|----|----|----|----|----|----|----|-----------|----|------|------|----|----|----|---|---------|---|---|---|---|---------|---|---|---|--------|---------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 7 | _ | 0 | | Reset | | 29<br>28<br>27<br>27<br>0x1F<br>25<br>25 | | | | | | | | | | | | 0x10 | | • | | • | • | | | 0×0 | | | | | 0×0 | | | | 0x0 | 0×0 | | Access | | | | | | <u>~</u> | | | | | | | | <u>~</u> | | | | | | | | 2 | | | | | 2 | | | | 22 | ď | | Name | | | | | | CHNUM | | | | | | | | FIFOLEVEL | | | | | | | | CHERROR | | | | | CHGRANT | | | | ANYREQ | ANYBUSY | | Bit | Name | Reset | Access | Description | |-------|---------------------------------------------------|-----------------|--------------------|--------------------------------------------------------------------------| | 31:29 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 28:24 | CHNUM | 0x1F | R | Number of Channels | | | The value of CHNUM alv | ways reads th | e total number o | of channels present for this instance of the DMA controller module. | | 23:21 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 20:16 | FIFOLEVEL | 0x10 | R | FIFO Level | | | The value of FIFOLEVE this register will read the | | | ries currently in the FIFO. (Note when all channels are disabled, FIFO.) | | 15:13 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 12:8 | CHERROR | 0x0 | R | Errant Channel Number | | | When the ERROR flag is a transfer error. | s set in the LD | DMA_IF register | the CHERROR field will indicate the most recent channel to have | | 7:3 | CHGRANT | 0x0 | R | Granted Channel Number | | | The value of this field incis zero. | dicates the cu | rrently active ch | annel or last active channel. Note that the reset value for this field | | 2 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 1 | ANYREQ | 0x0 | R | Any DMA Channel Request Pending | | | The value of this bit will l | be TRUE (1) i | f any requests a | are pending | | 0 | ANYBUSY | 0x0 | R | Any DMA Channel Busy | | | The value of this bit will | be TRUE (1) i | f one or more D | MA channels are actively transferring data | ## 26.7.5 LDMA\_SYNCSWSET - DMA Sync Trig Sw Set Register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|---|----|---|---|---|---|---|---|------|---|---|---| | 0x010 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | | • | | | | | | | | | | | • | | • | • | | | | | | | 2 | OXO. | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | F | П | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|----------------|-------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | SYNCSWSET | 0x0 | W | DMA SYNC Software Trigger Set | | | Sets the corresponding I | oit in the SYN | CSTATUS.SYN | CTRIG field to value 1. | ## 26.7.6 LDMA\_SYNCSWCLR - DMA Sync Trig Sw Clear register | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|---|---|---|---|---|---|---|-----|---|---|---| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | OXO | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | SYNCSWCLR | 0x0 | W | DMA SYNC Software Trigger Clear | | | Clears the corresponding | g bit in the S | /NCSTATUS.S | YNCTRIG field to value 0. | ## 26.7.7 LDMA\_SYNCHWEN - DMA Sync HW trigger enable register | Offset | | | | | | | | | | | | | | | Ві | it Po | siti | on | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|-------|------|----|----|----|----|----|---|---|---|---|---|------|-----------|---|-----| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 41 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | - 0 | | Reset | | | | | | | | | | | | Š | OXO | | | | | | | | | | | | | | | | 0X0 | | | | Access | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | i | ¥<br>X | | | | Name | | | | | | | | | | | | | OTINCCE REN | | | | | | | | | | | | | | | <br> | SYNCSETEN | | | | Bit | Name | Reset | Access | Description | |-------|------------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:24 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 23:16 | SYNCCLREN | 0x0 | RW | Hardware Sync Trigger Clear Enable | | | Enables the corresp [23:16]. | onding bit in the | SYNCSTATU | S.SYNCTRIG field to be cleared by PRS channel 7-0, mapping to bits | | 15:8 | Reserved | To ensure ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | SYNCSETEN | 0x0 | RW | Hardware Sync Trigger Set Enable | | | Enables the corresp [7:0]. | onding bit in the | SYNCSTATU | S.SYNCTRIG field to be set by PRS channel 7-0, mapping to bits | ## 26.7.8 LDMA\_SYNCHWSEL - DMA Sync HW trigger selection register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|------|------|----|----|----|---|----|----------|---|---|---|---|-------------|---|---|---|---| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | ~ | 0 | | Reset | | | • | | | | ' | | | | | Š | )<br>X | | | | | ' | | ' | | | <u>'</u> | | | ' | | 2 | 3 | | ' | | | Access | | | | | | | | | | | | 2 | <u>}</u> | | | | | | | | | | | | | | | 2 | 2 | | | - | | Name | | | | | | | | | | | | | TINCCLRED | | | | | | | | | | | | | | | SVNCSETEDGE | - | | | | | Bit | Name | Paget | A 22222 | Description | |-------|--------------------------|--------------------|-----------------|--------------------------------------------------------------------------| | BIT | Name | Reset | Access | Description | | 31:24 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 23:16 | SYNCCLREDGE | 0x0 | RW | Hardware Sync Trigger Clear Edge Select | | | Select rising or falling | edge detection | on PRS to clea | ar trigger. | | | Value | Mode | | Description | | | 0 | RISE | | Use rising edge detection | | | 1 | FALL | | Use falling edge detection | | 15:8 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | SYNCSETEDGE | 0x0 | RW | Hardware Sync Trigger Set Edge Select | | | Select rising or falling | edge detection | n on PRS to set | trigger. | | | Value | Mode | | Description | | | 0 | RISE | | Use rising edge detection | | | 1 | FALL | | Use falling edge detection | | | | | | | ## 26.7.9 LDMA\_SYNCSTATUS - DMA Sync Trigger Status Register | Offset | Bit Position | | |--------|-----------------------------------------|-----------------| | 0x020 | 8 8 8 2 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 | r 9 r 4 r 7 r 0 | | Reset | | 0×0 | | Access | | ď | | Name | | SYNCTRIG | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:8 | Reserved | To ensure o | compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 7:0 | SYNCTRIG | 0x0 | R | sync trig status | | | | | | | | | | | | | ne status of setting and clearing by software (SYNCSWSET/SYNCSWCLR), hardware (PRS), and loading actures. Setting a bit always takes prescedence over clearing. | | | | | | | | | | | | ## 26.7.10 LDMA\_CHEN - DMA Channel Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---------------|---|---|---| | 0x024 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | • | | • | | • | | | • | • | | | | | • | | • | | | | | | | 2 | e<br>S | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ĺ | Z<br>II<br>II | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|-----------------------------------------------------------------------------------------------|-----------------------|------------------|-------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:8 | Reserved | To ensure<br>ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 7:0 | CHEN | 0x0 | W | Channel Enables | | | | | | | | | | | Setting one of these bits will enable the respective DMA channel, writing zeros has no effect | | | | | | | | | | | | ## 26.7.11 LDMA\_CHDIS - DMA Channel Disable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|--------|-------|---|---|---| | 0x028 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | • | | | | • | | | | | | | • | • | | • | | | | | | | | 2 | Š | | · | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | } | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | מוכווט | SIGHO | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | |------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | 7:0 | CHDIS | 0x0 | W | DMA Channel disable | | | | | | | | | | | | s will disable respective DMA channel, writing zeros has no effect. If set while a transfer is in ansfer block will complete. The remaining blocks will pause until resumed later by setting corre- | | | | | | | | | | | # 26.7.12 LDMA\_CHSTATUS - DMA Channel Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|---|----|---|---|---|-----------|----------|---|---|---| | 0x02C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 6 | 80 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | ۵ | צ | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | OLITATOLO | <u> </u> | | | | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|--------------------------------------------------------------------------------|-------------------|-----------------|---------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:8 | Reserved | To ensur ventions | e compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 7:0 | CHSTATUS | 0x0 | R | DMA Channel Status | | | | | | | | | | | | The value of this bit will be TRUE (1) if one or more DMA channels are enabled | | | | | | | | | | | | | ## 26.7.13 LDMA\_CHBUSY - DMA Channel Busy Register | Offset | Bit Position | | |--------|---------------------------------------------------------------|-----------------------------------------------------------| | 0x030 | 30<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>2 | 7 9 2 4 8 2 1 0 | | Reset | | 0×0 | | Access | | α | | Name | | BUSY | | Bit | Name | Reset | Access | Description | | | | | | | | | | |------|-----------------------------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | | | | | | | | | | 7:0 | BUSY | 0x0 | R | Channels Busy | | | | | | | | | | | | The bits of this field read 1 when the corresponding channel is busy. | | | | | | | | | | | | | ## 26.7.14 LDMA\_CHDONE - DMA Channel Linking Done Register | Offset | Bit Position | | | | | | | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------|---------|-----|-----------------------------------------|---------| | 0x034 | 33 34 35 36 37 38 39 30 30 31 32 33 34 35 36 37 37 38 30 30 31 31 32 33 33 33 30 31 32 33 33 34 35 36 37 37 38 48 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 40 <th>7</th> <th>5</th> <th>4</th> <th>က</th> <th>7 -</th> <th>0</th> | 7 | 5 | 4 | က | 7 - | 0 | | Reset | | 0X 0X | 000 | 0x0 | 0x0 | 000000000000000000000000000000000000000 | 0x0 | | Access | | RW<br>RW | W. | RW | RW | %<br>₩<br>% | RW<br>W | | Name | | CHDONE7<br>CHDONE6 | CHDONE5 | CHDONE4 | HDO | CHDONE2<br>CHDONE1 | CHDONEO | | Bit | Name | Reset | Access | Description | |------|----------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7 | CHDONE7 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | | 6 | CHDONE6 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | | 5 | CHDONE5 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | | 4 | CHDONE4 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | | 3 | CHDONE3 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | | 2 | CHDONE2 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | | 1 | CHDONE1 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | | 0 | CHDONE0 | 0x0 | RW | DMA Channel Link done intr flag | | | | | | egister when the entire linked transfer is done. The interrupt serv-<br>ires this will be set once the structure is done. | ## 26.7.15 LDMA\_DBGHALT - DMA Channel Debug Halt Register | Offset | Bit Position | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------| | 0x038 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>L 0 0 4 0 0 0</th> | L 0 0 4 0 0 0 | | Reset | | 0×0 | | Access | | RW | | Name | | DBGHALT | | Bit | Name | Reset | Access | Description | |------|----------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility witi | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | DBGHALT | 0x0 | RW | DMA Debug Halt | | | Setting one of these bits halted. This may be usef | | | DMA channel's peripheral request when debugging and the CPU is re. | ## 26.7.16 LDMA\_SWREQ - DMA Channel Software Transfer Request | Offset | | | | | | | | | | | | | | | Bi | t Pc | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|-------|---------------------------|---|---|---| | 0x03C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | œ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | CMDEO | )<br> <br> <br> <br> <br> | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | SWREQ | 0x0 | W | Software Transfer Requests | | | Setting one of these bits | will trigger a | DMA transfer fo | r the corresponding channel. Writing zeros has no effect. | ## 26.7.17 LDMA\_REQDIS - DMA Channel Request Disable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|--------|----------|---|---|---| | 0x040 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ∞ | 7 | 9 | 5 | 4 | 3 | 2 | _ | 0 | | Reset | | | | | • | | | | | | | | | • | | • | | • | | | | | | | | • | | 2 | 3 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | Š | <u>}</u> | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | REODIS | 3 | | | | | Bit | Name | Reset | Access | Description | |------|-----------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | REQDIS | 0x0 | RW | DMA Request Disables | | | Setting one of these bits ripheral requests will be | • | eripheral reques | sts for the corresponding channel. When cleared any pending pe- | ## 26.7.18 LDMA\_REQPEND - DMA Channel Requests Pending Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|------------------|---|---|---| | 0x044 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | Δ | <u> </u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ֝֟֝֝֟֝֝֝֟֝֝֟֝֝֟֝ | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | j<br>Ž | | | | | Bit | Name | Reset | Access | Description | |------|-----------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | REQPEND | 0x0 | R | DMA Requests Pending | | | When a DMA channel ha | ıs a pending p | peripheral reque | st the corresponding REQPEND bit will read 1. | ## 26.7.19 LDMA\_LINKLOAD - DMA Channel Link Load Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|-----|----------|---|---|---| | 0x048 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | • | • | | | • | | | • | | | | • | | | | | | | • | • | | | | | • | 2 | 3 | | · | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ראַ | 3 | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | X | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | | | | | Bit | Name | Reset | Access | Description | |------|----------------------------------------------------|-------------|--------------------|----------------------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | LINKLOAD | 0x0 | W | DMA Link Loads | | | Setting one of these bits nel. This empowers softv | | | DMA channel to load the next DMA structure and enable the chan-<br>nce of descriptors. | ## 26.7.20 LDMA\_REQCLEAR - DMA Channel Request Clear Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|----------|---|---|---| | 0x04C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 | 2 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | | | | | Bit | Name | Reset | Access | Description | |------|---------------------------|----------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | REQCLEAR | 0x0 | W | DMA Request Clear | | | Setting one of these bits | will clear any | internally regist | ered transfer requests for the corresponding channel. | ## 26.7.21 LDMA\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|------|----|----|----|---|----|---|---|---------|-------|---------|-------|--------|-------|-------|-------| | 0x050 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | 0x0 | | • | | | | | | | | | | | • | ' | <u>'</u> | | • | | | | | | | 0x0 | 000 | 0x0 | 0×0 | 000 | 0x0 | 0x0 | 0x0 | | Access | Z. | | | | | | | | | | | | | | | | | | | | | | | | ZW<br>W | W. | ZW<br>W | W. | ₩<br>M | ₽ | Z. | S. | | Name | ERROR | | | | | | | | | | | | | | | | | | | | | | | | DONE7 | DONE6 | DONE5 | DONE4 | DONE3 | DONE2 | DONE1 | DONE0 | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|------------------|--------------------------------------------------------------------------| | 31 | ERROR | 0x0 | RW | Error Flag | | | Set to 1 on an Error | | | | | 30:8 | Reserved | To ensure ventions | compatibility w | ith future devices, always write bits to 0. More information in 1.2 Con- | | 7 | DONE7 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | | 6 | DONE6 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | | 5 | DONE5 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | | 4 | DONE4 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | | 3 | DONE3 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | | 2 | DONE2 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | | 1 | DONE1 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | | 0 | DONE0 | 0x0 | RW | DMA Structure Operation Done | | | When a channel com | pletes a transfe | er or sync opera | tion, the corresponding DONE bit is set the LDMA_IF register. | ## 26.7.22 LDMA\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|--------|---|---|---|---| | 0x054 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | ဝ | æ | 7 | 9 | 2 | 4 | 3 | 2 | _ | 0 | | Reset | 0X0 | | | | ' | | | | | | | | | • | | | | | | | | | | | | | | > | 2 | | | | | Access | ₩<br>M | | | | | | | | | | | | | | | | | | | | | | | | | | | Ž | 2 | | | | | Name | ERROR | | | | | | | | | | | | | | | | | | | | | | | | | | | HUOUHU | | | | | | Bit | Name | Reset | Access | Description | |------|----------------------|----------------------|----------------|---------------------------------------------------------------------------| | 31 | ERROR | 0x0 | RW | Enable or disable the error interrupt | | | This is the bitfield | to enable the link o | lone interrupt | | | 30:8 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | CHDONE | 0x0 | RW | Enable or disable the done interrupt | | | This is the bitfield | to enable the AHB | bus error inte | errupt | # 26.7.23 LDMA\_CHx\_CFG - Channel Configuration Register | Offset | | | | | | | | | | | | | | | Bi | it Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|------------|------------|----|----|-----------|----------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x05C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | 1 | 0 | | Reset | | | | | | | | | | | 0X0 | 0x0 | | • | 2 | <u> </u> | | • | | | | | • | | • | • | | | | | | | | Access | | | | | | | | | | | Z. | RW | | | 2 | <u>}</u> | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | DSTINCSIGN | SRCINCSIGN | | | OTO ISSUE | ARBOLOTO | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|-----------------------|--------------------|------------------------|------------------------------------------------------------------------| | 31:22 | Reserved | To ensure ventions | e compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 21 | DSTINCSIGN | 0x0 | RW | Destination Address Increment Sign | | | 0: Increment destinat | tion address, 1 | Decrement desti | nation address | | | Value | Mode | | Description | | | 0 | POSITIVI | E | Increment destination address | | | 1 | NEGATI | /E | Decrement destination address | | 20 | SRCINCSIGN | 0x0 | RW | Source Address Increment Sign | | | 0: Increment source | address, 1: De | crement source ad | ddress | | | Value | Mode | | Description | | | 0 | POSITIVI | E | Increment source address | | | 1 | NEGATI | /E | Decrement source address | | 19:18 | Reserved | To ensure ventions | e compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 17:16 | ARBSLOTS | 0x0 | RW | Arbitration Slot Number Select | | | For channels using re | ound robin arbi | tration, this bit-fiel | d 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 | To ensure ventions | e compatibility with | h future devices, always write bits to 0. More information in 1.2 Con- | ## 26.7.24 LDMA\_CHx\_LOOP - Channel Loop Counter Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|----------|---|---|---|---| | 0x060 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 41 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | ' | | | | ' | | | | | | ' | | | | | | | | | | | ' | | | | 2 | 3 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | 2 | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | TNOGOOL | | | | | | Bit | Name | Reset | Access | Description | |------|--------------------------------------------------------|-------------|--------------------|------------------------------------------------------------------------| | 31:8 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 7:0 | LOOPCNT | 0x0 | RW | Linked Structure Sequence Loop Counter | | | This bit-field specifies the fore using a looping desc | | terations when ι | ising looping descriptors. Software should write to LOOPCNT be- | # 26.7.25 LDMA\_CHx\_CTRL - Channel Descriptor Control Word Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|---------|---------|--------|----------|------|------|-----|------------------|------------|------------|---------|---------|----|------------|-----------|------|----------|----|----|----|---|----|---------|---|---|---|---|---|-----------|---|-------------|----------| | 0x064 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | 000 | 000 | 2 | 2 | 2 | 2 | Ş | Š | 0x0 | 0x0 | 000 | 0x0 | | 2 | OX O | | 0×0 | | • | | | | 0x0 | | • | | | | 000 | | 0 | S<br>S | | Access | œ | œ | 20 | <u> </u> | 20 | 2 | 2 | ≥<br>Y | W. | RW | ₩<br>M | R<br>M | | 2 | <u>}</u> | | RW | | | | | | R. | | | | | | 2 | | 710 | <u>}</u> | | Name | DSTMODE | SRCMODE | CIVIFO | ) | SIZE | SIZE | O V | OKCINC<br>OKCINC | IGNORESREQ | DECLOOPCNT | REQMODE | DONEIEN | | BI OCKSI7E | BLUCKSIZE | | BYTESWAP | | | | | | XFERCNT | | | | | | STRUCTREQ | | STDIICTTVBE | _ | | | | SRCI | DON | BLOC | XFEF | STRI | STRU | |-------|------------------------------------------------------------|----------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| | Bit | Name | Reset | Access | Description | | _ | | | 31 | DSTMODE | 0x0 | R | | dressing Mode | | | | | This field specifies | the destination ad<br>ne destination addr | dressing mod | e of linked descriptor | rs. After loading a linked or. Note that the first des | | | | | Value | Mode | | Description | | | | | | 0 | ABSOLUT | E | The DSTADDR address of the c | field of LDMA_CHx_DST<br>lestination data. | Γ contains the abs | olute | | | 1 | RELATIVE | | The DSTADDR offset of the des | field of LDMA_CHx_DS1<br>stination data. | Γ contains the rela | ntive | | 30 | SRCMODE | 0x0 | R | Source Addres | sing Mode | | | | | | | | | fter loading a linked desc<br>that the first descriptor al | | | | | | | | | | | | | | Value | Mode | | Description | | | | | | Value<br>0 | Mode<br>ABSOLUT | E | • | field of LDMA_CHx_SR0<br>cource data. | C contains the abs | solute | | | | | | The SRCADDR address of the s | source data. field of LDMA_CHx_SR0 | | | | 29:28 | 0 | ABSOLUT | | The SRCADDR address of the s The SRCADDR offset of the sou | source data. field of LDMA_CHx_SR0 | | | | 29:28 | 0 1 DSTINC This bit-field specif | ABSOLUT RELATIVE 0x0 fies the stride or nu | RW | The SRCADDR address of the s The SRCADDR offset of the sou | source data. field of LDMA_CHx_SR0 | C contains the rela | ative | | 29:28 | 0 1 DSTINC This bit-field specif | ABSOLUT RELATIVE 0x0 fies the stride or nu | RW | The SRCADDR address of the s The SRCADDR offset of the sou | field of LDMA_CHx_SROurce data. Idress Increment Size crement the destination as | C contains the rela | ative | | 29:28 | DSTINC This bit-field specif data is transferred. | ABSOLUT RELATIVE 0x0 fies the stride or nu The unit data wid | RW | The SRCADDR address of the s The SRCADDR offset of the sou Destination Addresses to income the sound by the SIZE bit-field description | field of LDMA_CHx_SROurce data. Idress Increment Size crement the destination as | C contains the related to the | unit of | | 29:28 | DSTINC This bit-field specif data is transferred. | ABSOLUT RELATIVE 0x0 fies the stride or nu . The unit data wid Mode | RW | The SRCADDR address of the south offset of the south offset | field of LDMA_CHx_SRO<br>free data. Idress Increment Size Externent the destination and and can be a byte, half- | ddress after each word or word. | unit of | | 29:28 | DSTINC This bit-field specificata is transferred. Value 0 | ABSOLUT RELATIVE 0x0 fies the stride or nu The unit data wid Mode ONE | RW | The SRCADDR address of the saddress of the saddress of the sound offset of the sound offset of the sound of the SIZE bit-field th | field of LDMA_CHx_SROurce data. Idress Increment Size crement the destination and and can be a byte, half-mation address by one un | ddress after each word or word. hit data size after each wit data sizes after | unit of | | Bit | Name | Reset | Access | Description | |-------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27:26 | SIZE | 0x0 | RW | Unit Data Transfer Size | | | This field specifies the | ne size of data t | ransferred. | | | | Value | Mode | | Description | | | 0 | BYTE | | Each unit transfer is a byte | | | 1 | HALFWO | RD | Each unit transfer is a half-word | | | 2 | WORD | | Each unit transfer is a word | | 25:24 | SRCINC | 0x0 | RW | Source Address Increment Size | | | | | | ata addresses to increment the source address after each unit of data e 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 | Ignore Sreq | | | The channel arbiter | will ignore single | e requests (SRE | (Q) and only respond to multiple requests (REQ) when this bit is set. | | 22 | DECLOOPCNT | 0x0 | RW | Decrement Loop Count | | | When using looping, scriptor execution. | , setting this bit | will decrement t | ne LOOPCNT field in the LDMA_CHx_LOOP register after each de- | | 21 | REQMODE | 0x0 | RW | DMA Request Transfer Mode Select | | | Selects the DMA Re | quest 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 | ALL<br>0x0 | RW | | | 20 | DONEIEN | 0x0<br>et the interrupt fl | lag when the tra | XFRCNT field. | | 20 | DONEIEN Setting this bit will se | 0x0<br>et the interrupt fl | lag when the tra | DMA Operation Done Interrupt Flag Set En | | | DONEIEN Setting this bit will se synchronized in the BLOCKSIZE | 0x0 et the interrupt fl case of a SYNC | lag when the tra<br>transfer. | DMA Operation Done Interrupt Flag Set En nsfer is done, or linked in the case where the LINK bit is set, or | | | DONEIEN Setting this bit will se synchronized in the BLOCKSIZE | 0x0 et the interrupt fl case of a SYNC | lag when the tra<br>transfer. | DMA Operation Done Interrupt Flag Set En nsfer is done, or linked in the case where the LINK bit is set, or Block Transfer Size | | | DONEIEN Setting this bit will se synchronized in the BLOCKSIZE This bit-field controls | 0x0 et the interrupt fl case of a SYNC 0x0 s the number of | lag when the tra<br>transfer. | DMA Operation Done Interrupt Flag Set En Insfer is done, or linked in the case where the LINK bit is set, or Block Transfer Size ers per arbitration cycle | | | DONEIEN Setting this bit will se synchronized in the BLOCKSIZE This bit-field controls Value | 0x0 et the interrupt fl case of a SYNC 0x0 s the number of | lag when the tra<br>transfer. | DMA Operation Done Interrupt Flag Set En Insfer is done, or linked in the case where the LINK bit is set, or Block Transfer Size Pers per arbitration cycle Description | | | DONEIEN Setting this bit will se synchronized in the BLOCKSIZE This bit-field controls Value | 0x0 et the interrupt fl case of a SYNC 0x0 s the number of Mode UNIT1 | lag when the tra<br>transfer. | DMA Operation Done Interrupt Flag Set En Insfer is done, or linked in the case where the LINK bit is set, or Block Transfer Size Inster arbitration cycle Description One unit transfer 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 | UNIT102 | 4 | 1024 unit transfers per arbitration | | | 15 | ALL | | Transfer all units as specified by the XFRCNT field | | 15 | BYTESWAP | 0x0 | RW | Endian Byte Swap | | | For word and half-wo | rd transfers, se | etting this bit wil | I swap all bytes of each word or half-word. | | 14:4 | XFERCNT | 0x0 | RW | DMA Unit Data Transfer Count | | | Specifies number of ushould be one less the | | | r bytes) to transfer, as determined by the SIZE field. The value written | | 3 | STRUCTREQ | 0x0 | R | Structure DMA Transfer Request | | | Structure Transfer Re | equest | | | | 2 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 1:0 | STRUCTTYPE | 0x0 | RW | DMA Structure Type | | | DMA Structure type | | | | | | Value | Mode | | Description | | | 0 | TRANSF | ER | DMA transfer structure type selected. | | | 1 | SYNCHR | ONIZE | Synchronization structure type selected. | | | 2 | WRITE | | Write immediate value structure type selected. | ## 26.7.26 LDMA\_CHx\_SRC - Channel Descriptor Source Address | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|--------|----|----|----|----|----|----|----|----|----|----|----|---|----|--------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|---| | 0x068 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | ဝ | ∞ | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | 0X0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Access | | ŏ<br>ŏ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | 900000 | 2 | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------|-------|--------|---------------------| | 31:0 | SRCADDR | 0x0 | RW | Source Data Address | 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. ## 26.7.27 LDMA\_CHx\_DST - Channel Descriptor Destination Address | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|--------|------|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---| | 0x06C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 8 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 9 | 6 | ∞ | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | • | | | | | | | | | | 2 | 3 | | | | | | | | • | | | | | | | | | Access | | | | | | | | | | | | | | | | 2 | 2 | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | GUATAD | ζ | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|---------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------| | 31:0 | DSTADDR | 0x0 | RW | Destination Data Address | | | | | | eading from this register during a DMA transfer will indicate the ter is incremented or decremented with each destination write. | # 26.7.28 LDMA\_CHx\_LINK - Channel Descriptor Link Address | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|--------|----|----|----|----|----|----|----|----|----|----|----|--------|----------|------|------|----|----|----|---|----|---|----|---|---|---|---|---|---|------|----------| | 0x070 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 80 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | ' | • | | | | | | | | | | | • | 5 | 2 | | | • | | | | | • | | ' | 1 | | | | 000 | 0x0 | | Access | | %<br>% | | | | | | | | | | | | ₩<br>M | ~ | | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | פרילאואו | ζ | | | | | | | | | | | | | | | LINK | LINKMODE | | Bit | Name | Reset | Access | Description | |------|----------|---------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:2 | LINKADDR | 0x0 | RW | Link Structure Address | | | | | | ted descriptor to this register. When a linked descriptor is loaded, it this register will reflect the address of the next linked descriptor. | | 1 | LINK | 0x0 | RW | Link Next Structure | | | | | | T set, the DMA will load the next linked descriptor. If the next linked ne next linked descriptor. | | 0 | LINKMODE | 0x0 | R | Link Structure Addressing Mode | | | • | • | | descriptors. After loading a linked descriptor, reading this field will indi-<br>criptor. Note that the first descriptor always uses absolute addressing | | | Value | Mode | | Description | | | | | | | | | 0 | ABSOLU <sup>*</sup> | TE | The LINKADDR field of LDMA_CHx_LINK contains the absolute address of the linked descriptor. | # 26.8 LDMAXBAR Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | Description | |--------|------------------------------|------|---------------------------------------| | 0x000 | LDMAXBAR_CHx_REQSEL | RW | Channel Peripheral Request Select Reg | | 0x1000 | LDMAXBAR_CHx_RE-<br>QSEL_SET | RW | Channel Peripheral Request Select Reg | | 0x2000 | LDMAXBAR_CHx_RE-<br>QSEL_CLR | RW | Channel Peripheral Request Select Reg | | 0x3000 | LDMAXBAR_CHx_RE-<br>QSEL_TGL | RW | Channel Peripheral Request Select Reg | # 26.9 LDMAXBAR Register Description # 26.9.1 LDMAXBAR\_CHx\_REQSEL - Channel Peripheral Request Select Reg... | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|--------|----------| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | | | | | | | | | ç | e<br>N | | | | • | | | | | | • | • | • | | • | | ć | OXO | <u> </u> | | Access | | | | | | | | | | | | | Ž | ≥<br>Y | | | | | | | | | | | | | | | | Ž | }<br>Ľ | | | Name | | | | | | | | | | | | | | SOURCESEL | | | | | | | | | | | | | | | | Ü | SIGSEL | | | Bit | Name | Reset | Access | Description | |-------|------------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31:22 | Reserved | To ensure ventions | e compatibility v | with future devices, always write bits to 0. More information in 1.2 Con- | | 21:16 | SOURCESEL | 0x0 | RW | Source Select | | | Select input source to | DMA channel | | | | 15:4 | Reserved | To ensure ventions | compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 3:0 | SIGSEL | 0x0 | RW | Signal Select | | | Select input signal to | DMA channel. | | | ### 27. 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. #### 27.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. #### 27.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 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 ### 27.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. When the EN bit in WDOGn\_EN cleared to 0, the watchdog counter is reset. #### 27.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 HFCLKDIV1024. #### 27.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. ### 27.3.3 Energy Mode Handling The watchdog timer can be configured to either keep on running or freeze when entering EM2 DeepSleep or EM3 Stop. The configuration is done individually for each energy mode in the 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. For the watchdog there is no difference between EM0 Active and EM1 Sleep. 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. #### 27.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. ### 27.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 27.2 WDOG Warning, Window, and Timeout on page 979 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 27.2. WDOG Warning, Window, and Timeout ### 27.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 27.2 PRS Clearing WDOG on page 980 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 27.2. PRS Clearing WDOG ### 27.3.7 PRS Rising Edge Monitoring PRS channels can be used to monitor multiple processes. The first and second channel are selected by PRS\_CONSUM-ER\_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 27.3. PRS Edge Monitoring in WDOG # 27.4 WDOG Register Map The offset register address is relative to the registers base address. | Offset | Name | Туре | 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 | Туре | Description | |--------|-------------------|------|-------------------------------| | 0x3024 | WDOG_SYNCBUSY_TGL | RH | Synchronization Busy Register | # 27.5 WDOG Register Description # 27.5.1 WDOG\_IPVERSION - IP Version Register | Offset | | | | | | | | | | | | | | | Bi | t Po | sitio | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-------|----|----|----|---|----|---|--------------|---|---|---|---|---|---|---|---| | 0x000 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | <sub>∞</sub> | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | • | • | • | | | | | | | • | | • | | > | 3 | | | | • | | • | • | • | | | • | | | | | | Access | | | | | | | | | | | | | | | | Ω | | | | | | | | | | | | | | | | | | Name | | | | | | | | | | | | | | | | IDVEDVION | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|-------------------------------------------------------|-------|--------|---------------------------------------------------------------| | 31:0 | IPVERSION | 0x0 | R | IP Version | | | The read only IPVERSIOn modules with different values | 0 | | this module. There may be minor software changes required for | # 27.5.2 WDOG\_EN - Enable Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|-----| | 0x004 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0×0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | EN | | Bit | Name | Reset | Access | Description | |------|----------|-------------|--------------------|--------------------------------------------------------------------------------------------| | 31:1 | Reserved | To ensure o | compatibility witi | h future devices, always write bits to 0. More information in 1.2 Con- | | 0 | EN | 0x0 | RW | Module Enable | | | | | | d write to CONFIG type registers before setting the ENABLE bit. er setting the ENABLE bit. | # 27.5.3 WDOG\_CFG - Configuration Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|--------|----|----|----|----|----------|----|----|----|----|----|----|----------|------|------|----|----|----|---|---------------|---------------|------------|---|---|---|----------|----------|--------|--------|--------| | 0x008 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | 6 | ω | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | 0×0 | | | | 2 | OX<br>O | | | ' | | | 2 | L<br>S | | | ' | | ' | | 0×0 | 0x0 | 0×0 | | | • | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | | Access | | | N<br>N | | | | 2 | }<br>Y | | | | | | 2 | <u>}</u> | | | | | | | ₩<br>M | Z. | Z. | | | | ₩<br>M | %<br>M | %<br>M | RW | A<br>M | | Name | | | WINSEL | | | | | WARINGEL | | | | | | | 7ERSEL | | | | | | | PRS1MISSRSTEN | PRSOMISSRSTEN | WDOGRSTDIS | | | | DEBUGRUN | EM4BLOCK | EM3RUN | EM2RUN | CLRSRC | | Bit | Name | Reset | Access | Description | |-------|---------------------|--------------------|-------------------|---------------------------------------------------------------------------| | 31 | Reserved | To ensure ventions | e compatibility v | vith future devices, always write bits to 0. More information in 1.2 Con- | | 30:28 | WINSEL | 0x0 | RW | WDOG Illegal Window Select | | | 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 | To ensure | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 25:24 | WARNSEL | 0x0 | RW | WDOG Warning Period Select | | | Select WDOG warning | g timeout perio | od. | | | | 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 | To ensure ventions | e compatibility w | vith future devices, always write bits to 0. More information in 1.2 Con- | | 19:16 | PERSEL | 0xF | RW | WDOG Timeout Period Select | | | Select WDOG timeou | it 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 | To ensure o | compatibility with | future devices, always write bits to 0. More information in 1.2 Con- | | 10 | PRS1MISSRSTEN | 0x0 | RW | PRS Src1 Missing Event WDOG Reset | | | When set, a PRS Source | e 1 missing ev | vent will trigger a | WDOG reset. | | 9 | PRS0MISSRSTEN | 0x0 | RW | PRS Src0 Missing Event WDOG Reset | | | When set, a PRS Source | e 0 missing ev | vent will trigger a | WDOG reset. | | 8 | WDOGRSTDIS | 0x0 | RW | WDOG Reset Disable | | | Disable WDOG reset ou | tput. | | | | | Value | Mode | | Description | | | 0 | EN | | A timeout will cause a WDOG reset | | | 1 | DIS | | A timeout will not cause a WDOG reset | | | | | | | | 7:5 | Reserved | To ensure o | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con- | | 7:5 | Reserved DEBUGRUN | | compatibility with | n future devices, always write bits to 0. More information in 1.2 Con-<br>Debug Mode Run | | | | ventions<br>0x0 | RW | | | | DEBUGRUN | ventions<br>0x0 | RW | | | | DEBUGRUN Set to keep WDOG runn | ventions 0x0 ning in debug | RW | Debug Mode Run | | | DEBUGRUN Set to keep WDOG runn Value | ventions 0x0 ning in debug Mode | RW | Debug Mode Run Description | | | | , | | | |-----|--------------------|---------------------|--------|-------------------------------------------------------------------| | Bit | Name | Reset | Access | Description | | | Set to disallow EM | M4 entry by softwar | e. | | | | Value | Mode | | Description | | | 0 | DISABLE | | EM4 can be entered by software. See EMU for detailed description. | | | 1 | ENABLE | | EM4 cannot be entered by software. | | 2 | EM3RUN | 0x0 | RW | EM3 Run | | | Set to keep WDO | G running in EM3. | | | | | Value | Mode | | Description | | | 0 | DISABLE | | WDOG timer is frozen in EM3. | | | 1 | ENABLE | | WDOG timer is running in EM3. | | 1 | EM2RUN | 0x0 | RW | EM2 Run | | | Set to keep WDO | G running in EM2. | | | | | Value | Mode | | Description | | | 0 | DISABLE | | WDOG timer is frozen in EM2. | | | 1 | ENABLE | | WDOG timer is running in EM2. | | 0 | CLRSRC | 0x0 | RW | WDOG Clear Source | | | Select WDOG cle | ar source. | | | | | Value | Mode | | Description | | | 0 | SW | | A write to the clear bit will clear the WDOG counter | | | 1 | PRSSRCO | ) | A rising edge on the PRS Source 0 will clear the WDOG counter | | | | | | | # 27.5.4 WDOG\_CMD - Command Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|---|---|---|---|-------| | 0x00C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 7 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | | | • | | • | | | • | | | | • | | • | • | | • | | | | | | • | | • | • | | | | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | > | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CLEAR | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|------------------|-------------------------------------------------------------------------| | 31:1 | Reserved | To ensure ventions | compatibility wi | th future devices, always write bits to 0. More information in 1.2 Con- | | 0 | CLEAR | 0x0 | W | WDOG Timer Clear | | | Clear WDOG timer. Th | ne bit must be | written 4 WDOG | cycles before the timeout. | | | Value | Mode | | Description | | | 0 | UNCHANG | GED | WDOG timer is unchanged. | | | 1 | CLEARED | ) | WDOG timer is cleared to 0. | | | | | | | # 27.5.5 WDOG\_STATUS - Status Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|--------| | 0x014 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | 3 | 2 | - ( | _<br>o | | Reset | 0x0 | | • | • | | • | • | | | | | | | • | | • | | • | | | | | | | | | • | | | | · | | | Access | œ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Name | LOCK | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|---------------|---------------------------------------------------------------------------| | 31 | LOCK | 0x0 | R | WDOG Configuration Lock Status | | | Status of all lockal | ole WDOG registers | S. | | | | Value | Mode | | Description | | | 0 | UNLOCKE | D | All WDOG lockable registers are unlocked. | | | 1 | LOCKED | | All WDOG lockable registers are locked. | | 30:0 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | # 27.5.6 WDOG\_IF - Interrupt Flag Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|---|----|---|---|---|---|---|------|---------|-----|---------|------| | 0x018 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | စ | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | | • | | • | | • | | | | • | | | | • | • | | • | | | | • | | | • | | • | 0X0 | 0x0 | 0×0 | 0X0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | W. | ZW<br>W | RW | ZW<br>W | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | PEM1 | PEM0 | NIM | WARN | TOUT | | Bit | Name | Reset | Access | Description | |------|----------------------|--------------------|-------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure ventions | compatibility wit | h future devices, always write bits to 0. More information in 1.2 Con- | | 4 | PEM1 | 0x0 | RW | PRS Src1 Event Missing Interrupt Flag | | | Set when a WDOG clea | r happens be | fore a prs event | has been detected on PRS Source one. | | 3 | PEM0 | 0x0 | RW | PRS Src0 Event Missing Interrupt Flag | | | Set when a WDOG clea | r happens be | fore a prs event | has been detected on PRS Source zero. | | 2 | WIN | 0x0 | RW | WDOG Window Interrupt Flag | | | Set when a WDOG clea | r happens be | low the window | limit value. | | 1 | WARN | 0x0 | RW | WDOG Warning Timeout Interrupt Flag | | | Set when a WDOG war | ning timeout h | as occurred. | | | 0 | TOUT | 0x0 | RW | WDOG Timeout Interrupt Flag | | | Set when a WDOG time | out has occur | rred. | | # 27.5.7 WDOG\_IEN - Interrupt Enable Register | Offset | | | | | | | | | | | | | | | Ві | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|----|----|---|---|---|---|---|------|------|-----|------|------| | 0x01C | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 11 | 10 | 6 | 8 | 7 | 9 | 5 | 4 | က | 2 | _ | 0 | | Reset | | • | | • | | | | • | | • | | • | • | | • | • | | • | • | • | • | - | | | • | | • | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | | Access | | | | | | | | | | | | | | | | | | | | | | | | | | | | RW | W. | ₩. | W. | RW | | Name | | | | | | | | | | | | | | | | | | | | | | | | | | | | PEM1 | PEM0 | NIM | WARN | TOUT | | Bit | Name | Reset | Access | Description | |------|------------------------|--------------|--------------------|------------------------------------------------------------------------| | 31:5 | Reserved | To ensure o | compatibility witl | n future devices, always write bits to 0. More information in 1.2 Con- | | 4 | PEM1 | 0x0 | RW | PRS Src1 Event Missing Interrupt Enable | | | Enable/disable the PEM | 1 interrupt. | | | | 3 | PEM0 | 0x0 | RW | PRS Src0 Event Missing Interrupt Enable | | | Enable/disable the PEM | 0 interrupt. | | | | 2 | WIN | 0x0 | RW | WDOG Window Interrupt Enable | | | Enable/disable the WIN | interrupt. | | | | 1 | WARN | 0x0 | RW | WDOG Warning Timeout Interrupt Enable | | | Enable/disable the WAR | N interrupt. | | | | 0 | TOUT | 0x0 | RW | WDOG Timeout Interrupt Enable | | | Enable/disable the TOU | T interrupt. | | | # 27.5.8 WDOG\_LOCK - Lock Register | Offset | | | | | | | | | | | | | | | Bi | t Po | siti | on | | | | | | | | | | | | | | | |--------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|------|------|----|----|----|---|----|---|------|--------|---|---|---|---|---|---|---| | 0x020 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 9 | 17 | 16 | 15 | 4 | 13 | 12 | 7 | 10 | တ | 8 | 7 | 9 | 2 | 4 | က | 2 | _ | 0 | | Reset | | | 1 | ı | | · | | · | | 1 | • | | | • | | | | | ı | | • | | 1 | 0470 | | | | | 1 | | | | | Access | | | | | | | | | | | | | | | | | | | | | | | | } | > | | | | | | | | | Name | | | | | | | | | | | | | | | | | | | | | | | | | LOCANE | | | | | | | | | Bit | Name | Reset | Access | Description | |-------|---------------------|---------------------|---------------|---------------------------------------------------------------------------| | 31:16 | Reserved | To ensure ventions | compatibility | with future devices, always write bits to 0. More information in 1.2 Con- | | 15:0 | LOCKKEY | 0xABE8 | W | WDOG Configuration Lock | | | Write any other val | lue than the unlock | code to lock | WDOG_EN, WDOD_CFG registers from editing. Write the unlock | | | Value | Mode | | Description | | | _ | | | | | | 0 | LOCK | | Lock WDOG lockable registers | # 27.5.9 WDOG\_SYNCBUSY - Synchronization Busy Register | Offset | Bit Position | | | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----| | 0x024 | 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 <th>e 2 t</th> <th>0</th> | e 2 t | 0 | | Reset | | | 0x0 | | Access | | | ~ | | Name | | | CMD | | Bit | Name | Reset | Access | Description | |------|-------------------------|--------------------|-----------------|---------------------------------------------------------------------------| | 31:1 | Reserved | To ensure ventions | compatibility w | with future devices, always write bits to 0. More information in 1.2 Con- | | 0 | CMD | 0x0 | R | Sync Busy for Cmd Register | | | CMD bitfield sync is bu | sy when set. | | | ### 28. Revision History #### Revision 1.0 August, 2020 - · Added register interface name to register chapter titles throughout document for better navigation. - HFXO: added mention of clipped sine wave support. - 3. System Processor: Corrected cycles for divide instruction. - 6. MSC Memory System Controller: Removed mention of "devices supporting read-while-write" from MSC\_WRITECMD\_ERASE-MAINO. - 8.3.1.5 RHCLK AHB Radio Clock: Changed text to clarify that this refers to the Radio AHB clock instead of the radio transicever clock fed directly by the crystal. - Removed references to ACMP peripheral from EMU, EUART, and USART chapters. ACMP is not available on this device family. - 10. SMU Security Management Unit: Corrected register bit definitions: Added TIMER4 to PPUPATD0, PPUSATD0, and removed BUFC from PPUPATD1, PPUSATD1, BMPUPATD0, BMPUSATD0. Remaining bits moved to correct locations. - 19. TIMER Timer/Counter: Corrected equations for frequency calculations, to properly include prescaler. - 21. USART Universal Synchronous Asynchronous Receiver/Transmitter: Removed IRPRSEN bit from USART\_IRCTRL register. Function does not exist in this device family. - 25. GPIO General Purpose Input/Output: Removed mention of THMSW\_HALFSWITCH from Fixed Pin Function Table. - 25. GPIO General Purpose Input/Output: Removed registers and bit enumerations with no customer usage from descriptions. - 25. GPIO General Purpose Input/Output: Corrected register names for TIMERx CDTI0/1/2 signal routing. #### Revision 0.5 March, 2020 - 3. System Processor: Corrected Cortex-M33 revision number. - · 4.2.3 SRAM: Added note about root code usage of RAM during a system reset. - 4.2.1.2 Bus Faults: Removed sentence stating that the radio subsystem is the only peripheral which can generate a bus fault with clock disabled. - 6. MSC Memory System Controller: Corrected size of User Data space. - Updated register descriptions for formatting conventions, typos, and clarity, and added missing register details throughout document. - 8.3.3 RC Oscillator Calibration: Added names of relevant PRS consumer outputs. - 11. CRYPTOACC Cryptographic Accelerator: Removed mention of P-224 (unsupported), added HW\_CFG registers. - Added section: 12.3.1.3 EM1P. - Updated information about debugging through EM2 and EM3 using the EM2DBGEN bit in the EMU2/3 and debugging sections. - 12.3.7 Power Configurations: Updated with latest power configuration details. - · Added section: 12.3.9 EFP Communication. - Updated 12.3.12 Temperature Sensor and added section 12.3.12.1 Linearization, Offset Correction, and Calibration. - 20. PDM PDM Interface: Fixed sections referring to more than 2 channels. - 21.3.2.17 Single Data-link with External Driver: Added note about CSSETUP usage in asynchronous mode with AUTOCS. - 22. EUART Enhanced Universal Asynchronous Receiver/Transmitter: Removed LIN reference from Auto Baud Detection paragraph. - 24.3.5.2 Internal and Dedicated Inputs: Corrected DECOUPLE voltage at positive input. - Added section: 24.3.7.2 Output Polarity. - Added section: 24.3.7.4 Output Resolution. - Removed erroneous PADREFPOS and PADREFNEG options from IADC SINGLE and SCAN input selection registers. #### Revision 0.1 July, 2019 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 | | АНВ | 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 | | ВТ | 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 | | 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 | | 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 | | PHY | Physical Layer | | PROTIMER | Protocol Timer | | Abbreviation | Description | |--------------|------------------------------------| | 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 | **Quality** www.silabs.com/quality Support & Community 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 #### Trademark Information Silicon Laboratories Inc.®, Silicon Laboratories®, Silicon Labs®, SiLabs® and the Silicon Labs logo®, Bluegiga®, Bluegiga Logo®, ClockBuilder®, CMEMS®, DSPLL®, EFM®, EFM32®, EFR, Ember®, Energy Micro, Energy Micro logo and combinations thereof, "the world's most energy friendly microcontrollers", Ember®, EZLink®, EZRadio®, EZRadio®, EZRadioPRO®, Gecko®, Gecko OS, Gecko OS Studio, ISOmodem®, Precision32®, ProSLIC®, Simplicity Studio®, SiPHY®, Telegesis, the Telegesis Logo®, USBXpress®, Zentri, the Zentri logo and Zentri DMS, Z-Wave®, 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.