# nRF52805 **Objective Product Specification** v0.5 # Feature list #### Features: - Bluetooth® 5.0 2.4 GHz transceiver - -95 dBm sensitivity in 1 Mbps *Bluetooth* Blow energy mode - -20 to +4 dBm TX power, configurable in 4 dB steps - On-air compatible with nRF52, nRF51, nRF24L, and nRF24AP Series - Supported data rates: - Bluetooth 5.0: 2 Mbps, 1 Mbps - Proprietary 2.4 GHz: 2 Mbps, 1 Mbps - Single-ended antenna output (on-chip balun) - 4.6 mA peak current in TX (0 dBm) - 4.6 mA peak current in RX - RSSI (1 dB resolution) - ARM Cortex -M4 32-bit processor, 64 MHz - 144 EEMBC CoreMark® score running from flash memory - 34.4 µA/MHz running CoreMark from flash memory - 32.8 μA/MHz running CoreMark from RAM memory - Serial wire debug (SWD) - Flexible power management - 1.7 V to 3.6 V supply voltage range - Fully automatic LDO and DC/DC regulator system - Fast wake-up using 64 MHz internal oscillator - 0.3 $\mu A$ at 3 V in System OFF mode, no RAM retention - 0.5 $\mu$ A at 3 V in System OFF mode with full 24 kB RAM retention - 1.5 $\mu A$ at 3 V in System ON mode, with full 24 kB RAM retention, wake on RTC - 1.4 $\mu A$ at 3 V in System ON mode, no RAM retention, wake on RTC - 192 kB flash and 24 kB RAM - Nordic SoftDevice ready - Temperature sensor - 12-bit, 200 ksps ADC 2 configurable channels with programmable gain - Up to 10 general purpose I/O pins - 3x 32-bit timer with counter mode - SPI master/slave with EasyDMA - I2C compatible 2-wire master/slave with EasyDMA - UART (CTS/RTS) with EasyDMA - Programmable peripheral interconnect (PPI) - AES HW encryption with EasyDMA - 2x real-time counter (RTC) - Single crystal operation - Package variants - WLCSP package, 2.482 x 2.464 mm ## Applications: - Basic proprietary protocol devices - Basic network processor - Beacons - Thermostats - Presenters/Stylus - Asset tags - Health and medical - Basic CE remote controls - Toys 4454\_187 v0.5 ii # Contents | | Feature list. | . ii | |---|------------------------------------------------------------------|----------| | 1 | Revision history. | 9 | | 2 | About this document. | 10 | | | 2.1 Document status | 10 | | | 2.2 Peripheral chapters | 10 | | | 2.3 Register tables | 10 | | | 2.3.1 Fields and values | 11 | | | 2.3.2 Permissions | | | | 2.4 Registers | 11 | | | 2.4.1 DUMMY | 11 | | | | | | 3 | Block diagram. | 13 | | 4 | Core components | 14 | | | 4.1 CPU | | | | | . 14 | | | 4.1.1 Electrical specification | 14 | | | 4.1.2 CPU and support module configuration | 14 | | | 4.2 Memory | 15 | | | 4.2.1 RAM - Random access memory | 16<br>16 | | | | 16 | | | 4.2.3 Memory map | 17 | | | 4.2.4 Instantiation | 18 | | | | 18 | | | 4.3.1 Writing to flash | 18 | | | 4.3.3 Writing to user information configuration registers (UICR) | 19 | | | 4.3.4 Erasing user information configuration registers (UICR) | | | | 4.3.5 Erase all | 19 | | | 4.3.6 Partial erase of a page in flash | | | | 4.3.7 Registers | | | | 4.3.8 Electrical specification | 23 | | | 4.4 FICR — Factory information configuration registers | 23 | | | 4.4.1 Registers | | | | 4.5 UICR — User information configuration registers | 31 | | | 4.5.1 Registers | 31 | | | 4.6 EasyDMA | 34 | | | 4.6.1 EasyDMA error handling | 35 | | | 4.6.2 EasyDMA array list | | | | 4.7 AHB multilayer | 36 | | | 4.8 Debug | | | | 4.8.1 DAP - Debug access port | 38 | | | 4.8.2 CTRL-AP - Control access port | 38 | | | 4.8.3 Debug interface mode | 40 | | | 4.8.4 Real-time debug | 40 | | | | | | 5 | Power and clock management. | 41 | | | 5.1 Power management unit (PMU) | 41 | | | 5.2 Current consumption | 41 | |---|----------------------------------------------------------------------------------------------|------| | | 5.2.1 Electrical specification | . 42 | | | 5.3 POWER — Power supply | . 46 | | | 5.3.1 Regulators | | | | 5.3.2 System OFF mode | . 48 | | | 5.3.3 System ON mode | . 49 | | | 5.3.4 Power supply supervisor | . 49 | | | 5.3.5 RAM power control | | | | 5.3.6 Reset | | | | 5.3.7 Retained registers | | | | 5.3.8 Reset behavior | | | | 5.3.9 Registers | | | | 5.3.10 Electrical specification | . 59 | | | 5.4 CLOCK — Clock control | | | | 5.4.1 HFCLK clock controller | . 61 | | | 5.4.2 LFCLK clock controller | . 62 | | | 5.4.3 Registers | . 65 | | | 5.4.4 Electrical specification | . 71 | | | 5.4.4 Electrical specification | . /1 | | _ | De vivele e ve le | 72 | | 5 | Peripherals | . 73 | | | 6.1 Peripheral interface | . 73 | | | 6.1.1 Peripheral ID | . 73 | | | 6.1.2 Peripherals with shared ID | 74 | | | 6.1.3 Peripheral registers | 74 | | | 6.1.4 Bit set and clear | . 74 | | | 6.1.5 Tasks | 74 | | | 6.1.6 Events | . 74 | | | 6.1.7 Shortcuts | . 75 | | | 6.1.8 Interrupts | 75 | | | 6.2 AAR — Accelerated address resolver | . 76 | | | 6.2.1 EasyDMA | . 76 | | | 6.2,2 Resolving a resolvable address | | | | 6.2.3 Use case example for chaining RADIO packet reception with address resolution using AAR | . 77 | | | 6.2.4 IRK data structure | | | | 6.2.5 Registers | . 77 | | | 6.2.6 Electrical specification | . 81 | | | 6.3 BPROT — Block protection | . 81 | | | 6.3.1 Registers | | | | 6.4 CCM — AES CCM mode encryption | | | | 6.4.1 Key-steam generation | | | | 6.4.2 Encryption | | | | 6.4.3 Decryption | | | | 6.4.4 AES CCM and RADIO concurrent operation | | | | 6.4.5 Encrypting packets on-the-fly in radio transmit mode | | | | 6.4.6 Decrypting packets on-the-fly in radio receive mode | | | | 6.4.7 CCM data structure | | | | 6.4.8 EasyDMA and ERROR event | | | | 6.4.9 Registers | | | | 6.4.10 Electrical specification | | | | · | | | | 6.5 ECB — AES electronic codebook mode encryption | | | | 6.5.1 Shared resources | | | | 6.5.2 EasyDMA | | | | 6.5.3 ECB data structure | | | | 6.5.4 Registers | . 9/ | 4454\_187 v0.5 iv | 6.5.5 Electrical specification | 99 | |-----------------------------------------------------|-------| | 6.6 EGU — Event generator unit | 100 | | | 100 | | | 102 | | | 102 | | | 103 | | | 105 | | | 109 | | | 110 | | | 110 | | | 111 | | | 111 | | · | 111 | | 6.8.E. Flootrical appointant | 116 | | | 116 | | | | | i g | 117 | | | 118 | | | 122 | | | 123 | | ů . | 124 | | | 124 | | | 125 | | | 125 | | | 126 | | | 127 | | | 129 | | | 129 | | | 130 | | 6.10.11 Bit counter | 130 | | | 131 | | 6.10.13 Registers | 132 | | 6.10.14 Electrical specification | 153 | | 6.11 RNG — Random number generator | 158 | | 6.11.1 Bias correction | 159 | | 6.11.2 Speed | 159 | | 6.11.3 Registers | 159 | | 6.11.3 Registers | 161 | | | 162 | | | 162 | | 6.12.2 Resolution versus overflow and the PRESCALER | 162 | | 6.12.3 COUNTER register | 163 | | | 163 | | | 164 | | | 164 | | | 164 | | | 166 | | , , , | 168 | | | 169 | | | 174 | | · | 174 | | | 174 | | | 174 | | | 175 | | | 176 | | U.IJ.T AHAIUK HIPUKI AHU CHAHILEIS | T / O | 4454\_187 v0.5 V | | 6.13.5 Operation modes | 176 | |----|-----------------------------------------------------------------------------------------------------------------------------------------------|-----| | | 6.13.6 EasyDMA | 178 | | | 6.13.7 Resistor ladder | 179 | | | 6.13.8 Reference | 180 | | | 6.13.9 Acquisition time | 180 | | | 6.13.10 Limits event monitoring | 181 | | | 6.13.11 Registers | 182 | | | 6.13.12 Electrical specification | 196 | | | 6.13.13 Performance factors | 197 | | 6. | 14 SPI — Serial peripheral interface master | 197 | | | 6.14.1 Functional description | 198 | | | 6.14.2 Registers | 201 | | | 6.14.3 Electrical specification | 204 | | 6 | 15 SPIM — Serial peripheral interface master with EasyDMA | 205 | | Ο. | 6.15.1 SPI master transaction sequence | 206 | | | 6.15.2 Master mode pin configuration | 207 | | | 6.15.3 EasyDMA | | | | 6.15.4 Low power | 208 | | | 6.15.5 Registers | 208 | | | | 208 | | _ | 6.15.6 Electrical specification | 217 | | о. | | | | | 6.16.1 Shared resources | 219 | | | 6.16.2 EasyDMA | 219 | | | 6.16.3 SPI slave operation | 219 | | | 6.16.4 Pin configuration | 221 | | | 6.16.5 Registers | 222 | | _ | 6.16.6 Electrical specification | 233 | | 6. | 17 SWI — Software interrupts | 235 | | | 6.17.1 Registers | 235 | | 6. | 18 TEMP — Temperature sensor | 235 | | | 6.18.1 Registers | 235 | | | 6.18.2 Electrical specification | 241 | | 6. | 19 TWI — $I^2$ C compatible two-wire interface | 242 | | | 6.19.1 Functional description | 242 | | | 6.19.2 Master mode pin configuration | 242 | | | 6.19.3 Shared resources | 243 | | | 6.19.4 Master write sequence | 243 | | | 6.19.5 Master read sequence | 244 | | | 6.19.6 Master repeated start sequence | 245 | | | 6.19.7 Low power | 246 | | | 6.19.8 Registers | 246 | | | 6.19.9 Electrical specification | 253 | | 6. | 20 TIMER — Timer/counter | 254 | | | 6.20.1 Capture | 256 | | | 6.20.2 Compare | 256 | | | 6.20.3 Task delays | 256 | | | 6.20.4 Task priority | 256 | | | 6.20.5 Registers | 256 | | 6. | 21 TWIM $\stackrel{\circ}{-}$ I <sup>2</sup> C compatible two-wire interface master with EasyDMA $\ldots$ $\ldots$ $\ldots$ $\ldots$ $\ldots$ | 261 | | | 6.21.1 EasyDMA | 262 | | | 6.21.2 Master write sequence | 263 | | | 6.21.3 Master read sequence | 264 | | | 6.21.4 Master repeated start sequence | 265 | | | 6.21.5 Low power | 266 | | | | | | 6.21.6 Master mode pin configuration | 266 | |-----------------------------------------------------------------------|-------| | 6.21.7 Registers | | | 6.21.8 Electrical specification | 277 | | 6.21.9 Pullup resistor | | | 6.22 TWIS — $I^2C$ compatible two-wire interface slave with EasyDMA | | | 6.22.1 EasyDMA | | | 6.22.2 TWI slave responding to a read command | | | 6.22.3 TWI slave responding to a write command | | | 6.22.4 Master repeated start sequence | 283 | | 6.22.5 Terminating an ongoing TWI transaction | . 284 | | 6.22.6 Low power | 284 | | 6.22.7 Slave mode pin configuration | 284 | | 6.22.8 Registers | 285 | | 6.22.9 Electrical specification | 295 | | 6.23 UART — Universal asynchronous receiver/transmitter | 295 | | 6.23.1 Functional description | 296 | | 6.23.2 Pin configuration | 296 | | 6.23.3 Shared resources | 296 | | 6.23.4 Transmission | 296 | | 6.23.5 Reception | 297 | | 6.23.6 Suspending the UART | 298 | | 6.23.7 Error conditions | 298 | | 6.23.8 Using the UART without flow control | 298 | | 6.23.9 Parity and stop bit configuration | 298 | | 6.23.10 Registers | 298 | | 6.23.11 Electrical specification | . 307 | | 6.24 UARTE — Universal asynchronous receiver/transmitter with EasyDMA | | | 6.24.1 EasyDMA | . 308 | | 6.24.2 Transmission | 308 | | 6.24.3 Reception | 309 | | 6.24.4 Error conditions | 311 | | 6.24.5 Using the UARTE without flow control | | | 6.24.6 Parity and stop bit configuration | 311 | | 6.24.7 Low power | | | 6.24.8 Pin configuration | 312 | | 6.24.9 Registers | 312 | | 6.24.10 Electrical specification | . 325 | | 6.25 WDT — Watchdog timer | 325 | | 6.25.1 Reload criteria | 326 | | 6.25.2 Temporarily pausing the watchdog | 326 | | 6.25.3 Watchdog reset | 326 | | 6.25.4 Registers | 326 | | 6.25.5 Electrical specification | 330 | | | | | Hardware and layout. | 331 | | 7.1 Pin assignments | 331 | | 7.1.1 WLCSP ball assignments | 331 | | 7.2 Mechanical specifications | 332 | | 7.2.1 WLCSP 2.482 x 2.464 mm package | 333 | | 7.3 Reference circuitry | 333 | | | | | Recommended operating conditions. | 334 | | 8.1 WLCSP light sensitivity | 334 | | out weed, home sensitivity. | 227 | 4454\_187 v0.5 vii | 9 | Absolute maximum ratings. | 335 | |----|--------------------------------|-----| | 10 | Ordering information. | 336 | | | 10.1 IC marking | 336 | | | 10.2 Box labels | 336 | | | 10.3 Order code | 337 | | | 10.4 Code ranges and values | 338 | | | 10.5 Product options | 339 | | 11 | Legal notices. | 341 | | | 11.1 Liability disclaimer | 341 | | | 11.2 Life support applications | 341 | | | 11.3 RoHS and REACH statement | 341 | | | 11.4 Trademarks | 341 | | | 11.5 Copyright notice | 342 | | | | | 4454\_187 v0.5 viii # 1 Revision history | Date | Version | Description | |-----------|---------|---------------------| | June 2019 | 0.5 | Preliminary release | # 2 About this document This document is organized into chapters that are based on the modules and peripherals available in the IC # 2.1 Document status The document status reflects the level of maturity of the document. | Document name | Description | |---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Objective Product Specification (OPS) | Applies to document versions up to 1.0. This document contains target specifications for product development. | | Product Specification (PS) | Applies to document versions 1.0 and higher. This document contains final product specifications. Nordic Semiconductor ASA reserves the right to make changes at any time without notice in order to improve design and supply the best possible product. | Table 1: Defined document names # 2.2 Peripheral chapters Every peripheral has a unique capitalized name or an abbreviation of its name, e.g. TIMER, used for identification and reference. This name is used in chapter headings and references, and it will appear in the ARM® Cortex® Microcontroller Software Interface Standard (CMSIS) hardware abstraction layer to identify the peripheral. The peripheral instance name, which is different from the peripheral name, is constructed using the peripheral name followed by a numbered postfix, starting with 0, for example, TIMERO. A postfix is normally only used if a peripheral can be instantiated more than once. The peripheral instance name is also used in the CMSIS to identify the peripheral instance. The chapters describing peripherals may include the following information: - A detailed functional description of the peripheral - Register configuration for the peripheral - Electrical specification tables, containing performance data which apply for the operating conditions described in Recommended operating conditions on page 334. # 2.3 Register tables Individual registers are described using register tables. These tables are built up of two sections. The first three colored rows describe the position and size of the different fields in the register. The following rows describe the fields in more detail. ## 2.3.1 Fields and values The **Id** (Field Id) row specifies the bits that belong to the different fields in the register. If a field has enumerated values, then every value will be identified with a unique value id in the **Value Id** column. A blank space means that the field is reserved and read as undefined, and it also must be written as 0 to secure forward compatibility. If a register is divided into more than one field, a unique field name is specified for each field in the **Field** column. The **Value Id** may be omitted in the single-bit bit fields when values can be substituted with a Boolean type enumerator range, e.g. true/false, disable(d)/enable(d), on/off, and so on. Values are usually provided as decimal or hexadecimal. Hexadecimal values have a 0x prefix, decimal values have no prefix. The Value column can be populated in the following ways: - Individual enumerated values, for example 1, 3, 9. - Range of values, e.g. [0..4], indicating all values from and including 0 and 4. - Implicit values. If no values are indicated in the **Value** column, all bit combinations are supported, or alternatively the field's translation and limitations are described in the text instead. If two or more fields are closely related, the **Value Id**, **Value**, and **Description** may be omitted for all but the first field. Subsequent fields will indicate inheritance with '..'. A feature marked **Deprecated** should not be used for new designs. ### 2.3.2 Permissions Different fields in a register might have different access permissions enforced by hardware. The access permission for each register field is documented in the Access column in the following ways: | Access | Description | Hardware behavior | |--------|-----------------|------------------------------------------------------------------------------------------------------------------------| | RO | Read-only | Field can only be read. A write will be ignored. | | wo | Write-only | Field can only be written. A read will return an undefined value. | | RW | Read-write | Field can be read and written multiple times. | | W1 | Write-once | Field can only be written once per reset. Any subsequent write will be ignored. A read will return an undefined value. | | RW1 | Read-write-once | Field can be read multiple times, but only written once per reset. Any subsequent write will be ignored. | Table 2: Register field permission schemes # 2.4 Registers | Register | Offset | Description | |----------|--------|---------------------------------------------------| | DUMMY | 0x514 | Example of a register controlling a dummy feature | Table 3: Register overview ### 2.4.1 DUMMY Address offset: 0x514 Example of a register controlling a dummy feature | Bit r | umber | | 31 | 30 2 | 9 28 | 27 | 26 2 | 25 2 | 4 23 | 22 | 21 2 | 20 1 | 9 1 | 8 1 | 7 16 | 15 | 14 | 13 | 12 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | . 0 | |------------|---------------|--------------|---------------------------------------------------|------|------|----|------|------|------|---------------------------------|-----------------------------------------------|------|------|------|-------|-------|------|------|-------|------|-------|------|------|------|----|---|-----|------|------| | ID | | | | | | D | D | D C | | | | | ( | 2 ( | : c | | | | | | | В | | | | | | А | A | | Res | et 0x00050002 | | 0 | 0 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 ( | 0 1 | L C | ) 1 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | ) 1 | . 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW FIELD_A | | | | | | | | Exa | amp | ole o | of a | rea | d-v | vrite | e fie | ld v | vith | sev | eral | eni | ıme | erat | ed | | | | | | | | | | | | | | | | val | lues | | | | | | | | | | | | | | | | | | | | | | | Disabled | 0 | | | | | | | The example feature is disabled | | | | | | | | | | | | | | | | | | | | | NormalMode | | | | 1 | | | | | | | The example feature is enabled in normal mode | | | | | | | | | | | | | | | | | | | | | | ExtendedMode | 2 The example feature is enabled along with extra | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | fur | nctio | onal | lity | | | | | | | | | | | | | | | | | | | В | RW FIELD_B | | | | | | | | Exa | amp | ole o | of a | dep | ore | cate | d re | ad | wri | te fi | eld | | | | | | | Dep | reca | ated | | | | Disabled | 0 | | | | | | Th | ne ov | /erri | ide | fea | ture | e is | disa | ble | d | | | | | | | | | | | | | | | Enabled | 1 | | | | | | Th | ne ov | /erri | ide | fea | ture | e is | ena | ble | d | | | | | | | | | | | | | С | RW FIELD_C | | | | | | | | Exa | amp | ole o | of a | reá | d-v | vrite | e fie | ld v | vith | a v | alid | ran | ge c | f v | alue | es | | | | | | | | ValidRange | [2. | .7] | | | | | Exa | amp | ole o | of a | llow | /ed | val | ues | for | this | fiel | d | | | | | | | | | | | D | RW FIELD_D | | | | | | | | | amp | | of a | rea | d-v | vrite | fie | ld v | vith | no | rest | ricti | on | on | the | | | | | | # 3 Block diagram This block diagram illustrates the overall system. Arrows with white heads indicate signals that share physical pins with other signals. Figure 1: Block diagram # 4 Core components # 4.1 CPU The ARM<sup>®</sup> Cortex<sup>®</sup>-M4 processor has a 32-bit instruction set (Thumb<sup>®</sup>-2 technology) that implements a superset of 16- and 32-bit instructions to maximize code density and performance. This processor implements several features that enable energy-efficient arithmetic and high-performance signal processing including: - Digital signal processing (DSP) instructions - Single-cycle multiply and accumulate (MAC) instructions - Hardware divide - 8 and 16-bit single instruction multiple data (SIMD) instructions The ARM Cortex Microcontroller Software Interface Standard (CMSIS) hardware abstraction layer for the ARM Cortex processor series is implemented and available for the M4 CPU. Real-time execution is highly deterministic in thread mode, to and from sleep modes, and when handling events at configurable priority levels via the nested vectored interrupt controller (NVIC). Executing code from flash will have a wait state penalty on the nRF52 Series. The section Electrical specification on page 14 shows CPU performance parameters including wait states in different modes, CPU current and efficiency, and processing power and efficiency based on the CoreMark® benchmark. The ARM System Timer (SysTick) is present on the device. The SysTick's clock will only tick when the CPU is running or when the system is in debug interface mode. # 4.1.1 Electrical specification ## 4.1.1.1 CPU performance The CPU clock speed is 64 MHz. Current and efficiency data is taken when in System ON and the CPU is executing the CoreMark<sup>®</sup> benchmark. It includes power regulator and clock base currents. All other blocks are IDLE. | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|----------------------------------------------|------|------|------|-----------| | W <sub>FLASH</sub> | CPU wait states, running from flash | 0 | | 2 | | | $W_{RAM}$ | CPU wait states, running from RAM | | | 0 | | | $CM_{FLASH}$ | CoreMark <sup>1</sup> , running from flash | | 144 | | CoreMark | | CM <sub>FLASH/MHz</sub> | CoreMark per MHz, running from flash | | 2.25 | | Corel | | | | | | | MHz | | CM <sub>FLASH/mA</sub> | CoreMark per mA, running from flash, DCDC 3V | | 65 | | CoreMark/ | | | | | | | mΔ | # 4.1.2 CPU and support module configuration The ARM<sup>®</sup> Cortex<sup>®</sup>-M4 processor has a number of CPU options and support modules implemented on the device. Using IAR v6.50.1.4452 with flags --endian=little --cpu=Cortex-M4 -e --fpu=VFPv4\_sp -Ohs -no\_size\_constraints | Option / Module | Description | Implemented | |-----------------|------------------------------------|---------------| | Core options | | | | NVIC | Nested vector interrupt controller | 30 vectors | | PRIORITIES | Priority bits | 3 | | WIC | Wakeup interrupt controller | NO | | Endianness | Memory system endianness | Little endian | | Bit-banding | Bit banded memory | NO | | DWT | Data watchpoint and trace | NO | | SysTick | System tick timer | YES | | Modules | | | | MPU | Memory protection unit | YES | | FPU | Floating-point unit | NO | | DAP | Debug access port | YES | | ETM | Embedded trace macrocell | NO | | ITM | Instrumentation trace macrocell | NO | | TPIU | Trace port interface unit | NO | | ETB | Embedded trace buffer | NO | | FPB | Flash patch and breakpoint unit | YES | | нтм | AMBA® AHB trace macrocell | NO | # 4.2 Memory The nRF52805 contains flash and RAM that can be used for code and data storage. The amount of RAM and flash will vary depending on variant, see Memory variants on page 15. | Device name | RAM | Flash | Comments | |---------------|-------|--------|----------| | nRF52805-CAAA | 24 kB | 192 kB | | Table 4: Memory variants The CPU and peripherals with EasyDMA can access memory via the AHB multilayer interconnect. The CPU is also able to access peripherals via the AHB multilayer interconnect, as illustrated in Memory layout on page 16. Figure 2: Memory layout See AHB multilayer on page 36 and EasyDMA on page 34 for more information about the AHB multilayer interconnect and the EasyDMA. The same physical RAM is mapped to both the Data RAM region and the Code RAM region. It is up to the application to partition the RAM within these regions so that one does not corrupt the other. # 4.2.1 RAM - Random access memory The RAM interface is divided into multiple RAM AHB slaves. Each RAM AHB slave is connected to two 4-kilobyte RAM sections, see Section 0 and Section 1 in Memory layout on page 16. Each of the RAM sections have separate power control for System ON and System OFF mode operation, which is configured via RAM register (see the POWER — Power supply on page 46). # 4.2.2 Flash - Non-volatile memory The flash can be read an unlimited number of times by the CPU, but it has restrictions on the number of times it can be written and erased, and also on how it can be written. Writing to flash is managed by the non-volatile memory controller (NVMC), see NVMC — Non-volatile memory controller on page 18. The flash is divided into multiple 4 kB pages that can be accessed by the CPU via both the ICODE and DCODE buses as shown in, Memory layout on page 16. Each page is divided into 8 blocks. # 4.2.3 Memory map The complete memory map is shown in Memory map on page 17. As described in Memory on page 15, Code RAM and Data RAM are the same physical RAM. # 4.2.4 Instantiation | ID | Base address | Peripheral | Instance | Description | | |----|--------------|------------|----------|----------------------------------------------------------|------------| | 0 | 0x40000000 | BPROT | BPROT | Block protect | | | 0 | 0x40000000 | CLOCK | CLOCK | Clock control | | | 0 | 0x40000000 | POWER | POWER | Power control | | | 0 | 0x50000000 | GPIO | Р0 | General purpose input and output | | | 1 | 0x40001000 | RADIO | RADIO | 2.4 GHz radio | | | 2 | 0x40002000 | UART | UARTO | Universal asynchronous receiver/transmitter | Deprecated | | 2 | 0x40002000 | UARTE | UARTE0 | Universal asynchronous receiver/transmitter with EasyDMA | | | 3 | 0x40003000 | TWI | TWI0 | Two-wire interface master | Deprecated | | 3 | 0x40003000 | TWIM | TWIM0 | Two-wire interface master | | | 3 | 0x40003000 | TWIS | TWIS0 | Two-wire interface slave | | | 4 | 0x40004000 | SPI | SPI0 | SPI master | Deprecated | | 4 | 0x40004000 | SPIM | SPIM0 | SPI master | | | 4 | 0x40004000 | SPIS | SPIS0 | SPI slave | | | 6 | 0x40006000 | GPIOTE | GPIOTE | GPIO tasks and events | | | 7 | 0x40007000 | SAADC | SAADC | Analog-to-digital converter | | | 8 | 0x40008000 | TIMER | TIMER0 | Timer 0 | | | 9 | 0x40009000 | TIMER | TIMER1 | Timer 1 | | | 10 | 0x4000A000 | TIMER | TIMER2 | Timer 2 | | | 11 | 0x4000B000 | RTC | RTC0 | Real-time counter 0 | | | 12 | 0x4000C000 | TEMP | TEMP | Temperature sensor | | | 13 | 0x4000D000 | RNG | RNG | Random number generator | | | 14 | 0x4000E000 | ECB | ECB | AES Electronic Codebook (ECB) mode block encryption | | | 15 | 0x4000F000 | AAR | AAR | Accelerated address resolver | | | 15 | 0x4000F000 | CCM | CCM | AES CCM mode encryption | | | 16 | 0x40010000 | WDT | WDT | Watchdog timer | | | 17 | 0x40011000 | RTC | RTC1 | Real-time counter 1 | | | ID | Base address | Peripheral | Instance | Description | |-----|--------------|------------|----------|--------------------------------------| | 20 | 0x40014000 | EGU | EGU0 | Event generator unit 0 | | 20 | 0x40014000 | SWI | SWI0 | Software interrupt 0 | | 21 | 0x40015000 | EGU | EGU1 | Event generator unit 1 | | 21 | 0x40015000 | SWI | SWI1 | Software interrupt 1 | | 22 | 0x40016000 | SWI | SWI2 | Software interrupt 2 | | 23 | 0x40017000 | SWI | SWI3 | Software interrupt 3 | | 24 | 0x40018000 | SWI | SWI4 | Software interrupt 4 | | 25 | 0x40019000 | SWI | SWI5 | Software interrupt 5 | | 30 | 0x4001E000 | NVMC | NVMC | Non-volatile memory controller | | 31 | 0x4001F000 | PPI | PPI | Programmable peripheral interconnect | | N/A | 0x10000000 | FICR | FICR | Factory information configuration | | N/A | 0x10001000 | UICR | UICR | User information configuration | Table 5: Instantiation table # 4.3 NVMC — Non-volatile memory controller The non-volatile memory controller (NVMC) is used for writing and erasing of the internal flash memory and the UICR (user information configuration registers). The CONFIG on page 20 is used to enable the NVMC for writing (CONFIG.WEN) and erasing (CONFIG.EEN). The user must make sure that writing and erasing are not enabled at the same time. Having both enabled at the same time may result in unpredictable behavior. The CPU must be halted before initiating a NVMC operation from the debug system. # 4.3.1 Writing to flash When writing is enabled, full 32-bit words are written to word-aligned addresses in flash. As illustrated in Memory on page 15, the flash is divided into multiple pages. The same 32-bit word in the flash can only be written n<sub>WRITE</sub> number of times before a page erase must be performed. The NVMC is only able to write 0 to bits in the flash that are erased (set to 1). It cannot rewrite a bit back to 1. Only full 32-bit words can be written to flash using the NVMC interface. To write less than 32 bits, write the data as a full 32-bit word and set all the bits that should remain unchanged in the word to 1. Note that the restriction on the number of writes ( $n_{\text{WRITE}}$ ) still applies in this case. Only word-aligned writes are allowed. Byte or half-word-aligned writes will result in a hard fault. The time it takes to write a word to flash is specified by $t_{WRITE}$ . The CPU is halted while the NVMC is writing to the flash. # 4.3.2 Erasing a page in flash When erase is enabled, the flash memory can be erased page by page using the ERASEPAGE on page 20. After erasing a flash page, all bits in the page are set to 1. The time it takes to erase a page is specified by $t_{\text{ERASEPAGE}}$ . The CPU is halted if the CPU executes code from the flash while the NVMC is writing to the flash. See Partial erase of a page in flash on page 19 for information on dividing the page erase time into shorter chunks. # 4.3.3 Writing to user information configuration registers (UICR) User information configuration registers (UICR) are written in the same way as flash. After UICR has been written, the new UICR configuration will take effect after a reset. UICR can only be written $n_{WRITE}$ number of times before an erase must be performed using ERASEUICR on page 21 or ERASEALL on page 21. The time it takes to write a word to UICR is specified by $t_{WRITE}$ . The CPU is halted while the NVMC is writing to the UICR. # 4.3.4 Erasing user information configuration registers (UICR) When erase is enabled, UICR can be erased using the ERASEUICR on page 21. After erasing UICR all bits in UICR are set to 1. The time it takes to erase UICR is specified by $t_{\text{ERASEPAGE}}$ . The CPU is halted if the CPU executes code from the flash while the NVMC performs the erase operation. ### 4.3.5 Frase all When erase is enabled, flash and UICR can be erased completely in one operation by using ERASEALL on page 21. This operation will not erase the factory information configuration registers (FICR). The time it takes to perform an ERASEALL command is specified by t<sub>ERASEALL</sub>. The CPU is halted if the CPU executes code from the flash while the NVMC performs the erase operation. # 4.3.6 Partial erase of a page in flash Partial erase is a feature in the NVMC to split a page erase time into shorter chunks, so this can be used to prevent longer CPU stalls in time-critical applications. Partial erase is only applicable to the code area in the flash and does not work with UICR. When erase is enabled, the partial erase of a flash page can be started by writing to ERASEPAGEPARTIAL on page 22. The duration of a partial erase can be configured in ERASEPAGEPARTIALCFG on page 22. A flash page is erased when its erase time reaches $t_{\text{ERASEPAGE}}$ . Use ERASEPAGEPARTIAL N number of times so that N \* ERASEPAGEPARTIALCFG $\geq t_{\text{ERASEPAGE}}$ , where N \* ERASEPAGEPARTIALCFG gives the cumulative (total) erase time. Every time the cumulative erase time reaches $t_{\text{ERASEPAGE}}$ , it counts as one erase cycle. After the erase is done, all bits in the page are set to '1'. The CPU is halted if the CPU executes code from the flash while the NVMC performs the partial erase operation. The bits in the page are undefined if the flash page erase is incomplete, i.e. if a partial erase has started but the total erase time is less than $t_{\text{ERASEPAGE}}$ . # 4.3.7 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|--------------------------------|---------------| | 0x4001E000 | NVMC | NVMC | Non-volatile memory controller | | Table 6: Instances | Register | Offset | Description | | |-----------|--------|--------------------------------------------------------------------|------------| | READY | 0x400 | Ready flag | | | CONFIG | 0x504 | Configuration register | | | ERASEPAGE | 0x508 | Register for erasing a page in code area | | | ERASEPCR1 | 0x508 | Register for erasing a page in code area. Equivalent to ERASEPAGE. | Deprecated | | ERASEALL | 0x50C | Register for erasing all non-volatile user memory | | | ERASEPCR0 | 0x510 | Register for erasing a page in code area. Equivalent to ERASEPAGE. | Deprecated | | ERASEUICR | 0x514 | Register for erasing user information configuration registers | | | Register | Offset | Description | |---------------------|--------|---------------------------------------------------| | ERASEPAGEPARTIAL | 0x518 | Register for partial erase of a page in code area | | ERASEPAGEPARTIALCFG | 0x51C | Register for partial erase configuration | Table 7: Register overview ## 4.3.7.1 READY Address offset: 0x400 Ready flag | Bit number | | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|-------|------------------|------------------------------------------------------------------------| | ID | | | A | | Reset 0x00000001 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A R READY | | | NVMC is ready or busy | | | Busy | 0 | NVMC is busy (ongoing write or erase operation) | | | Ready | 1 | NVMC is ready | # 4.3.7.2 CONFIG Address offset: 0x504 Configuration register # 4.3.7.3 ERASEPAGE Address offset: 0x508 Register for erasing a page in code area | Bit n | umber | 31 30 | 29 28 | 27 : | 26 2 | 5 24 | 1 23 | 22 | 21 2 | 20 19 | 18 | 17 : | 16 1 | 15 1 | 4 1 | 3 12 | 11 | 10 | 9 8 | 3 7 | 6 | 5 | 4 | 3 | 2 : | 1 0 | | |-------|--------------|-------|-------|------|------|------|------|-------|-------|--------|-------|-------|------|-------|------|-------|------|------|------|-------|------|-----|-----|----|-----|-----|--| | ID | | A A | А А | Α | A A | 4 A | Α | Α | Α, | A A | Α | Α | Α. | A A | Δ Δ | A | Α | Α | A A | A A | Α | Α | Α | Α. | A | А А | | | Rese | t 0x00000000 | 0 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW ERASEPAGE | | | | | | Re | gist | er fo | or sta | artir | ng ei | rase | e of | ар | age | in c | ode | are | a. | | | | | | | | | | | | | | | | Th | ne va | alue | is th | ie ac | ddre | ss t | to th | ne p | age | to | be e | rase | ed (a | add | res | ses | | | | | | | | | | | | | of | first | t wo | rd ir | n pa | ge). | No | te t | hat | the | era | se n | nust | be | ena | ble | d | | | | | | | | | | | | | us | ing ( | CON | IFIG. | WEI | N be | for | e th | ie p | age | can | be | eras | sed. | | | | | | | | | | | | | | | | At | tem | pts | to er | rase | pag | es i | that | are | e ou | tsid | e th | e co | ode | area | a m | ay | | | | | | | | | | | | | res | sult | in u | nde | sirak | ole b | eh | avio | r, e | .g. t | he v | vroi | ng p | age | ma | y b | e | | | | | | | | | | | | | era | asec | d. | | | | | | | | | | | | | | | | | | | # 4.3.7.4 ERASEPCR1 (Deprecated) Address offset: 0x508 Register for erasing a page in code area. Equivalent to ERASEPAGE. ### **4.3.7.5 ERASEALL** Address offset: 0x50C Register for erasing all non-volatile user memory # 4.3.7.6 ERASEPCRO (Deprecated Address offset: 0x510 Register for erasing a page in code area. Equivalent to ERASEPAGE. ### **4.3.7.7 ERASEUICR** Address offset: 0x514 Register for erasing user information configuration registers NORDIC ### 4.3.7.8 ERASEPAGEPARTIAL Address offset: 0x518 Register for partial erase of a page in code area # 4.3.7.9 ERASEPAGEPARTIALCFG Address offset: 0x51C Register for partial erase configuration | Bit n | umber | | 313 | 0 29 2 | 28 27 2 | 6 25 2 | 4 23 2 | 2 21 | 20 19 | 9 18 1 | 17 16 | 5 15 | 14 1 | .3 12 | 2 11 | 10 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | . 0 | |-------|---------------|----------|-----|--------|---------|--------|--------|-------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-----|----|---|---|-----|-----|-----| | ID | | | | | | | | | | | | | | | | | | | Α | Α | Α | Α , | 4 Δ | \ A | | Rese | et 0x0000000A | | 0 ( | 0 0 | 0 0 0 | 0 0 | 0 ( | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 1 ( | 0 1 | . 0 | | ID | | Value ID | | | | | | | | | | | | | | | | | | | | | | | | Α | RW DURATION | | | | | | Dura | ation | of th | e par | tial | eras | e in | milli | seco | nds | | | | | | | | | | | | | | | | | The | user | must | : ensu | ıre t | hat t | the t | otal | eras | e tin | ne is | lor | ng | | | | | | | | | | | | | | eno | ugh f | or a d | omp | lete | eras | e of | the | flasl | n pag | ge. | | | | | | | | # 4.3.8 Electrical specification # 4.3.8.1 Flash programming | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------------------------|-----------------------------------------------------------|-------|------|-------------------|-------| | n <sub>WRITE</sub> | Number of times a 32-bit word can be written before erase | | | 2 | | | n <sub>ENDURANCE</sub> | Erase cycles per page | 10000 | | | | | t <sub>WRITE</sub> | Time to write one 32-bit word | | | 41 <sup>2</sup> | μs | | t <sub>ERASEPAGE</sub> | Time to erase one page | | | 85 <sup>2</sup> | ms | | t <sub>ERASEALL</sub> | Time to erase all flash | | | 169 <sup>2</sup> | ms | | t <sub>ERASEPAGEPARTIAL,acc</sub> | Accuracy of the partial page erase duration. Total | | | 1.05 <sup>2</sup> | | | | execution time for one partial page erase is defined as | | | | | | | ERASEPAGEPARTIALCFG * t <sub>erasepagepartial,acc</sub> . | | | | | # 4.4 FICR — Factory information configuration registers Factory information configuration registers (FICR) are pre-programmed in factory and cannot be erased by the user. These registers contain chip-specific information and configuration. # 4.4.1 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|-----------------------------------|---------------| | 0x10000000 | FICR | FICR | Factory information configuration | | Table 8: Instances | Register | Offset | Description | |-----------------|--------|-------------------------------------------------------------| | CODEPAGESIZE | 0x010 | Code memory page size | | CODESIZE | 0x014 | Code memory size | | DEVICEID[0] | 0x060 | Device identifier | | DEVICEID[1] | 0x064 | Device identifier | | ER[0] | 0x080 | Encryption root, word 0 | | ER[1] | 0x084 | Encryption root, word 1 | | ER[2] | 0x088 | Encryption root, word 2 | | ER[3] | 0x08C | Encryption root, word 3 | | IR[0] | 0x090 | Identity root, word 0 | | IR[1] | 0x094 | Identity root, word 1 | | IR[2] | 0x098 | Identity root, word 2 | | IR[3] | 0x09C | Identity root, word 3 | | DEVICEADDRTYPE | 0x0A0 | Device address type | | DEVICEADDR[0] | 0x0A4 | Device address 0 | | DEVICEADDR[1] | 0x0A8 | Device address 1 | | INFO.PART | 0x100 | Part code | | INFO.VARIANT | 0x104 | Part variant, hardware version and production configuration | | INFO.PACKAGE | 0x108 | Package option | | INFO.RAM | 0x10C | RAM variant | | INFO.FLASH | 0x110 | Flash variant | | INFO.UNUSED8[0] | 0x114 | Reserved | <sup>&</sup>lt;sup>2</sup> HFXO is used here | Register | Offset | Description | | |-----------------|--------|---------------------|----------------| | INFO.UNUSED8[1] | 0x118 | | Reserved | | INFO.UNUSED8[2] | 0x11C | | Reserved | | TEMP.A0 | 0x404 | Slope definition A0 | | | TEMP.A1 | 0x408 | Slope definition A1 | | | TEMP.A2 | 0x40C | Slope definition A2 | | | TEMP.A3 | 0x410 | Slope definition A3 | | | TEMP.A4 | 0x414 | Slope definition A4 | | | TEMP.A5 | 0x418 | Slope definition A5 | | | TEMP.B0 | 0x41C | Y-intercept B0 | | | TEMP.B1 | 0x420 | Y-intercept B1 | | | TEMP.B2 | 0x424 | Y-intercept B2 | | | TEMP.B3 | 0x428 | Y-intercept B3 | | | TEMP.B4 | 0x42C | Y-intercept B4 | • | | TEMP.B5 | 0x430 | Y-intercept B5 | | | TEMP.TO | 0x434 | Segment end T0 | | | TEMP.T1 | 0x438 | Segment end T1 | * ( <b>/</b> \ | | TEMP.T2 | 0x43C | Segment end T2 | | | TEMP.T3 | 0x440 | Segment end T3 | X | | TEMP.T4 | 0x444 | Segment end T4 | | Table 9: Register overview # 4.4.1.1 CODEPAGESIZE Address offset: 0x010 Code memory page size | Bit number | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|----------------------|------------------------------------------------------------------| | ID | | A A A A A A | A A A A A A A A A A A A A A A A A A A | | Reset 0x00001000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | Value | | | A R CODEPAGESIZE | | | Code memory page size | #### 4 4 1 2 CODESIZE Address offset: 0x014 Code memory size | Bit number | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|-------------------------|-----------------------------------------------------------------| | ID | A A A A A A A | . A A A A A A A A A A A A A A A A A A A | | Reset 0x00000030 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0 0 0 | | ID Acce Field Value ID | Value | Description | R CODESIZE Code memory size in number of pages Total code space is: CODEPAGESIZE \* CODESIZE # 4.4.1.3 DEVICEID[n] (n=0..1) Address offset: $0x060 + (n \times 0x4)$ Device identifier | י טו | Acce Fleid | | | | | | | | | crib | | | | | | | | | | | | | | | | | | |---------|------------|-----|------|------------|------|----|----|------|------|------|------|----|------|------|------|----|------|------|----|---|-----|---|---|-----|------------|---|---| | ID | Acce Field | | | | | | | | | | | | | | | | | | | | | | | | | | | | Reset ( | 0xFFFFFFF | 1 | 1 1 | 1 1 | 1 | 1 | 1 | 1 | 1 | 1 1 | l 1 | 1 | 1 1 | ۱ 1 | 1 | 1 | 1 1 | . 1 | 1 | 1 | 1 1 | 1 | 1 | 1 | 1 1 | 1 | 1 | | ID | | Α | A A | <b>А</b> А | Α | Α | Α | Α | A | 4 Α | A A | Α | A A | A A | Α | Α | A A | Α | Α | A | А А | Α | Α | Α . | <b>А</b> А | Α | Α | | Bit nur | mber | 313 | 30 2 | 9 28 | 3 27 | 26 | 25 | 24 2 | 23 2 | 2 2 | 1 20 | 19 | 18 1 | 7 16 | 5 15 | 14 | 13 1 | 2 11 | 10 | 9 | 8 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | R DEVICEID 64 bit unique device identifier DEVICEID[0] contains the least significant bits of the device identifier. DEVICEID[1] contains the most significant bits of the device identifier. # 4.4.1.4 ER[n] (n=0..3) Address offset: $0x080 + (n \times 0x4)$ Encryption root, word n # 4.4.1.5 IR[n] (n=0..3) Address offset: $0x090 + (n \times 0x4)$ Identity root, word n # 4.4.1.6 DEVICEADDRTYPE Address offset: 0x0A0 Device address type | Bit number | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|---------------------|---------------------------------------------------------------------| | ID | | A | | Reset 0xFFFFFFF | 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field Value ID | | Description | | A R DEVICEADDRTYPE | | Device address type | | Public | 0 | Public address | | Random | 1 | Random address | # 4.4.1.7 DEVICEADDR[n] (n=0..1) Address offset: $0x0A4 + (n \times 0x4)$ Device address n | Bit n | umbe | er | 31 | 30 2 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 1 | 18 : | 17 1 | 16 1 | 15 1 | .4 1 | 3 12 | 2 11 | 10 | 9 | 8 | 7 | 6 ! | 5 4 | 3 | 2 | 1 ( | |-------|-------|------------|----|------|----|----|----|----|----|----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-------|-----|-----|-----|---|---|-----| | ID | | | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α. | Α | A . | Δ . | Α Α | A | Α | Α | Α | Α | Α / | Δ Δ | Α | Α | A A | | Rese | t OxF | FFFFFF | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 1 | L 1 | 1 | 1 | 1 | 1 | 1 | 1 : | 1 1 | 1 | 1 | 1 1 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | R | DEVICEADDR | | | | | | | | | 48 | bit | dev | vice | ad | dre | ess | | | | | | | | | | | | | | | | | | | | | | | | | | | DE | VIC | EAD | DDF | R[0] | со | nta | ins | the | lea | st s | igni | fica | nt l | oits | of | | | | | | | | | | | | | | | | | | the | e de | evic | e a | ddr | ess | . DE | VI | CEA | DD | R[1] | со | ntai | ns t | he | mo | st | | | | | | | | | | | | | | | | | sigi | nifi | can | t bi | ts c | of t | he o | dev | ice | ado | ires | s. O | nly | bits | s [1! | 5:0 | of | | | | | | | | | | | | | | | | | DE | VIC | EAD | DDF | R[1] | ar | e us | ed | | | | | | | | | | | | | | ## 4.4.1.8 INFO.PART Address offset: 0x100 Part code ## 4.4.1.9 INFO.VARIANT Address offset: 0x104 Part variant, hardware version and production configuration | Bit number | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|-------------|-------------------------|-----------------------------------------------------------------| | ID | | AAAAAAA | | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field | Value ID | Value | Description | | A R VARIANT | | | Part variant, hardware version and production | | | | | configuration, encoded as ASCII | | | AAAA | 0x41414141 | AAAA | | | AAA0 | 0x41414130 | AAA0 | | | AABA | 0x41414241 | AABA | | | AABB | 0x41414242 | AABB | | | AAB0 | 0x41414230 | AAB0 | | | AACA | 0x41414341 | AACA | | | AACB | 0x41414342 | AACB | | | AAC0 | 0x41414330 | AAC0 | | | Unspecified | 0xFFFFFFF | Unspecified | | | | | | ## 4.4.1.10 INFO.PACKAGE Address offset: 0x108 Package option | Bit number | | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|-------------|-----------------------------|---------------------------------------------------------------------| | ID | | $A \ A \ A \ A \ A \ A \ A$ | A A A A A A A A A A A A A A A A A A A | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field | | | | | A R PACKAGE | | | Package option | | | CA | 0x2004 | CAxx - WLCSP | | | Unspecified | 0xFFFFFFF | Unspecified | ## 4.4.1.11 INFO.RAM Address offset: 0x10C **RAM** variant | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 | |------------------|-------------|-------------------------------------------------------------------------------------|---| | ID | | A A A A A A A A A A A A A A A A A A A | Α | | Reset 0x00000018 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | ID Acce Field | | Value Description | | | A R RAM | | RAM variant | | | | K24 | 0x18 24 kByte RAM | | | | Unspecified | 0xFFFFFFF Unspecified | | # 4.4.1.12 INFO.FLASH Address offset: 0x110 Flash variant # 4.4.1.13 TEMP.A0 Address offset: 0x404 Slope definition A0 | A D A | · | A /slane definition) register | |-----------------|---|-------------------------------------------------------------------------------------| | ID Acce Field | | | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | A A A A A A A A A A A A A A A A A A A | | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | A R A A (slope definition) register ## 4.4.1.14 TEMP.A1 Address offset: 0x408 Slope definition A1 | D | | |--------------------------------------------------------------------------------------|-------------| | <u> </u> | | | ID A A A A A | 11111 | | | A A A A A | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 | 5 4 3 2 1 ( | # 4.4.1.15 TEMP.A2 Address offset: 0x40C Slope definition A2 | Bit number | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 | 8 17 16 1 | 5 14 13 | 12 11 | 10 9 | 8 | 7 6 | 5 5 | 4 | 3 | 2 1 | 0 | |-----------------|------------------|---------------------------|-----------|---------|-------|------|---|-----|-----|---|---|-----|---| | ID | | | | | А | A A | Α | A A | 4 A | Α | A | A A | Α | | Reset 0xFFFFFFF | 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 | 11: | 1 1 | 1 1 | 1 1 | 1 | 1 : | l 1 | 1 | 1 | 1 1 | 1 | | ID Acce Field | | Description | | | | | | | | | | | | | A R A | | A (slope definitio | n) regist | er | | | | | | | | | _ | ## 4.4.1.16 TEMP.A3 Address offset: 0x410 Slope definition A3 # 4.4.1.17 TEMP.A4 Address offset: 0x414 Slope definition A4 | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|--|---------------------------------------------------------------------------------------| | ID | | A A A A A A A A A A A A A A A A A A A | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field | | Value Description | | Λ B Λ | | A (clans definition) register | ### 4.4.1.18 TEMP.A5 Address offset: 0x418 Slope definition A5 | A R A | | A (slope definition) r | egister | | | | | | | |-----------------|-------------------|----------------------------|----------------|---------|-----|-----|-----|-----|-----| | ID Acce Field | | | | | | | | | | | Reset 0xFFFFFFF | 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 | 1 1 1 1 1 | 1 1 1 | 1 1 | 1 1 | . 1 | 1 1 | 1 1 | | ID | | | | A A A | А А | A A | . A | 4 A | A A | | Bit number | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 | 16 15 14 13 12 | 11 10 9 | 8 7 | 6 5 | 4 | 3 2 | 1 0 | ### 4.4.1.19 TEMP.B0 Address offset: 0x41C Y-intercept B0 | Bit number | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|----------------------|--------------------------------------------------------------------| | ID | | A A A A A A A A A A A A A A A A A A A | | Reset 0xFFFFFFF | 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field | | | | A R B | | B (y-intercept) | ### 4.4.1.20 TEMP.B1 Address offset: 0x420 Y-intercept B1 ### 4.4.1.21 TEMP.B2 Address offset: 0x424 Y-intercept B2 ## 4.4.1.22 TEMP.B3 Address offset: 0x428 Y-intercept B3 | Α | R B | | | | | B (v- | inter | cent | +) | | | | | | | | | | | | | | | | |-------|-------------|---------|---------|-------|--------|-------|-------|------|-------|------|------|----|------|-------|------|---|---|---|---|-----|---|---|-----|---| | ID | | | | | | Desc | | | | | | | | | | | | | | | | | | | | Rese | t OxFFFFFFF | 1 1 1 | . 1 1 | 1 1 | 1 | 1 1 | . 1 | 1 : | 1 1 | 1 | 1 1 | 1 | 1 | 1 1 | 1 | 1 | 1 | 1 | 1 | 1 1 | 1 | 1 | 1 | 1 | | ID | | | | | | | | | | | | | Α | A A | Α | Α | Α | Α | A | Δ Δ | Α | Α | Α, | 4 | | Bit n | umber | 31 30 2 | 9 28 27 | 26 25 | 5 24 : | 23 22 | 2 21 | 20 1 | .9 18 | 17 1 | 6 15 | 14 | 13 : | 12 13 | l 10 | 9 | 8 | 7 | 6 | 5 4 | 3 | 2 | 1 ( | C | # 4.4.1.23 TEMP.B4 Address offset: 0x42C Y-intercept B4 | ID Acce Field | | | | | | | | | | | | |-----------------|-------------------------|------------------------|------------|-------|-------|---|-----|----|-----|-------|-------| | | | | | | | | | | | | | | Reset 0xFFFFFFF | 1 1 1 1 1 1 1 1 | 1111111 | 1 1 1 | 1 1 | 1 1 | 1 | 1 1 | 1 | 1 1 | . 1 1 | . 1 1 | | ID | | | | A A | A A | Α | А А | Α. | A A | . A A | A A | | Bit number | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 | 7 16 15 14 | 13 12 | 11 10 | 9 | 8 7 | 6 | 5 4 | 3 2 | 1 0 | ## 4.4.1.24 TEMP.B5 Address offset: 0x430 Y-intercept B5 | Bit number | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 3 | 14 13 12 11 10 9 | 9 8 7 6 5 4 3 2 1 0 | |-----------------|-------------------|--------------------------------------|------------------|---------------------| | ID | | | AAAAA | A A A A A A A A | | Reset 0xFFFFFFF | 1 1 1 1 1 1 | 11111111111 | 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 | | ID Acce Field | | Description | | | | A R B | | B (y-intercept) | | | ### 4.4.1.25 TEMP.TO Address offset: 0x434 Segment end T0 # 4.4.1.26 TEMP.T1 Address offset: 0x438 Segment end T1 | Bit number | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 | 5 4 3 2 1 0 | |-----------------|------------------------|-----------------------------------------------------|-------------| | ID | | A A | AAAAAA | | Reset 0xFFFFFFF | 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 | | ID Acce Field | | | | | A R T | | T (segment end) register | | ### 4.4.1.27 TEMP.T2 Address offset: 0x43C Segment end T2 | Bit number | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 | 3 2 1 0 | |------------------------|-------------------------|-----------------------------------------------|---------|---------| | ID | | | A A A A | АААА | | Reset 0xFFFFFFF | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | | ID Acce Field Value ID | Value | Description | | | A R T T (segment end) register ### 4.4.1.28 TEMP.T3 Address offset: 0x440 Segment end T3 | A R T | | T (seg | ment en | d) regi | ster | | | | | | | | | | | |-----------------|-------------------|---------------|----------|---------|-------|-------|-------|------|---|---|-----|------------|---|-----|-----| | ID Acce Field | | | | | | | | | | | | | | | | | Reset 0xFFFFFFF | 1 1 1 1 1 1 | 1 1 1 1 | 1 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 | 1 | 1 | 1 1 | 1 | 1 | 1 1 | | ID | | | | | | | | | | Α | Α , | <b>А</b> А | Α | Α . | А А | | Bit number | 31 30 29 28 27 26 | 5 25 24 23 22 | 21 20 19 | 9 18 17 | 16 15 | 14 13 | 12 11 | 10 9 | 8 | 7 | 6 ! | 5 4 | 3 | 2 | 1 0 | ### 4.4.1.29 TEMP.T4 Address offset: 0x444 Segment end T4 # 4.5 UICR — User information configuration registers The user information configuration registers (UICRs) are non-volatile memory (NVM) registers for configuring user-specific settings. For information on writing UICR registers, see the NVMC — Non-volatile memory controller on page 18 and Memory on page 15 chapters. # 4.5.1 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|--------------------------------|---------------| | 0x10001000 | UICR | UICR | User information configuration | | Table 10: Instances | Register | Offset | Description | | |----------|--------|-------------------------------------|----------| | UNUSED0 | 0x000 | | Reserved | | UNUSED1 | 0x004 | | Reserved | | UNUSED2 | 0x008 | | Reserved | | UNUSED3 | 0x010 | | Reserved | | NRFFW[0] | 0x014 | Reserved for Nordic firmware design | | | NRFFW[1] | 0x018 | Reserved for Nordic firmware design | | | NRFFW[2] | 0x01C | Reserved for Nordic firmware design | | | NRFFW[3] | 0x020 | Reserved for Nordic firmware design | | | NRFFW[4] | 0x024 | Reserved for Nordic firmware design | | | NRFFW[5] | 0x028 | Reserved for Nordic firmware design | | | NRFFW[6] | 0x02C | Reserved for Nordic firmware design | | | NRFFW[7] | 0x030 | Reserved for Nordic firmware design | | | Register | Offset | Description | |-----------------------|----------------|--------------------------------------------------------------------------| | NRFFW[8] | 0x034 | Reserved for Nordic firmware design | | | | - | | NRFFW[9]<br>NRFFW[10] | 0x038<br>0x03C | Reserved for Nordic firmware design Reserved for Nordic firmware design | | | | | | NRFFW[11] | 0x040 | Reserved for Nordic firmware design | | NRFFW[12] | 0x044 | Reserved for Nordic firmware design | | NRFHW[0] | 0x050 | Reserved for Nordic hardware design | | NRFHW[1] | 0x054 | Reserved for Nordic hardware design | | NRFHW[2] | 0x058 | Reserved for Nordic hardware design | | NRFHW[3] | 0x05C | Reserved for Nordic hardware design | | NRFHW[4] | 0x060 | Reserved for Nordic hardware design | | NRFHW[5] | 0x064 | Reserved for Nordic hardware design | | NRFHW[6] | 0x068 | Reserved for Nordic hardware design | | NRFHW[7] | 0x06C | Reserved for Nordic hardware design | | NRFHW[8] | 0x070 | Reserved for Nordic hardware design | | NRFHW[9] | 0x074 | Reserved for Nordic hardware design | | NRFHW[10] | 0x078 | Reserved for Nordic hardware design | | NRFHW[11] | 0x07C | Reserved for Nordic hardware design | | CUSTOMER[0] | 0x080 | Reserved for customer | | CUSTOMER[1] | 0x084 | Reserved for customer | | CUSTOMER[2] | 0x088 | Reserved for customer | | CUSTOMER[3] | 0x08C | Reserved for customer | | CUSTOMER[4] | 0x090 | Reserved for customer | | CUSTOMER[5] | 0x094 | Reserved for customer | | CUSTOMER[6] | 0x098 | Reserved for customer | | CUSTOMER[7] | 0x09C | Reserved for customer | | CUSTOMER[8] | 0x0A0 | Reserved for customer | | CUSTOMER[9] | 0x0A4 | Reserved for customer | | CUSTOMER[10] | 0x0A8 | Reserved for customer | | CUSTOMER[11] | 0x0AC | Reserved for customer | | CUSTOMER[12] | 0x0B0 | Reserved for customer | | CUSTOMER[13] | 0x0B4 | Reserved for customer | | CUSTOMER[14] | 0x0B8 | Reserved for customer | | CUSTOMER[15] | 0x0BC | Reserved for customer | | CUSTOMER[16] | 0x0C0 | Reserved for customer | | CUSTOMER[17] | 0x0C4 | Reserved for customer | | CUSTOMER[18] | 0x0C8 | Reserved for customer | | CUSTOMER[19] | 0x0CC | Reserved for customer | | CUSTOMER[20] | 0x0D0 | Reserved for customer | | CUSTOMER[21] | 0x0D4 | Reserved for customer | | CUSTOMER[22] | 0x0D8 | Reserved for customer | | CUSTOMER[23] | 0x0DC | Reserved for customer | | CUSTOMER[24] | 0x0E0 | Reserved for customer | | CUSTOMER[25] | 0x0E4 | Reserved for customer | | CUSTOMER[26] | 0x0E8 | Reserved for customer | | CUSTOMER[27] | 0x0EC | Reserved for customer | | CUSTOMER[28] | 0x0F0 | Reserved for customer | | CUSTOMER[29] | 0x0F4 | Reserved for customer | | CUSTOMER[30] | 0x0F8 | Reserved for customer | | CUSTOMER[31] | 0x0FC | Reserved for customer | | PSELRESET[0] | 0x200 | Mapping of the nRESET function (see POWER chapter for details) | | PSELRESET[1] | 0x204 | Mapping of the nRESET function (see POWER chapter for details) | | APPROTECT | 0x208 | Access port protection | | | | | Table 11: Register overview # 4.5.1.1 NRFFW[n] (n=0..12) Address offset: $0x014 + (n \times 0x4)$ Reserved for Nordic firmware design | Α | RW NRFFW | Reserved for Nordic firmware design | | |-------|--------------|---------------------------------------------------------------------------------------|--| | ID | | Value Description | | | Res | et OxFFFFFFF | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | ID | | A A A A A A A A A A A A A A A A A A A | | | Bit r | number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | # 4.5.1.2 NRFHW[n] (n=0..11) Address offset: $0x050 + (n \times 0x4)$ Reserved for Nordic hardware design # 4.5.1.3 CUSTOMER[n] (n=0..31) Address offset: $0x080 + (n \times 0x4)$ Reserved for customer # 4.5.1.4 PSELRESET[n] (n=0..1) Address offset: $0x200 + (n \times 0x4)$ Mapping of the nRESET function (see POWER chapter for details) All PSELRESET registers have to contain the same value for a pin mapping to be valid. If values are not the same, there will be no nRESET function exposed on a GPIO. As a result, the device will always start independently of the levels present on any of the GPIOs. | Bit r | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | С | АААА | | Rese | t OxFFFFFFF | | 1 1 1 1 1 1 1 1 | . 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | | | Α | RW PIN | | 21 | GPIO pin number onto which nRESET is exposed | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | | | | ### **4.5.1.5 APPROTECT** Address offset: 0x208 Access port protection | Bit number | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | |-----------------|----------|--------------------------------------------|------------------------------------------------------------------------|--| | ID | | | A A A A A A A | | | Reset 0xFFFFFFF | | 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | ID Acce Field | | | Description | | | A RW PALL | | Enable or disable access port protection. | | | | | | See Debug on page 37 for more information. | | | | | Disabled | 0xFF | Disable | | | | Enabled | 0x00 | Enable | | # 4.6 EasyDMA EasyDMA is a module implemented by some peripherals to gain direct access to Data RAM. EasyDMA is an AHB bus master similar to CPU and is connected to the AHB multilayer interconnect for direct access to Data RAM. EasyDMA is not able to access flash. A peripheral can implement multiple EasyDMA instances to provide dedicated channels. For example, for reading and writing of data between the peripheral and RAM. This concept is illustrated in EasyDMA example on page 34. Figure 4: EasyDMA example An EasyDMA channel is implemented in the following way, but some variations may occur: ``` READERBUFFER_SIZE 5 WRITERBUFFER_SIZE 6 uint8_t readerBuffer[READERBUFFER_SIZE] __at__ 0x20000000; uint8_t writerBuffer[WRITERBUFFER_SIZE] __at__ 0x200000005; // Configuring the READER channel MYPERIPHERAL->READER.MAXCNT = READERBUFFER_SIZE; MYPERIPHERAL->READER.PTR = &readerBuffer; // Configure the WRITER channel MYPERIPHERAL->WRITER.MAXCNT = WRITEERBUFFER_SIZE; MYPERIPHERAL->WRITER.MAXCNT = &writerBuffer; ``` This example shows a peripheral called MYPERIPHERAL that implements two EasyDMA channels - one for reading called READER, and one for writing called WRITER. When the peripheral is started, it is assumed that the peripheral will: - Read 5 bytes from the readerBuffer located in RAM at address 0x20000000. - · Process the data. - Write no more than 6 bytes back to the writerBuffer located in RAM at address 0x20000005. The memory layout of these buffers is illustrated in EasyDMA memory layout on page 35. | 0x20000000 | readerBuffer[0] | readerBuffer[1] | readerBuffer[2] | readerBuffer[3] | |------------|-----------------|-----------------|-----------------|-----------------| | 0x20000004 | readerBuffer[4] | writerBuffer[0] | writerBuffer[1] | writerBuffer[2] | | 0x20000008 | writerBuffer[3] | writerBuffer[4] | writerBuffer[5] | | Figure 5: EasyDMA memory layout The WRITER.MAXCNT register should not be specified larger than the actual size of the buffer (writerBuffer). Otherwise, the channel would overflow the writerBuffer. Once an EasyDMA transfer is completed, the AMOUNT register can be read by the CPU to see how many bytes were transferred. For example, CPU can read MYPERIPHERAL->WRITER.AMOUNT register to see how many bytes WRITER wrote to RAM. Note that the PTR register of a READER or WRITER must point to a valid memory region before use. The reset value of a PTR register is not guaranteed to point to valid memory. See Memory on page 15 for more information about the different memory regions and EasyDMA connectivity. # 4.6.1 EasyDMA error handling Some errors may occur during DMA handling. If READER.PTR or WRITER.PTR is not pointing to a valid memory region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 15 for more information about the different memory regions. If several AHB bus masters try to access the same AHB slave at the same time, AHB bus congestion might occur. An EasyDMA channel is an AHB master. Depending on the peripheral, the peripheral may either stall and wait for access to be granted, or lose data. # 4.6.2 EasyDMA array list EasyDMA is able to operate in Array List mode. The Array List mode is implemented in channels where the LIST register is available. The array list does not provide a mechanism to explicitly specify where the next item in the list is located. Instead, it assumes that the list is organized as a linear array where items are located one after the other in RAM. The EasyDMA Array List can be implemented by using the data structure ArrayList\_type as illustrated in the code example below using a READER EasyDMA channel as an example: ``` #define BUFFER_SIZE 4 typedef struct ArrayList { uint8_t buffer[BUFFER_SIZE]; } ArrayList_type; ArrayList_type ReaderList[3] __at__ 0x20000000; MYPERIPHERAL->READER.MAXCNT = BUFFER_SIZE; MYPERIPHERAL->READER.PTR = &ReaderList; MYPERIPHERAL->READER.LIST = MYPERIPHERAL_READER_LIST_ArrayList; ``` The data structure only includes a buffer with size equal to the size of READER.MAXCNT register. EasyDMA uses the READER.MAXCNT register to determine when the buffer is full. #### READER.PTR = &ReaderList | 0x20000000 : ReaderList[0] | $\vdash$ | |----------------------------|----------| | 0x20000004 : ReaderList[1] | | | 0x20000008 : ReaderList[2] | | | buffer[0] | buffer[1] | buffer[2] | buffer[3] | |-----------|-----------|-----------|-----------| | buffer[0] | buffer[1] | buffer[2] | buffer[3] | | buffer[0] | buffer[1] | buffer[2] | buffer[3] | Figure 6: EasyDMA array list # 4.7 AHB multilayer AHB multilayer enables parallel access paths between multiple masters and slaves in a system. Access is resolved using priorities. Each bus master is connected to the slave devices using an interconnection matrix. The bus masters are assigned priorities. Priorities are used to resolve access when two (or more) bus masters request access to the same slave device. The following applies: - If two (or more) bus masters request access to the same slave device, the master with the highest priority is granted the access first. - Bus masters with lower priority are stalled until the higher priority master has completed its transaction. - If the higher priority master pauses at any point during its transaction, the lower priority master in queue is temporarily granted access to the slave device until the higher priority master resumes its activity. - Bus masters that have the same priority are mutually exclusive, thus cannot be used concurrently. Below is a list of bus masters in the system and their priorities. | Bus master name | Description | |-----------------|--------------------------------------| | bus master name | Description | | CPU | | | SPIMO/SPISO | Same priority and mutually exclusive | | RADIO | | | CCM/ECB/AAR | Same priority and mutually exclusive | | SAADC | * | | UARTEO | | | TWIM0/TWIS0 | Same priority and mutually exclusive | Table 12: AHB bus masters (listed in priority order, highest to lowest) Defined bus masters are the CPU and the peripherals with implemented EasyDMA, and the available slaves are RAM AHB slaves. How the bus masters and slaves are connected using the interconnection matrix is illustrated in Memory on page 15. ## 4.8 Debug Debug system offers a flexible and powerful mechanism for non-intrusive debugging. Figure 7: Overview The main features of the debug system are: - Two-pin serial wire debug (SWD) interface - Flash patch and breakpoint (FPB) unit supports: - Two literal comparators • Six instruction comparators #### 4.8.1 DAP - Debug access port An external debugger can access the device via the DAP. The debug access port (DAP) implements a standard ARM<sup>®</sup> CoreSight<sup>™</sup> serial wire debug port (SW-DP), which implements the serial wire debug protocol (SWD). SWD is a two-pin serial interface, see SWDCLK and SWDIO in Overview on page 37. In addition to the default access port in CPU (AHB-AP), the DAP includes a custom control access port (CTRL-AP). The CTRL-AP is described in more detail in CTRL-AP - Control access port on page 38. #### Note: - The SWDIO line has an internal pull-up resistor. - The SWDCLK line has an internal pull-down resistor. #### 4.8.2 CTRL-AP - Control access port The control access port (CTRL-AP) is a custom access port that enables control of the device when other access ports in the DAP are disabled by the access port protection. Access port protection blocks the debugger from read and write access to all CPU registers and memory-mapped addresses. See the UICR register APPROTECT on page 34 for more information on enabling access port protection. Control access port has the following features: - Soft reset, see Reset on page 51 for more information - Disabling of access port protection, which is the reason why CTRL-AP allows control of the device even when all other access ports in the DAP are disabled by the access port protection Access port protection is disabled by issuing an ERASEALL command via CTRL-AP. This command will erase the flash, UICR, and RAM. #### 4.8.2.1 Registers | Register | Offset | Description | |-----------------|--------|--------------------------------------------| | RESET | 0x000 | Soft reset triggered through CTRL-AP | | ERASEALL | 0x004 | Erase all | | ERASEALLSTATUS | 0x008 | Status register for the ERASEALL operation | | APPROTECTSTATUS | 0x00C | Status register for access port protection | | IDR | 0x0FC | CTRL-AP identification register, IDR | Table 13: Register overview #### 4.8.2.1.1 RESET Address offset: 0x000 Soft reset triggered through CTRL-AP | Bit number | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|---------------------|--------------------------------------------------------------------| | ID | | А | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A RW RESET | | Soft reset triggered through CTRL-AP. See Reset behavior in | | | | POWER chapter for more details. | | NoReset | 0 | Reset is not active | | Reset | 1 | Reset is active. Device is held in reset. | #### 4.8.2.1.2 ERASEALL Address offset: 0x004 Erase all | Bit number | | 31 30 29 28 27 | 7 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|-------------|----------------|--------------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A W ERASEALL | | | Erase all flash and RAM | | | NoOperation | 0 | No operation | | | Erase | 1 | Erase all flash and RAM | #### 4.8.2.1.3 ERASEALLSTATUS Address offset: 0x008 Status register for the ERASEALL operation | Bit nur | nber | | 313 | 0 29 2 | 28 27 | 26 2 | 25 24 | 23 22 | 21 2 | 20 19 | 18 1 | 7 16 | 15 3 | L4 13 | 12 1 | 11 10 | 9 | 8 7 | 7 6 | 5 | 4 | 3 | 2 1 | . 0 | |---------|------------------|----------|------|--------|-------|------|-------|-------|-------|-------|--------|-------|-------|-------|------|-------|---|-----|-----|---|---|---|-----|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | Α | | Reset ( | 0x00000000 | | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 0 | 0 ( | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 0 | 0 | | ID , | Acce Field | Value ID | Valu | e | | 4 | | | | | | | | | | | | | | | | | | | | Α | R ERASEALLSTATUS | | | | | | | Statu | s reg | ister | for t | he El | RASE | ALL | oper | atio | n | | | | | | | | | | | Ready | 0 | | | | | ERAS | EALL | is re | ady | | | | | | | | | | | | | | | | | Busy | 1 | | | | | ERAS | EALL | is bu | usy (c | n-go | oing) | | | | | | | | | | | | #### 4.8.2.1.4 APPROTECTSTATUS Address offset: 0x00C Status register for access port protection | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | R APPROTECTSTATUS | | | Status register for access port protection | | | | Enabled | 0 | Access port protection enabled | | | | Disabled | 1 | Access port protection not enabled | #### 4.8.2.1.5 IDR Address offset: 0x0FC CTRL-AP identification register, IDR | D.: | - 1 | | | 24 | 20.24 | 2 20 | | 200 | | | 2 22 | 24 | 20 | 10. | | 7.4 | | | 42. | 12.4 | | _ | 0 | 7 | _ | _ | | _ | 4 | _ | |-------|-------|------------|------------|-----|-------|------|----|------|------|------|------|-------|-------|-------|-------|-------|------|----|-----|-------|------|---|---|----|-----|-----|-----|---|---|---| | BIT N | umbe | r<br>- | | 31 | 30 29 | 9 28 | 27 | 26 2 | 25 2 | 24 2 | 3 22 | 2 21 | 20 | 19 . | 18 1 | . / 1 | 5 15 | 14 | 13. | 12 1. | 1 10 | 9 | 8 | / | 6 | 5 4 | 4 3 | 2 | 1 | U | | ID | | | | Ε | E E | Е | D | D | D I | D ( | С | С | С | С | С | C E | В | В | В | | | | | Α. | A , | A A | A А | Α | Α | Α | | Rese | t 0x0 | 2880000 | | 0 | 0 0 | 0 | 0 | 0 | 1 ( | 0 1 | ١ ٥ | 0 | 0 | 1 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | R | APID | | | | | | | | Α | P id | lenti | ifica | ation | ı | | | | | | | | | | | | | | | | | В | R | CLASS | | | | | | | | Α | cce | ss p | ort | (AP | ) cla | iss | | | | | | | | | | | | | | | | | | | NotDefined | 0x0 | ) | | | | | Ν | lo d | efin | ed ( | class | 5 | | | | | | | | | | | | | | | | | | | | MEMAP | 0x8 | 3 | | | | | Ν | 1em | ory | acc | ess | poi | rt | | | | | | | | | | | | | | | | С | R | JEP106ID | | | | | | | | JI | EDE | C JE | P10 | )6 id | ent | ity | code | 9 | | | | | | | | | | | | | | D | R | JEP106CONT | | | | | | | | JI | EDE | C JE | P10 | )6 cc | onti | nua | tion | co | de | | | | | | | | | | | | | E | R | REVISION | | | | | | | | R | evis | ion | | | | | | | | | | | | | | | | | | | #### 4.8.2.2 Electrical specification #### 4.8.2.2.1 Control access port | Symbol | Description | | Min. | Тур. | Max. | Units | |---------------------|---------------------------------------------------|-----|-------|------|------|-------| | R <sub>pull</sub> | Internal SWDIO and SWDCLK pull up/down resistance | XIO | | 13 | | kΩ | | f <sub>SWDCLK</sub> | SWDCLK frequency | | 0.125 | | 8 | MHz | ### 4.8.3 Debug interface mode Before an external debugger can access either CPU's access port (AHB-AP) or the control access port (CTRL-AP), the debugger must first request the device to power up via CxxxPWRUPREQ in the SWJ-DP. If the device is in System OFF when power is requested via CxxxPWRUPREQ, the system will wake up and the DIF flag in RESETREAS on page 56 will be set. The device is in the debug interface mode as long as the debugger is requesting power via CxxxPWRUPREQ. Once the debugger stops requesting power via CxxxPWRUPREQ, the device is back in normal mode. Some peripherals behave differently in Debug Interface mode compared to normal mode. These differences are described in more detail in the chapters of the peripherals that are affected. When a debug session is over, the external debugger must make sure to put the device back into normal mode since the overall power consumption is higher in debug interface mode than in normal mode. For details on how to use the debug capabilities, read the debug documentation of your IDE. ## 4.8.4 Real-time debug The nRF52805 supports real-time debugging. Real-time debugging allows interrupts to execute to completion in real time when breakpoints are set in thread mode or lower priority interrupts. This enables developers to set breakpoints and single-step through the code without the risk of real-time event-driven threads running at higher priority failing. For example, this enables the device to continue to service the high-priority interrupts of an external controller or sensor without failure or loss of state synchronization while the developer steps through code in a low-priority thread. # 5 Power and clock management ## 5.1 Power management unit (PMU) Power and clock management in nRF52805 is designed to automatically ensure maximum power efficiency. The core of the power and clock management system is the power management unit (PMU) illustrated in Power management unit on page 41. Figure 8: Power management unit The PMU automatically detects which power and clock resources are required by the different components in the system at any given time. It will then start/stop and choose operation modes in supply regulators and clock sources, without user interaction, to achieve the lowest power consumption possible. ## 5.2 Current consumption As the system is being constantly tuned by the Power management unit (PMU) on page 41, estimating the current consumption of an application can be challenging if the designer is not able to perform measurements directly on the hardware. To facilitate the estimation process, a set of current consumption scenarios are provided to show the typical current drawn from the VDD supply. Each scenario specifies a set of operations and conditions applying to the given scenario. Current consumption scenarios, common conditions on page 42 shows a set of common conditions used in all scenarios, unless otherwise stated in the description of a given scenario. All scenarios are listed in Electrical specification on page 42. | Condition | Value | |-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | VDD | 3 V | | Temperature | 25°C | | CPU | WFI (wait for interrupt)/WFE (wait for event) sleep | | Peripherals | All idle | | Clock | Not running | | Regulator | LDO | | RAM | Full 24 kB retention | | Compiler <sup>3</sup> | GCC v4.9.3 20150529 (arm-none-eabi-gcc). Compiler flags: -O0 -falign-functions=16 -fno-strict-aliasing -mcpu=cortex-m4 -mfloat-abi=soft -msoft-float -mthumb. | | 32 MHz crystal <sup>4</sup> | SMD 2520, 32 MHz, 10 pF +/- 10 ppm | Table 14: Current consumption scenarios, common conditions ## 5.2.1 Electrical specification ## 5.2.1.1 CPU running | Symbol | Description Min. | Тур. | Max. Units | | |-------------------|---------------------------------------------------------|------|------------|--| | I <sub>CPU0</sub> | CPU running CoreMark @64 MHz from flash, Clock = HFXO, | 2.2 | mA | | | | Regulator = DCDC | | | | | I <sub>CPU1</sub> | CPU running CoreMark @64 MHz from flash, Clock = HFXO | 4.2 | mA | | | I <sub>CPU2</sub> | CPU running CoreMark @64 MHz from RAM, Clock = HFXO, | 2.1 | mA | | | | Regulator = DCDC | | | | | I <sub>CPU3</sub> | CPU running CoreMark @64 MHz from RAM, Clock = HFXO | 4 | mA | | | I <sub>CPU4</sub> | CPU running CoreMark @64 MHz from flash, Clock = HFINT, | 2 | mA | | | | Regulator = DCDC | | | | Applying only when CPU is running Applying only when HFXO is running ## 5.2.1.2 Radio transmitting/receiving | Symbol | Description | | Min. | Тур. | Max. | Units | |------------------------|------------------------------------------------------|------|------|------|------|-------| | I <sub>RADIO_TX0</sub> | Radio transmitting @ 4 dBm output power, 1 Mbps | | | 8 | | mA | | | Bluetooth low energy mode, Clock = HFXO, Regulator = | | | | | | | | DCDC | | | | | | | I <sub>RADIO_TX1</sub> | Radio transmitting @ 0 dBm output power, 1 Mbps | | | 5.8 | | mA | | | Bluetooth low energy mode, Clock = HFXO, Regulator = | | | | | | | | DCDC | | | | | | | I <sub>RADIO_TX2</sub> | Radio transmitting @ -40 dBm output power, 1 Mbps | | | 3.4 | | mA | | | Bluetooth low energy mode, Clock = HFXO, Regulator = | | | | | | | | DCDC | | | | | | | I <sub>RADIO_RX0</sub> | Radio receiving @ 1 Mbps Bluetooth low energy mode, | | | 6.1 | | mA | | | Clock = HFXO, Regulator = DCDC | | | | | | | I <sub>RADIO_TX3</sub> | Radio transmitting @ 0 dBm output power, 1 Mbps | | | 10.5 | | mA | | | Bluetooth low energy mode, Clock = HFXO | • (A | | | | | | I <sub>RADIO_TX4</sub> | Radio transmitting @ -40 dBm output power, 1 Mbps | | | 5.1 | | mA | | | Bluetooth low energy mode, Clock = HFXO | XIO | | | | | | I <sub>RADIO_RX1</sub> | Radio receiving @ 1 Mbps Bluetooth low energy mode, | | | 10.8 | | mA | | | Clock = HFXO | | | | | | Figure 9: Radio transmitting @ 4 dBm output power, 1 Mbps Bluetooth low energy mode, Clock = HFXO, Regulator = DCDC (typical values) Figure 10: Radio transmitting @ 0 dBm output power, 1 Mbps Bluetooth low energy mode, Clock = HFXO, Regulator = DCDC (typical values) ## 5.2.1.3 Sleep | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------------------|---------------------------------------------------------------------------------------|------|------|------|-------| | I <sub>ON_RAMOFF_EVENT</sub> | System ON, No RAM retention, Wake on any event | | 0.6 | | μА | | I <sub>ON_RAMON_EVENT</sub> | System ON, Full 24 kB RAM retention, Wake on any event | | 0.8 | | μΑ | | I <sub>ON_RAMON_POF</sub> | System ON, Full 24 kB RAM retention, Wake on any event, Power fail comparator enabled | | 0.8 | | μΑ | | I <sub>ON_RAMON_GPIOTE</sub> | System ON, Full 24 kB RAM retention, Wake on GPIOTE input (Event mode) | | 3.3 | | μΑ | | I <sub>ON_RAMON_GPIOTEPOR</sub> | <sub>T</sub> System ON, Full 24 kB RAM retention, Wake on GPIOTE<br>PORT event | | 0.8 | | μΑ | | I <sub>ON_RAMON_RTC</sub> | System ON, Full 24 kB RAM retention, Wake on RTC (running from LFRC clock) | | 1.5 | | μΑ | | I <sub>ON_RAMOFF_RTC</sub> | System ON, No RAM retention, Wake on RTC (running from LFRC clock) | | 1.4 | | μΑ | | I <sub>ON_RAMON_RTC_LFXO</sub> | System ON, Full 24 kB RAM retention, Wake on RTC (running from LFXO clock) | | 1.1 | | μΑ | | I <sub>ON_RAMOFF_RTC_LFXO</sub> | System ON, No RAM retention, Wake on RTC (running from LFXO clock) | | 1.0 | | μΑ | | I <sub>OFF_RAMOFF_RESET</sub> | System OFF, No RAM retention, Wake on reset | | 0.3 | | μΑ | | I <sub>OFF_RAMON_RESET</sub> | System OFF, Full 24 kB RAM retention, Wake on reset | | 0.5 | | μΑ | Figure 11: System OFF, No RAM retention, Wake on reset (typical values) Figure 12: System ON, Full 24 kB RAM retention, Wake on any event (typical values) ## 5.2.1.4 Compounded | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------|---------------------------------------------------------|------|------|------|-------| | I <sub>SO</sub> | CPU running CoreMark from flash, Radio transmitting @ 0 | | 7.4 | | mA | | | dBm output power, 1 Mbps Bluetooth low energy mode, | | | | | | | Clock = HFXO, Regulator = DCDC | | | | | | I <sub>S1</sub> | CPU running CoreMark from flash, Radio receiving @ 1 | | 7.6 | | mA | | | Mbps Bluetooth low energy mode, Clock = HFXO, Regulator | | | | | | | = DCDC | | | | | | I <sub>S2</sub> | CPU running CoreMark from flash, Radio transmitting @ 0 | | 13.8 | | mA | | | dBm output power, 1 Mbps Bluetooth low energy mode, | | | | | | | Clock = HFXO | | | | | | I <sub>S3</sub> | CPU running CoreMark from flash, Radio receiving @ 1 | | 14.2 | | mA | | | Mbps Bluetooth low energy mode, Clock = HFXO | | | | | ### 5.2.1.5 TIMER running | Symbol | Description | ~ | | Min. | Тур. | Max. | Units | |---------------------|----------------------------------------------------|---|---|------|------|------|-------| | I <sub>TIMERO</sub> | One TIMER instance running @ 1 MHz, Clock = HFINT | | | | 432 | | μΑ | | I <sub>TIMER1</sub> | Two TIMER instances running @ 1 MHz, Clock = HFINT | | | | 432 | | μΑ | | I <sub>TIMER2</sub> | One TIMER instance running @ 1 MHz, Clock = HFXO | | | | 730 | | μΑ | | I <sub>TIMER3</sub> | One TIMER instance running @ 16 MHz, Clock = HFINT | | | | 495 | | μΑ | | I <sub>TIMER4</sub> | One TIMER instance running @ 16 MHz, Clock = HFXO | , | 4 | | 792 | | μΑ | ## 5.2.1.6 RNG active | Symbol | Description | | | Min. | Тур. | Max. | Units | |-------------------|-------------|--|--|------|------|------|-------| | I <sub>RNG0</sub> | RNG running | | | | 539 | | μΑ | #### 5 2 1 7 TEMP active | Symbol | Description | | Min. | Тур. | Max. | Units | |--------------------|--------------|--|------|------|------|-------| | I <sub>TEMPO</sub> | TEMP started | | | 998 | | μΑ | ## 5.2.1.8 SAADC active | Symbol | Description | Min. | Тур. | Max. | Units | |------------------------|------------------------------------------------------------------|------|------|------|-------| | I <sub>SAADC,RUN</sub> | SAADC sampling @ 16 ksps, Acquisition time = 20 $\mu$ s, Clock = | | 1.1 | | mA | | | HFXO. Regulator = DCDC | | | | | #### 5.2.1.9 WDT active | Symbol | Description | Min. | Тур. | Max. | Units | |--------------------------|-------------|------|------|------|-------| | I <sub>WDT,STARTED</sub> | WDT started | | 1.3 | | μΑ | ## 5.3 POWER — Power supply This device has the following power supply features: - On-chip LDO and DC/DC regulators - Global System ON/OFF modes with individual RAM section power control - Analog or digital pin wakeup from System OFF - Supervisor HW to manage power on reset, brownout, and power fail - Auto-controlled refresh modes for LDO and DC/DC regulators to maximize efficiency - Automatic switching between LDO and DC/DC regulator based on load to maximize efficiency Note: Two additional external passive components are required to use the DC/DC regulator. ## 5.3.1 Regulators The following internal power regulator alternatives are supported: - Internal LDO regulator - Internal DC/DC regulator The LDO is the default regulator. The DC/DC regulator can be used as an alternative to the LDO regulator and is enabled through the DCDCEN on page 58 register. Using the DC/DC regulator will reduce current consumption compared to when using the LDO regulator, but the DC/DC regulator requires an external LC filter to be connected, as shown in DC/DC regulator setup on page 48. Figure 13: LDO regulator setup Figure 14: DC/DC regulator setup #### 5.3.2 System OFF mode System OFF is the deepest power saving mode the system can enter. In this mode, the system's core functionality is powered down and all ongoing tasks are terminated. The device can be put into System OFF mode using the register SYSTEMOFF on page 56. When in System OFF mode, the device can be woken up through one of the following signals: - 1. The DETECT signal, optionally generated by the GPIO peripheral - 2 Δ reset When the system wakes up from System OFF mode, it gets reset. For more details, see Reset behavior on page 52. One or more RAM sections can be retained in System OFF mode, depending on the settings in the RAM[n].POWER registers. RAM[n].POWER are retained registers, see Reset behavior. Note that these registers are usually overwritten by the startup code provided with the nRF application examples. Before entering System OFF mode, the user must make sure that all on-going EasyDMA transactions have been completed. This is usually accomplished by making sure that the EasyDMA enabled peripheral is not active when entering System OFF. #### 5.3.2.1 Emulated System OFF mode If the device is in debug interface mode, System OFF will be emulated to secure that all required resources needed for debugging are available during System OFF. See Debug on page 37 for more information. Required resources needed for debugging include the following key components: Debug on page 37, CLOCK — Clock control on page 60, POWER — Power supply on page 46, NVMC — Non-volatile memory controller on page 18, CPU, Flash, and RAM. Since the CPU is kept on in an emulated System OFF mode, it is recommended to add an infinite loop directly after entering System OFF, to prevent the CPU from executing code that normally should not be executed. #### 5.3.3 System ON mode System ON is the default state after power-on reset. In System ON, all functional blocks such as the CPU or peripherals can be in IDLE or RUN mode, depending on the configuration set by the software and the state of the application executing. Register RESETREAS on page 56 provides information about the source causing the wakeup or reset. The system can switch the appropriate internal power sources on and off, depending on how much power is needed at any given time. The power requirement of a peripheral is directly related to its activity level, and the activity level of a peripheral is usually raised and lowered when specific tasks are triggered or events are generated. #### 5.3.3.1 Sub power modes In System ON mode, when both the CPU and all the peripherals are in IDLE mode, the system can reside in one of the two sub power modes. The sub power modes are: - Constant Latency - Low-power In Constant Latency mode, the CPU wakeup latency and the PPI task response are constant and kept at a minimum. This is secured by forcing a set of basic resources to be turned on while in sleep. Having a constant and predictable latency is at the cost of having increased power consumption. The Constant Latency mode is selected by triggering the CONSTLAT task. In Low-power mode, the automatic power management system described in System ON mode on page 49 ensures that the most efficient supply option is chosen to save most power. Having the lowest power possible is at the cost of having a varying CPU wakeup latency and PPI task response. The Low-power mode is selected by triggering the LOWPWR task. When the system enters System ON mode, it is by default in Low-power sub power mode. ## 5.3.4 Power supply supervisor The power supply supervisor initializes the system at power-on and provides an early warning of impending power failure. In addition, the power supply supervisor puts the system in a reset state if the supply voltage is too low for safe operation (brownout). The power supply supervisor is illustrated in Power supply supervisor on page 50. Figure 15: Power supply supervisor #### 5.3.4.1 Power-fail comparator The power-fail comparator (POF) can provide the CPU with an early warning of impending power failure. It will not reset the system, but give the CPU time to prepare for an orderly power-down. The comparator features a hysteresis of $V_{HYST}$ , as illustrated in Power-fail comparator (BOR = Brownout reset) on page 50. The threshold $V_{POF}$ is set in register POFCON on page 57. If the POF is enabled and the supply voltage falls below $V_{POF}$ , the POFWARN event will be generated. This event will also be generated if the supply voltage is already below $V_{POF}$ at the time the POF is enabled, or if $V_{POF}$ is reconfigured to a level above the supply voltage. If power-fail warning is enabled and the supply voltage is below $V_{POF}$ the power-fail comparator will prevent the NVMC from performing write operations to the NVM. See NVMC — Non-volatile memory controller on page 18 for more information about the NVMC. Figure 16: Power-fail comparator (BOR = Brownout reset) To save power, the power-fail comparator is not active in System OFF or in System ON when HFCLK is not running. #### 5.3.5 RAM power control The RAM power control registers are used for configuring the following: - The RAM sections to be retained during System OFF - The RAM sections to be retained and accessible during System ON In System OFF, retention of a RAM section is configured in the RETENTION field of the corresponding RAM[n] register. In System ON, retention and accessibility for a RAM section is configured in the RETENTION and POWER fields of the corresponding RAM[n] register. The following table summarizes the behavior of these registers. | Configuration | | RAM section status | | | | |---------------|--------------------|------------------------|------------|----------|--| | System on/off | RAM[n].POWER.POWER | RAM[n].POWER.RETENTION | Accessible | Retained | | | Off | х | Off | No | No | | | Off | х | On | No | Yes | | | On | Off | Off | No | No | | | On | Off <sup>1</sup> | On | No | Yes | | | On | On | x | Yes | Yes | | Table 15: RAM section configuration. x = don't care The advantage of not retaining RAM contents is that the overall current consumption is reduced. See chapter Memory on page 15 for more information on RAM sections. #### 5.3.6 Reset There are multiple sources that may trigger a reset. After a reset has occurred, register RESETREAS can be read to determine which source generated the reset. #### 5.3.6.1 Power-on reset The power-on reset generator initializes the system at power-on. The system is held in reset state until the supply has reached the minimum operating voltage and the internal voltage regulators have started. A step increase in supply voltage of 300 mV or more, with rise time of 300 ms or less, within the valid supply range, may result in a system reset. #### 5.3.6.2 Pin reset A pin reset is generated when the physical reset pin on the device is asserted. Pin reset is configured via the PSELRESET[n] registers. **Note:** Pin reset is not available on all pins. #### 5.3.6.3 Wakeup from System OFF mode reset The device is reset when it wakes up from System OFF mode. <sup>&</sup>lt;sup>1</sup> Not useful setting. RAM section power off gives negligible reduction in current consumption when retention is on. The debug access port (DAP) is not reset following a wake up from System OFF mode if the device is in Debug Interface mode. See chapter Debug on page 37 for more information. #### 5.3.6.4 Soft reset A soft reset is generated when the SYSRESETREQ bit of the Application Interrupt and Reset Control Register (AIRCR register) in the ARM® core is set. Refer to ARM documentation for more details. A soft reset can also be generated via the RESET on page 38 register in the CTRL-AP. #### 5.3.6.5 Watchdog reset A Watchdog reset is generated when the watchdog times out. See chapter WDT — Watchdog timer on page 325 for more information. #### 5.3.6.6 Brown-out reset The brown-out reset generator puts the system in reset state if the supply voltage drops below the brownout reset (BOR) threshold. Refer to section Power fail comparator on page 60 for more information. #### 5.3.7 Retained registers A retained register is a register that will retain its value in System OFF mode and through a reset, depending on reset source. See individual peripheral chapters for information of which registers are retained for the various peripherals. ### 5.3.8 Reset behavior | Reset source | Reset target | | | | | | | | | |-----------------------------|--------------|-------------|------|--------------------|--------|----------------|-----|-----------|-----------| | | CPU | Peripherals | GPIO | Debug <sup>a</sup> | SWJ-DP | RAM | WDT | Retained | RESETREAS | | | | | | | | | | registers | | | CPU lockup <sup>5</sup> | х | х | х | | | | | | | | Soft reset | × | х | х | | | | | | | | Wakeup from System OFF | х | x | | x <sup>6</sup> | | x <sup>7</sup> | | | | | mode reset | | | | | | | | | | | Watchdog reset <sup>8</sup> | x | x | х | x | | х | х | х | | | Pin reset | х | х | х | x | | х | х | X | | | Brownout reset | x | x | x | х | x | x | x | x | x | | Power on reset | x | x | x | х | x | x | x | x | x | **Note:** The RAM is never reset, but depending on reset source, RAM content may be corrupted. NORD <sup>&</sup>lt;sup>a</sup> All debug components excluding SWJ-DP. See Debug on page 37 chapter for more information about the different debug components in the system. <sup>&</sup>lt;sup>5</sup> Reset from CPU lockup is disabled if the device is in debug interface mode. CPU lockup is not possible in System OFF. <sup>&</sup>lt;sup>6</sup> The Debug components will not be reset if the device is in debug interface mode. RAM is not reset on wakeup from OFF mode, but depending on settings in the RAM register parts, or the whole RAM, may not be retained after the device has entered System OFF mode. <sup>&</sup>lt;sup>8</sup> Watchdog reset is not available in System OFF. ## 5.3.9 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|---------------|-----------------------------------------| | 0x40000000 | POWER | POWER | Power control | For 24 kB RAM variant, only RAM[0].x to | | | | | | RAM[2].x registers are in use. | Table 16: Instances | Register | Offset | Description | |-------------------|--------|-------------------------------------------------------------------------------------------| | TASKS_CONSTLAT | 0x078 | Enable Constant Latency mode | | TASKS_LOWPWR | 0x07C | Enable Low-power mode (variable latency) | | EVENTS_POFWARN | 0x108 | Power failure warning | | EVENTS_SLEEPENTER | 0x114 | CPU entered WFI/WFE sleep | | EVENTS_SLEEPEXIT | 0x118 | CPU exited WFI/WFE sleep | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | RESETREAS | 0x400 | Reset reason | | SYSTEMOFF | 0x500 | System OFF register | | POFCON | 0x510 | Power failure comparator configuration | | GPREGRET | 0x51C | General purpose retention register | | GPREGRET2 | 0x520 | General purpose retention register | | DCDCEN | 0x578 | DC/DC enable register | | RAM[0].POWER | 0x900 | RAMO power control register. The RAM size will vary depending on product variant, and the | | | | RAMO register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[0].POWERSET | 0x904 | RAMO power control set register | | RAM[0].POWERCLR | 0x908 | RAM0 power control clear register | | RAM[1].POWER | 0x910 | RAM1 power control register. The RAM size will vary depending on product variant, and the | | | | RAM1 register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[1].POWERSET | 0x914 | RAM1 power control set register | | RAM[1].POWERCLR | 0x918 | RAM1 power control clear register | | RAM[2].POWER | 0x920 | RAM2 power control register. The RAM size will vary depending on product variant, and the | | | | RAM2 register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[2].POWERSET | 0x924 | RAM2 power control set register | | RAM[2].POWERCLR | 0x928 | RAM2 power control clear register | | RAM[3].POWER | 0x930 | RAM3 power control register. The RAM size will vary depending on product variant, and the | | | | RAM3 register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[3].POWERSET | 0x934 | RAM3 power control set register | | RAM[3].POWERCLR | 0x938 | RAM3 power control clear register | | RAM[4].POWER | 0x940 | RAM4 power control register. The RAM size will vary depending on product variant, and the | | | | RAM4 register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[4].POWERSET | 0x944 | RAM4 power control set register | | RAM[4].POWERCLR | 0x948 | RAM4 power control clear register | | RAM[5].POWER | 0x950 | RAM5 power control register. The RAM size will vary depending on product variant, and the | | | | RAM5 register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[5].POWERSET | 0x954 | RAM5 power control set register | | RAM[5].POWERCLR | 0x958 | RAM5 power control clear register | | Register | Offset | Description | |-----------------|--------|-------------------------------------------------------------------------------------------| | RAM[6].POWER | 0x960 | RAM6 power control register. The RAM size will vary depending on product variant, and the | | | | RAM6 register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[6].POWERSET | 0x964 | RAM6 power control set register | | RAM[6].POWERCLR | 0x968 | RAM6 power control clear register | | RAM[7].POWER | 0x970 | RAM7 power control register. The RAM size will vary depending on product variant, and the | | | | RAM7 register will only be present if the corresponding RAM AHB slave is present on the | | | | device. | | RAM[7].POWERSET | 0x974 | RAM7 power control set register | | RAM[7].POWERCLR | 0x978 | RAM7 power control clear register | Table 17: Register overview #### 5.3.9.1 TASKS\_CONSTLAT Address offset: 0x078 **Enable Constant Latency mode** #### 5.3.9.2 TASKS LOWPWR Address offset: 0x07C Enable Low-power mode (variable latency) | Bit n | umber | | 31 30 29 28 27 | 26 25 24 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------|----------|----------------|----------|------------------------------------------------------------------| | ID | | | | | A | | Rese | t 0x00000000 | | 0 0 0 0 0 | 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | Acce Field | Value ID | Value | | | | Α | W TASKS_LOWPWR | | | | Enable Low-power mode (variable latency) | | | | Trigger | 1 | | Trigger task | ## 5.3.9.3 EVENTS\_POFWARM Address offset: 0x108 Power failure warning | Bit n | umber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW EVENTS_POFWARN | | | Power failure warning | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | #### 5.3.9.4 EVENTS\_SLEEPENTER Address offset: 0x114 CPU entered WFI/WFE sleep #### 5.3.9.5 EVENTS\_SLEEPEXIT Address offset: 0x118 CPU exited WFI/WFE sleep #### **5.3.9.6 INTENSET** Address offset: 0x304 **Enable interrupt** | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | C B A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | Value ID | Value | Description | | Α | RW POFWARN | | | Write '1' to enable interrupt for event POFWARN | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW SLEEPENTER | | | Write '1' to enable interrupt for event SLEEPENTER | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW SLEEPEXIT | | | Write '1' to enable interrupt for event SLEEPEXIT | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | #### **5.3.9.7 INTENCLR** Address offset: 0x308 Disable interrupt | Bit r | umber | | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------------------|-----------------------------------------------------------------------| | ID | | | | СВА | | Res | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | Description | | Α | RW POFWARN | | | Write '1' to disable interrupt for event POFWARN | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW SLEEPENTER | | | Write '1' to disable interrupt for event SLEEPENTER | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW SLEEPEXIT | | | Write '1' to disable interrupt for event SLEEPEXIT | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | #### **5.3.9.8 RESETREAS** Address offset: 0x400 Reset reason Unless cleared, the RESETREAS register will be cumulative. A field is cleared by writing '1' to it. If none of the reset sources are flagged, this indicates that the chip was reset from the on-chip reset generator, which will indicate a power-on-reset or a brownout reset. | Bit n | umber | X | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|-------------|------------------------|-----------------------------------------------------------------| | ID | | | | F E D C B A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | Acce Field | Value ID | Value | Description | | Α | RW RESETPIN | | | Reset from pin-reset detected | | | | NotDetected | 0 | Not detected | | | | Detected | 1 | Detected | | В | RW DOG | | | Reset from watchdog detected | | | | NotDetected | 0 | Not detected | | | | Detected | 1 | Detected | | С | RW SREQ | | | Reset from soft reset detected | | | | NotDetected | 0 | Not detected | | | | Detected | 1 | Detected | | D | RW LOCKUP | | | Reset from CPU lock-up detected | | | | NotDetected | 0 | Not detected | | | | Detected | 1 | Detected | | E | RW OFF | | | Reset due to wake up from System OFF mode when wakeup | | | | | | is triggered from DETECT signal from GPIO | | | | NotDetected | 0 | Not detected | | | | Detected | 1 | Detected | | F | RW DIF | | | Reset due to wake up from System OFF mode when wakeup | | | | | | is triggered from entering into debug interface mode | | | | NotDetected | 0 | Not detected | | | | Detected | 1 | Detected | | | | | | | #### **5.3.9.9 SYSTEMOFF** Address offset: 0x500 #### System OFF register #### 5.3.9.10 POFCON Address offset: 0x510 Power failure comparator configuration | Bit r | number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | вввва | | Res | et 0x00000000 | | 0 0 0 0 0 0 0 | | | | | | Value | Description | | Α | RW POF | | | Enable or disable power failure comparator | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | В | RW THRESHOLD | • | | Power failure comparator threshold setting | | | | V17 | 4 | Set threshold to 1.7 V | | | | V18 | 5 | Set threshold to 1.8 V | | | | V19 | 6 | Set threshold to 1.9 V | | | | V20 | 7 | Set threshold to 2.0 V | | | | V21 | 8 | Set threshold to 2.1 V | | | | V22 | 9 | Set threshold to 2.2 V | | | | V23 | 10 | Set threshold to 2.3 V | | | | V24 | 11 | Set threshold to 2.4 V | | | | V25 | 12 | Set threshold to 2.5 V | | | | V26 | 13 | Set threshold to 2.6 V | | | | V27 | 14 | Set threshold to 2.7 V | | | | V28 | 15 | Set threshold to 2.8 V | | | | | | | #### **5.3.9.11 GPREGRET** Address offset: 0x51C General purpose retention register | Bit r | umber | 313 | 0 29 | 28 | 27 2 | 6 2 | 5 24 | 23 | 22 | 21 2 | 20 1 | 9 18 | 17 | 16 | 15 1 | 4 13 | 3 12 | 11 1 | 10 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 2 1 | 0 | |-------|--------------|-----|------|----|------|-----|------|----|------|-------|------|------|------|------|------|-------|------|------|------|---|---|---|---|---|-----|-----|---| | ID | | | | | | | | | | | | | | | | | | | | | Α | Α | Α | A | 4 Α | A A | Α | | Res | t 0x00000000 | 0 ( | 0 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW GPREGRET | | | | | | | Ge | ener | ral p | urp | ose | rete | ntic | n re | egist | er | | | | | | | | | | | This register is a retained register #### 5.3.9.12 GPREGRET2 Address offset: 0x520 General purpose retention register This register is a retained register #### 5.3.9.13 DCDCEN Address offset: 0x578 DC/DC enable register | Bit r | number | | 31 30 29 28 | 3 27 26 | 25 24 | 23 2 | 2 21 2 | 20 19 | 9 18 1 | 17 10 | 6 15 | 14 1 | 3 12 | 11 | 10 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | |-------|---------------|----------|-------------|---------|-------|------|---------|-------|--------|-------|------|------|------|----|------|---|---|---|---|-----|-----|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | et 0x00000000 | | 0 0 0 0 | 0 0 | 0 0 | 0 ( | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | ID | | | | | | Des | eriptic | on | | | | Ť | | | | | | | | | | | | | Α | RW DCDCEN | | | | | Enal | ble or | disa | able D | C/D | C cc | nver | er | | | | | | | | | | | | | | Disabled | 0 | | | Disa | ble | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | Enal | ble | | | | | | | | | | | | | | | | | ### 5.3.9.14 RAM[n].POWER (n=0..7) Address offset: $0x900 + (n \times 0x10)$ RAMn power control register. The RAM size will vary depending on product variant, and the RAMn register will only be present if the corresponding RAM AHB slave is present on the device. #### 5.3.9.15 RAM[n].POWERSET (n=0..7) Address offset: $0x904 + (n \times 0x10)$ RAMn power control set register 4454\_187 v0.5 When read, this register will return the value of the POWER register. | Bit nu | مطمعا | | | 21 20 20 20 27 20 25 20 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 | |---------|-------|----------------------|----|-------------------------|-----------------------------------------------------------------------------|---| | BIL III | ımbe | ···· | | 31 30 29 28 27 26 25 24 | 2 2 3 2 2 2 1 2 0 1 9 1 8 1 / 1 6 1 5 1 4 1 5 1 2 1 1 1 0 9 8 / 6 5 4 5 2 1 | U | | ID | | | | | D C | Α | | Rese | t 0x0 | 000FFFF | | 0 0 0 0 0 0 0 0 | $\begin{smallmatrix} 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 1 & 1 &$ | 1 | | ID | | | | | | | | A-B | W | S[i]POWER (i=01) | | | Keep RAM section Si of RAMn on or off in System ON mode | | | | | | On | 1 | On | | | C-D | W | S[i]RETENTION (i=01) | | | Keep retention on RAM section Si when RAM section is | | | | | | | | switched off | | | | | | On | 1 | On | | ### 5.3.9.16 RAM[n].POWERCLR (n=0..7) Address offset: $0x908 + (n \times 0x10)$ RAMn power control clear register When read, this register will return the value of the POWER register. | Bit n | umbe | er | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0 | |-------|-------|----------------------|-----|-------------------------|-----------------------------------------------------------|-------| | ID | | | | | D C | ВА | | Rese | t 0x0 | 000FFFF | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 | 1 1 1 | | ID | | | | Value | Description | | | A-B | W | S[i]POWER (i=01) | | | Keep RAM section Si of RAMn on or off in System ON mode | | | | | | Off | 1 | Off | | | C-D | W | S[i]RETENTION (i=01) | | AU | Keep retention on RAM section Si when RAM section is | | | | | | | | switched off | | | | | | Off | 1 | Off | | ## 5.3.10 Electrical specification ### 5.3.10.1 Device startup times | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------------|--------------------------------------------------------------------------|--------|------|------|-------| | t <sub>POR</sub> | Time in Power on Reset after VDD reaches 1.7 V for all | | | | | | | supply voltages and temperatures. Dependent on supply rise | | | | | | | time. <sup>9</sup> | | | | | | t <sub>POR,10us</sub> | VDD rise time 10us | | 1 | | ms | | t <sub>POR,10ms</sub> | VDD rise time 10ms | | 9 | | ms | | t <sub>POR,60ms</sub> | VDD rise time 60ms | | 23 | | ms | | t <sub>PINR</sub> | If a GPIO pin is configured as reset, the maximum time | | | | | | | taken to pull up the pin and release reset after power on | | | | | | | reset. Dependent on the pin capacitive load (C) <sup>10</sup> : t=5RC, R | | | | | | | = 13kOhm | | | | | | t <sub>PINR,500nF</sub> | C = 500nF | | | 32.5 | ms | | t <sub>PINR,10uF</sub> | C = 10uF | | | 650 | ms | | t <sub>R2ON</sub> | Time from reset to ON (CPU execute) | | | | | | t <sub>R2ON,NOTCONF</sub> | If reset pin not configured | tPOR | | | ms | | t <sub>R2ON,CONF</sub> | If reset pin configured | tPOR + | | | ms | | | | tPINR | | | | <sup>&</sup>lt;sup>9</sup> A step increase in supply voltage of 300 mV or more, with rise time of 300 ms or less, within the valid supply range, may result in a system reset. To decrease maximum time a device could hold in reset, a strong external pullup resistor can be used. | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|--------------------------------------------------------|------|--------|------|-------| | t <sub>OFF2ON</sub> | Time from OFF to CPU execute | | 16.5 | | μs | | t <sub>IDLE2CPU</sub> | Time from IDLE to CPU execute | | 3.0 | | μs | | t <sub>EVTSET,CL1</sub> | Time from HW event to PPI event in Constant Latency | | 0.0625 | | μs | | | System ON mode | | | | | | t <sub>EVTSET,CL0</sub> | Time from HW event to PPI event in Low Power System ON | | 0.0625 | | μs | | | mode | | | | | #### 5.3.10.2 Power fail comparator | Symbol | Description | | Min. | Тур. | Max. | Units | |---------------------|------------------------------------------------------------|----|------|------|------|-------| | $V_{POF}$ | Nominal power level warning thresholds (falling supply | | 1.7 | | 2.8 | V | | | voltage). Levels are configurable between Min. and Max. in | | | | | | | | 100mV increments. | | | | | | | V <sub>POFTOL</sub> | Threshold voltage tolerance | | | ±1 | ±5 | % | | $V_{POFHYST}$ | Threshold voltage hysteresis | | | 50 | | mV | | $V_{BOR,OFF}$ | Brown out reset voltage range SYSTEM OFF mode | | 1.2 | | 1.7 | V | | V <sub>BOR,ON</sub> | Brown out reset voltage range SYSTEM ON mode | 7/ | 1.48 | | 1.7 | V | ## 5.4 CLOCK — Clock control The clock control system can source the system clocks from a range of internal or external high and low frequency oscillators and distribute them to modules based upon a module's individual requirements. Clock distribution is automated and grouped independently by module to limit current consumption in unused branches of the clock tree. Listed here are the main features for CLOCK: - 64 MHz on-chip oscillator - 64 MHz crystal oscillator, using external 32 MHz crystal - 32.768 kHz +/-500 ppm RC oscillator - 32.768 kHz crystal oscillator, using external 32.768 kHz crystal - 32.768 kHz oscillator synthesized from 64 MHz oscillator - Firmware (FW) override control of oscillator activity for low latency start up - · Automatic oscillator and clock control, and distribution for ultra-low power Figure 17: Clock control #### 5.4.1 HFCLK clock controller The HFCLK clock controller provides the following clocks to the system. - HCLK64M: 64 MHz CPU clock - PCLK1M: 1 MHz peripheral clock - PCLK16M: 16 MHz peripheral clock - PCLK32M: 32 MHz peripheral clock The HFCLK controller supports the following high frequency clock (HFCLK) sources: - 64 MHz internal oscillator (HFINT) - 64 MHz crystal oscillator (HFXO) For illustration, see Clock control on page 61. When the system requests one or more clocks from the HFCLK controller, the HFCLK controller will automatically provide them. If the system does not request any clocks provided by the HFCLK controller, the controller will enter a power saving mode. These clocks are only available when the system is in ON mode. When the system enters ON mode, the internal oscillator (HFINT) clock source will automatically start to be able to provide the required HFCLK clock(s) for the system. The HFINT will be used when HFCLK is requested and HFXO has not been started. The HFXO is started by triggering the HFCLKSTART task and stopped using the HFCLKSTOP task. A HFCLKSTARTED event will be generated when the HFXO has started and its frequency is stable. The HFXO must be running to use the RADIO or the calibration mechanism associated with the 32.768 kHz RC oscillator. #### 5.4.1.1 64 MHz crystal oscillator (HFXO) The 64 MHz crystal oscillator (HFXO) is controlled by a 32 MHz external crystal NORDIC\* The crystal oscillator is designed for use with an AT-cut quartz crystal in parallel resonant mode. To achieve correct oscillation frequency, the load capacitance must match the specification in the crystal data sheet. Circuit diagram of the 64 MHz crystal oscillator on page 62 shows how the 32 MHz crystal is connected to the 64 MHz crystal oscillator. Figure 18: Circuit diagram of the 64 MHz crystal oscillator The load capacitance (CL) is the total capacitance seen by the crystal across its terminals and is given by: $$CL = \frac{(C1' \cdot C2')}{(C1' + C2')}$$ $$C1' = C1 + C_{pcb1} + C_{pin}$$ $$C2' = C2 + C_{pin} + C_{pin}$$ C1 and C2 are ceramic SMD capacitors connected between each crystal terminal and ground. For more information, see Reference circuitry on page 333. $C_{pcb1}$ and $C_{pcb2}$ are stray capacitances on the PCB. $C_{pin}$ is the pin input capacitance on the XC1 and XC2 pins. See table 64 MHz crystal oscillator (HFXO) on page 71. The load capacitors C1 and C2 should have the same value. For reliable operation, the crystal load capacitance, shunt capacitance, equivalent series resistance, and drive level must comply with the specifications in table 64 MHz crystal oscillator (HFXO) on page 71. It is recommended to use a crystal with lower than maximum load capacitance and/or shunt capacitance. A low load capacitance will reduce both start up time and current consumption. #### 5.4.2 LFCLK clock controller The system supports several low frequency clock sources. As illustrated in Clock control on page 61, the system supports the following low frequency clock sources: - 32.768 kHz RC oscillator (LFRC) - 32.768 kHz crystal oscillator (LFXO) - 32.768 kHz synthesized from HFCLK (LFSYNT) The LFCLK clock is started by first selecting the preferred clock source in register LFCLKSRC on page 70 and then triggering the LFCLKSTART task. If the LFXO is selected as the clock source, the LFCLK will initially start running from the 32.768 kHz LFRC while the LFXO is starting up and automatically switch to using the LFXO once this oscillator is running. The LFCLKSTARTED event will be generated when the LFXO has been started. NORDIC® The LFCLK clock is stopped by triggering the LFCLKSTOP task. It is not allowed to write to register LFCLKSRC on page 70 when the LFCLK is running. A LFCLKSTOP task will stop the LFCLK oscillator. However, the LFCLKSTOP task can only be triggered after the STATE field in register LFCLKSTAT on page 70 indicates a 'LFCLK running' state. The LFCLK clock controller and all of the LFCLK clock sources are always switched off when in OFF mode. #### 5.4.2.1 32.768 kHz RC oscillator (LFRC) The default source of the low frequency clock (LFCLK) is the 32.768 kHz RC oscillator (LFRC). The LFRC frequency will be affected by variation in temperature. The LFRC oscillator can be calibrated to improve accuracy by using the HFXO as a reference oscillator during calibration. See Table 32.768 kHz RC oscillator (LFRC) on page 72 for details on the default and calibrated accuracy of the LFRC oscillator. The LFRC oscillator does not require additional external components. #### 5.4.2.2 Calibrating the 32.768 kHz RC oscillator After the 32.768 kHz RC oscillator is started and running, it can be calibrated by triggering the CAL task. In this case, the HFCLK will be temporarily switched on and used as a reference. A DONE event will be generated when calibration has finished. The calibration mechanism will only work as long as HFCLK is generated from the HFCLK crystal oscillator, it is therefore necessary to explicitly start this crystal oscillator before calibration can be started, see HFCLKSTART task. It is not allowed to stop the LFRC during an ongoing calibration. #### 5.4.2.3 Calibration timer The calibration timer can be used to time the calibration interval of the 32.768 kHz RC oscillator. The calibration timer is started by triggering the CTSTART task and stopped by triggering the CTSTOP task. The calibration timer will always start counting down from the value specified in CTIV and generate a CTTO timeout event when it reaches 0. The Calibration timer will stop by itself when it reaches 0. Figure 19: Calibration timer Due to limitations in the calibration timer, only one task related to calibration, that is, CAL, CTSTART and CTSTOP, can be triggered for every period of LFCLK. #### 5.4.2.4 32.768 kHz crystal oscillator (LFXO) For higher LFCLK accuracy the low frequency crystal oscillator (LFXO) must be used. The following external clock sources are supported: - Low swing clock signal applied to the XL1 pin. The XL2 pin shall then be grounded. - Rail-to-rail clock signal applied to the XL1 pin. The XL2 pin shall then be grounded or left unconnected. The LFCLKSRC on page 70 register controls the clock source, and its allowed swing. The truth table for various situations is as follows: | SRC | EXTERNAL | BYPASS | Comment | |-----|----------|--------|----------------------------------------------------------------------------| | 0 | 0 | 0 | Normal operation, RC is source | | 0 | 0 | 1 | DO NOT USE | | 0 | 1 | Χ | DO NOT USE | | 1 | 0 | 0 | Normal XTAL operation | | 1 | 1 | 0 | Apply external low swing signal to XL1, ground XL2 | | 1 | 1 | 1 | Apply external full swing signal to XL1, leave XL2 grounded or unconnected | | 1 | 0 | 1 | DO NOT USE | | 2 | 0 | 0 | Normal operation, synth is source | | 2 | 0 | 1 | DO NOT USE | | 2 | 1 | Χ | DO NOT USE | Table 18: LFCLKSRC configuration depending on clock source To achieve correct oscillation frequency, the load capacitance must match the specification in the crystal data sheet. Circuit diagram of the 32.768 kHz crystal oscillator on page 64 shows the LFXO circuitry. Figure 20: Circuit diagram of the 32.768 kHz crystal oscillator The load capacitance (CL) is the total capacitance seen by the crystal across its terminals and is given by: $$CL = \frac{(C1' \cdot C2')}{(C1' + C2')}$$ $$C1' = C1 + C_{pcb1} + C_{pin}$$ C1 and C2 are ceramic SMD capacitors connected between each crystal terminal and ground. $C_{pcb1}$ and $C_{pcb2}$ are stray capacitances on the PCB. $C_{pin}$ is the pin input capacitance on the XC1 and XC2 pins (see 32.768 kHz crystal oscillator (LFXO) on page 72). The load capacitors C1 and C2 should have the same value. For more information, see Reference circuitry on page 333. #### 5.4.2.5 32.768 kHz synthesized from HFCLK (LFSYNT) LFCLK can also be synthesized from the HFCLK clock source. The accuracy of LFCLK will then be the accuracy of the HFCLK. Using the LFSYNT clock avoids the requirement for a 32.768 kHz crystal, but increases average power consumption as the HFCLK will need to be requested in the system. ## 5.4.3 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|---------------|---------------| | 0x40000000 | CLOCK | CLOCK | Clock control | | Table 19: Instances | Register | Offset | Description | |---------------------|--------|-------------------------------------------------------------------| | TASKS_HFCLKSTART | 0x000 | Start HFCLK crystal oscillator | | TASKS_HFCLKSTOP | 0x004 | Stop HFCLK crystal oscillator | | TASKS_LFCLKSTART | 0x008 | Start LFCLK source | | TASKS_LFCLKSTOP | 0x00C | Stop LFCLK source | | TASKS_CAL | 0x010 | Start calibration of LFRC oscillator | | TASKS_CTSTART | 0x014 | Start calibration timer | | TASKS_CTSTOP | 0x018 | Stop calibration timer | | EVENTS_HFCLKSTARTED | 0x100 | HFCLK oscillator started | | EVENTS_LFCLKSTARTED | 0x104 | LFCLK started | | EVENTS_DONE | 0x10C | Calibration of LFCLK RC oscillator complete event | | EVENTS_CTTO | 0x110 | Calibration timer timeout | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | HFCLKRUN | 0x408 | Status indicating that HFCLKSTART task has been triggered | | HFCLKSTAT | 0x40C | HFCLK status | | LFCLKRUN | 0x414 | Status indicating that LFCLKSTART task has been triggered | | LFCLKSTAT | 0x418 | LFCLK status | | LFCLKSRCCOPY | 0x41C | Copy of LFCLKSRC register, set when LFCLKSTART task was triggered | | LFCLKSRC | 0x518 | Clock source for the LFCLK | | CTIV | 0x538 | Calibration timer interval Retained | Table 20: Register overview ## 5.4.3.1 TASKS\_HFCLKSTART Address offset: 0x000 Start HFCLK crystal oscillator | Bit n | umber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------------|---------|-------------------------|---------------------------------------------------------------| | ID | | | | A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | W TASKS_HFCLKSTART | | | Start HFCLK crystal oscillator | | | | Trigger | 1 | Trigger task | #### 5.4.3.2 TASKS\_HFCLKSTOP Address offset: 0x004 Stop HFCLK crystal oscillator | | | _ | Trigger | 1 | Trigger task | |-------|--------|-----------------|---------|----------------------|------------------------------------------------------------------| | Α | w | TASKS_HFCLKSTOP | | | Stop HFCLK crystal oscillator | | ID | | | | | | | Res | et 0x( | 00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | A | | Bit r | numb | er | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | #### 5.4.3.3 TASKS\_LFCLKSTART Address offset: 0x008 Start LFCLK source | Bit r | number | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------------|---------|----------------------|------------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_LFCLKSTART | | | Start LFCLK source | | | | Trigger | 1 | Trigger task | ### 5.4.3.4 TASKS\_LFCLKSTOP Address offset: 0x00C Stop LFCLK source ### 5.4.3.5 TASKS\_CAL Address offset: 0x010 Start calibration of LFRC oscillator | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|---------|-------------------------|-----------------------------------------------------------------| | ID | | | | А | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_CAL | | | Start calibration of LFRC oscillator | | | | Trigger | 1 | Trigger task | #### 5.4.3.6 TASKS\_CTSTART Address offset: 0x014 Start calibration timer | Bit n | umber | | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | |-------|-----------------|---------|------------------|---------------------------------------------------------------------| | ID | | | | | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | W TASKS_CTSTART | | | Start calibration timer | | | | Trigger | 1 | Trigger task | #### 5.4.3.7 TASKS\_CTSTOP Address offset: 0x018 Stop calibration timer | Bit n | number | | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------|---------|------------------|-----------------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_CTSTOP | | | Stop calibration timer | | | | Trigger | 1 | Trigger task | ### 5.4.3.8 EVENTS\_HFCLKSTARTED Address offset: 0x100 HFCLK oscillator started #### 5.4.3.9 EVENTS LFCLKSTARTED Address offset: 0x104 LFCLK started #### **5.4.3.10 EVENTS DONE** Address offset: 0x10C Calibration of LFCLK RC oscillator complete event | Bit number | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|----------------------|--------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW EVENTS_DONE | | | Calibration of LFCLK RC oscillator complete event | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | ## 5.4.3.11 EVENTS\_CTTO Address offset: 0x110 Calibration timer timeout | Bit number | | 31 30 29 2 | 28 27 26 25 | 24 23 22 | 21 20 1 | 9 18 1 | 7 16 19 | 5 14 1 | 3 12 1 | 1 10 9 | 8 | 7 6 | 5 | 4 | 3 2 | 1 0 | |------------------|--------------|------------|-------------|----------|-----------|---------|---------|--------|--------|--------|---|-----|---|-----|-----|-----| | ID | | | | | | | | | | | | | | | | А | | Reset 0x00000000 | | 0 0 0 | 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 ( | 0 | 0 0 | | ID Acce Field | | | | Descr | iption | | // | | | | | | | | | | | A RW EVENTS_C | тто | | | Calibr | ation tir | ner tir | neout | | | | | | | | | | | | NotGenerated | 0 | | Event | not gen | erated | l | | | | | | | | | | | | Generated | 1 | 4 | Event | generat | ed | | | | 3 | | | | | | | #### 5.4.3.12 INTENSET Address offset: 0x304 Enable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | D C B A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | | | ID | Acce Field | Value ID | Value | Description | | Α | RW HFCLKSTARTED | | | Write '1' to enable interrupt for event HFCLKSTARTED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW LFCLKSTARTED | | | Write '1' to enable interrupt for event LFCLKSTARTED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW DONE | | | Write '1' to enable interrupt for event DONE | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW CTTO | | | Write '1' to enable interrupt for event CTTO | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | #### **5.4.3.13 INTENCLR** Address offset: 0x308 Disable interrupt | Bit n | umber | | 31 30 29 28 2 | 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | |-------|-------------------|----------|---------------|-------------|-----------------------------------------------------------------|--|--|--| | ID | | | | | D C B A | | | | | Rese | t 0x00000000 | | 0 0 0 0 | 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | | Description | | | | | Α | RW HFCLKSTARTED | | | | Write '1' to disable interrupt for event HFCLKSTARTED | | | | | | | Clear | 1 | | Disable | | | | | | | Disabled | 0 | | Read: Disabled | | | | | | | Enabled | 1 | | Read: Enabled | | | | | В | B RW LFCLKSTARTED | | | | Write '1' to disable interrupt for event LFCLKSTARTED | | | | | | | Clear | 1 | | Disable | | | | | | | Disabled | 0 | | Read: Disabled | | | | | | | Enabled | 1 | | Read: Enabled | | | | | С | RW DONE | | | | Write '1' to disable interrupt for event DONE | | | | | | | Clear | 1 | | Disable | | | | | | | Disabled | 0 | | Read: Disabled | | | | | | | Enabled | 1 | | Read: Enabled | | | | | D | RW CTTO | | | | Write '1' to disable interrupt for event CTTO | | | | | | | Clear | 1 | | Disable | | | | | | | Disabled | 0 | | Read: Disabled | | | | | | | Enabled | 1 | | Read: Enabled | | | | #### 5.4.3.14 HFCLKRUN Address offset: 0x408 Status indicating that HFCLKSTART task has been triggered #### 5.4.3.15 HFCLKSTAT Address offset: 0x40C **HFCLK** status | Bit numb | er | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |----------|----------|------------|-------------------------|-----------------------------------------------------------------| | ID | | | | В | | Reset 0x | 00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Ac | | | | Description | | A R | SRC | | | Source of HFCLK | | | | RC | 0 | 64 MHz internal oscillator (HFINT) | | | | Xtal | 1 | 64 MHz crystal oscillator (HFXO) | | B R | STATE | | | HFCLK state | | | | NotRunning | 0 | HFCLK not running | | | | Running | 1 | HFCLK running | #### 5.4.3.16 LFCLKRUN Address offset: 0x414 #### Status indicating that LFCLKSTART task has been triggered #### 5.4.3.17 LFCLKSTAT Address offset: 0x418 LFCLK status #### 5.4.3.18 LFCLKSRCCOPY Address offset: 0x41C Copy of LFCLKSRC register, set when LFCLKSTART task was triggered #### 5.4.3.19 LFCLKSRC Address offset: 0x518 Clock source for the LFCLK | Bit r | number | | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|---------------------|---------------------------------------------------------------------| | ID | | | | C B A A | | Res | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | Α | RW SRC | | | Clock source | | | | RC | 0 | 32.768 kHz RC oscillator | | | | Xtal | 1 | 32.768 kHz crystal oscillator | | | | Synth | 2 | 32.768 kHz synthesized from HFCLK | | В | RW BYPASS | | | Enable or disable bypass of LFCLK crystal oscillator with | | | | | | external clock source | | | | Disabled | 0 | Disable (use with Xtal or low-swing external source) | | | | Enabled | 1 | Enable (use with rail-to-rail external source) | | С | RW EXTERNAL | | | Enable or disable external source for LFCLK | | | | Disabled | 0 | Disable external source (use with Xtal) | | | | Enabled | 1 | Enable use of external source instead of Xtal (SRC needs to | | | | | | be set to Xtal) | ## 5.4.3.20 CTIV ( Retained ) Address offset: 0x538 This register is a retained register Calibration timer interval ## 5.4.4 Electrical specification ## 5.4.4.1 64 MHz internal oscillator (HFINT) | Symbol | Description | Min. | Тур. | Max. | Units | |--------------------------|--------------------------|------|-------|------|-------| | f <sub>NOM_HFINT</sub> | Nominal output frequency | | 64 | | MHz | | f <sub>TOL_HFINT</sub> | Frequency tolerance | | <±1.5 | <±8 | % | | t <sub>START_HFINT</sub> | Startup time | | 3 | | us | ## 5.4.4.2 64 MHz crystal oscillator (HFXO) | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------------|---------------------------------------------------------|------|------|------|-------| | f <sub>NOM_HFXO</sub> | Nominal output frequency | | 64 | | MHz | | f <sub>XTAL_HFXO</sub> | External crystal frequency | | 32 | | MHz | | $f_{TOL\_HFXO}$ | Frequency tolerance requirement for 2.4 GHz proprietary | | | ±60 | ppm | | | radio applications | | | | | | f <sub>TOL_HFXO_BLE</sub> | Frequency tolerance requirement, Bluetooth low energy | | | ±40 | ppm | | | applications | | | | | | $C_{L\_HFXO}$ | Load capacitance | | | 12 | pF | | C <sub>0_HFXO</sub> | Shunt capacitance | | | 7 | pF | | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|----------------------------------------|------|------|------|-------| | R <sub>S_HFXO_7PF</sub> | Equivalent series resistance C0 = 7 pF | | | 60 | ohm | | R <sub>S_HFXO_5PF</sub> | Equivalent series resistance C0 = 5 pF | | | 60 | ohm | | R <sub>S_HFXO_3PF</sub> | Equivalent series resistance C0 = 3 pF | | | 100 | ohm | | P <sub>D_HFXO</sub> | Drive level | | | 100 | uW | | C <sub>PIN_HFXO</sub> | Input capacitance XC1 and XC2 | | 4 | | pF | | t <sub>START_HFXO</sub> | Startup time | | 0.36 | | ms | #### 5.4.4.3 32.768 kHz RC oscillator (LFRC) | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|--------------------------------------------------------------|------|--------|------|-------| | f <sub>NOM_LFRC</sub> | Nominal frequency | | 32.768 | | kHz | | $f_{TOL\_LFRC}$ | Frequency tolerance | | | ±2 | % | | $f_{TOL\_CAL\_LFRC}$ | Frequency tolerance for LFRC after calibration <sup>11</sup> | | | ±500 | ppm | | t <sub>START_LFRC</sub> | Startup time for 32.768 kHz RC oscillator | | 600 | | us | ## 5.4.4.4 32.768 kHz crystal oscillator (LFXO) | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------------|------------------------------------------------------------|------|--------|------|-------| | $f_{NOM\_LFXO}$ | Crystal frequency | | 32.768 | | kHz | | f <sub>TOL_LFXO_BLE</sub> | Frequency tolerance requirement for BLE stack | | | ±250 | ppm | | $f_{TOL\_LFXO\_ANT}$ | Frequency tolerance requirement for ANT stack | | | ±50 | ppm | | C <sub>L_LFXO</sub> | Load capacitance | | | 12.5 | pF | | C <sub>0_LFXO</sub> | Shunt capacitance | | | 2 | pF | | R <sub>S_LFXO</sub> | Equivalent series resistance | | | 100 | kohm | | $P_{D\_LFXO}$ | Drive level | | | 0.5 | uW | | C <sub>pin</sub> | Input capacitance on XL1 and XL2 pads | | 4 | | pF | | t <sub>START_LFXO</sub> | Startup time for 32.768 kHz crystal oscillator | | 0.25 | | S | | $V_{AMP\_IN\_XO\_LOW}$ | Peak to peak amplitude for external low swing clock. Input | 200 | | 1000 | mV | | | signal must not swing outside supply rails. | | | | | # 5.4.4.5 32.768 kHz synthesized from HFCLK (LFSYNT) | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------------|-------------------------------------------------------|------|--------|------|-------| | f <sub>NOM_LFSYNT</sub> | Nominal frequency | | 32.768 | | kHz | | f <sub>TOL_LFSYNT</sub> | Frequency tolerance in addition to HFLCK tolerance 12 | | 8 | | ppm | | t <sub>START_LFSYNT</sub> | Startup time for synthesized 32.768 kHz | | 100 | | us | Constant temperature within $\pm 0.5$ °C and calibration performed at least every 8 seconds, defined as 3 $$^{12}$$ Frequency tolerance will be derived from the HFCLK source clock plus the LFSYNT tolerance # 6 Peripherals # 6.1 Peripheral interface Peripherals are controlled by the CPU by writing to configuration registers and task registers. Peripheral events are indicated to the CPU by event registers and interrupts if they are configured for a given event. Figure 21: Tasks, events, shortcuts, and interrupts # 6.1.1 Peripheral ID Every peripheral is assigned a fixed block of 0x1000 bytes of address space, which is equal to 1024 x 32 bit registers. See Instantiation on page 17 for more information about which peripherals are available and where they are located in the address map. There is a direct relationship between peripheral ID and base address. For example, a peripheral with base address 0x40000000 is assigned ID=0, a peripheral with base address 0x40001000 is assigned ID=1, and a peripheral with base address 0x4001F000 is assigned ID=31. Peripherals may share the same ID, which may impose one or more of the following limitations: - Some peripherals share some registers or other common resources. - Operation is mutually exclusive. Only one of the peripherals can be used at a time. - Switching from one peripheral to another must follow a specific pattern (disable the first, then enable the second peripheral). ### 6.1.2 Peripherals with shared ID In general (with the exception of ID 0), peripherals sharing an ID and base address may not be used simultaneously. The user can only enable one peripheral at the time on this specific ID. When switching between two peripherals sharing an ID, the user should do the following to prevent unwanted behavior: - Disable the previously used peripheral. - Remove any programmable peripheral interconnect (PPI) connections set up for the peripheral that is being disabled. - Clear all bits in the INTEN register, i.e. INTENCLR = 0xFFFFFFFF. - Explicitly configure the peripheral that you are about to enable and do not rely on configuration values that may be inherited from the peripheral that was disabled. - · Enable the now configured peripheral. See which peripherals are sharing ID in Instantiation on page 17. ### 6.1.3 Peripheral registers Most peripherals feature an ENABLE register. Unless otherwise specified in the relevant chapter, the peripheral registers (in particular the PSEL registers) must be configured before enabling the peripheral. Note that the peripheral must be enabled before tasks and events can be used. #### 6.1.4 Bit set and clear Registers with multiple single-bit bit fields may implement the set-and-clear pattern. This pattern enables firmware to set and clear individual bits in a register without having to perform a read-modify-write operation on the main register. This pattern is implemented using three consecutive addresses in the register map, where the main register is followed by dedicated SET and CLR registers (in that exact order). The SET register is used to set individual bits in the main register while the CLR register is used to clear individual bits in the main register. Writing $\mathbb 1$ to a bit in SET or CLR register will set or clear the same bit in the main register respectively. Writing $\mathbb 0$ to a bit in SET or CLR register has no effect. Reading the SET or CLR register returns the value of the main register. Note: The main register may not be visible and hence not directly accessible in all cases. #### 6.1.5 Tasks Tasks are used to trigger actions in a peripheral, for example to start a particular behavior. A peripheral can implement multiple tasks with each task having a separate register in that peripheral's task register group. A task is triggered when firmware writes 1 to the task register, or when the peripheral itself or another peripheral toggles the corresponding task signal. See Tasks, events, shortcuts, and interrupts on page 73. #### 6.1.6 Events Events are used to notify peripherals and the CPU about events that have happened, for example a state change in a peripheral. A peripheral may generate multiple events with each event having a separate register in that peripheral's event register group. An event is generated when the peripheral itself toggles the corresponding event signal, and the event register is updated to reflect that the event has been generated. See Tasks, events, shortcuts, and interrupts on page 73. An event register is only cleared when firmware writes 0 to it. Events can be generated by the peripheral even when the event register is set to 1. #### 6.1.7 Shortcuts A shortcut is a direct connection between an event and a task within the same peripheral. If a shortcut is enabled, the associated task is automatically triggered when its associated event is generated. Using a shortcut is the equivalent to making the same connection outside the peripheral and through the PPI. However, the propagation delay through the shortcut is usually shorter than the propagation delay through the PPI. Shortcuts are predefined, which means their connections cannot be configured by firmware. Each shortcut can be individually enabled or disabled through the shortcut register, one bit per shortcut, giving a maximum of 32 shortcuts for each peripheral. # 6.1.8 Interrupts All peripherals support interrupts. Interrupts are generated by events. A peripheral only occupies one interrupt, and the interrupt number follows the peripheral ID. For example, the peripheral with ID=4 is connected to interrupt number 4 in the nested vectored interrupt controller (NVIC). Using the INTEN, INTENSET and INTENCLR registers, every event generated by a peripheral can be configured to generate that peripheral's interrupt. Multiple events can be enabled to generate interrupts simultaneously. To resolve the correct interrupt source, the event registers in the event group of peripheral registers will indicate the source. Some peripherals implement only INTENSET and INTENCLR registers, and the INTEN register is not available on those peripherals. See the individual peripheral chapters for details. In all cases, reading back the INTENSET or INTENCLR register returns the same information as in INTEN. Each event implemented in the peripheral is associated with a specific bit position in the INTEN, INTENSET and INTENCLR registers. The relationship between tasks, events, shortcuts, and interrupts is shown in Tasks, events, shortcuts, and interrupts on page 73. #### Interrupt clearing Clearing an interrupt by writing 0 to an event register, or disabling an interrupt using the INTENCLR register, can take up to four CPU clock cycles to take effect. This means that an interrupt may reoccur immediatelly, even if a new event has not come, if the program exits an interrupt handler after the interrupt is cleared or disabled but before four clock cycles have passed. **Note:** To avoid an interrupt reoccurring before a new event has come, the program should perform a read from one of the peripheral registers. For example, the event register that has been cleared, or the INTENCLR register that has been used to disable the interrupt. This will cause a one to three-cycle delay and ensure the interrupt is cleared before exiting the interrupt handler. Care should be taken to ensure the compiler does not remove the read operation as an optimization. If the program can guarantee a four-cycle delay after event being cleared or interrupt disabled in any other way, then a read of a register is not required. # 6.2 AAR — Accelerated address resolver Accelerated address resolver is a cryptographic support function for implementing the Resolvable Private Address Resolution Procedure described in the *Bluetooth Core specification* v4.0. Resolvable Private Address generation should be achieved using ECB and is not supported by AAR. The procedure allows two devices that share a secret key to generate and resolve a hash based on their device address. The AAR block enables real-time address resolution on incoming packets when configured as described in this chapter. This allows real-time packet filtering (whitelisting) using a list of known shared keys (Identity Resolving Keys (IRK) in *Bluetooth*). #### 6.2.1 EasyDMA The AAR implements EasyDMA for reading and writing to the RAM. The EasyDMA will have finished accessing the RAM when the END, RESOLVED, and NOTRESOLVED events are generated. If the IRKPTR on page 81, ADDRPTR on page 81, and the SCRATCHPTR on page 81 is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 15 for more information about the different memory regions. ### 6.2.2 Resolving a resolvable address As per Bluetooth specification, a private resolvable address is composed of six bytes. Figure 22: Resolvable address To resolve an address the register ADDRPTR on page 81 must point to the start of the packet. The resolver is started by triggering the START task. A RESOLVED event is generated when the AAR manages to resolve the address using one of the Identity Resolving Keys (IRK) found in the IRK data structure. The AAR will use the IRK specified in the register IRKO to IRK15 starting from IRKO. The register NIRK on page 80 specifies how many IRKs should be used. The AAR module will generate a NOTRESOLVED event if it is not able to resolve the address using the specified list of IRKs. The AAR will go through the list of available IRKs in the IRK data structure and for each IRK try to resolve the address according to the Resolvable Private Address Resolution Procedure described in the *Bluetooth Core specification* v4.0 [Vol 3] chapter 10.8.2.3. The time it takes to resolve an address varies due to the location in the list of the resolvable address. The resolution time will also be affected by RAM accesses performed by other peripherals and the CPU. See the Electrical specifications for more information about resolution time. The AAR only compares the received address to those programmed in the module without checking the address type. The AAR will stop as soon as it has managed to resolve the address, or after trying to resolve the address using NIRK number of IRKs from the IRK data structure. The AAR will generate an END event after it has stopped. Figure 23: Address resolution with packet preloaded into RAM # 6.2.3 Use case example for chaining RADIO packet reception with address resolution using AAR The AAR may be started as soon as the 6 bytes required by the AAR have been received by the RADIO and stored in RAM. The ADDRPTR pointer must point to the start of packet. Figure 24: Address resolution with packet loaded into RAM by the RADIO # 6.2.4 IRK data structure The IRK data structure is located in RAM at the memory location specified by the IRKPTR register. | Property | Address offset | | Description | |----------|----------------|-----|---------------------------| | IRKO | | 0 | IRK number 0 (16 - byte) | | IRK1 | | 16 | IRK number 1 (16 - byte) | | | | | | | IRK15 | | 240 | IRK number 15 (16 - byte) | Table 21: IRK data structure overview # 6.2.5 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|------------------------------|---------------| | 0x4000F000 | AAR | AAR | Accelerated address resolver | | Table 22: Instances | Register | Offset | Description | |-------------|--------|-----------------------------------------------------------------------------| | TASKS_START | 0x000 | Start resolving addresses based on IRKs specified in the IRK data structure | | TASKS_STOP | 0x008 | Stop resolving addresses | | EVENTS END | 0×100 | Address resolution procedure complete | | Register | Offset | Description | |--------------------|--------|-------------------------------------------------| | EVENTS_RESOLVED | 0x104 | Address resolved | | EVENTS_NOTRESOLVED | 0x108 | Address not resolved | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | STATUS | 0x400 | Resolution status | | ENABLE | 0x500 | Enable AAR | | NIRK | 0x504 | Number of IRKs | | IRKPTR | 0x508 | Pointer to IRK data structure | | ADDRPTR | 0x510 | Pointer to the resolvable address | | SCRATCHPTR | 0x514 | Pointer to data area used for temporary storage | Table 23: Register overview # 6.2.5.1 TASKS\_START Address offset: 0x000 Start resolving addresses based on IRKs specified in the IRK data structure # 6.2.5.2 TASKS\_STOP Address offset: 0x008 Stop resolving addresses | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 | |------------------|----------|-----------------------------------------------------------------------------------|-----| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 | | ID Acce Field | Value ID | Value Description | | | A W TASKS_STOP | | Stop resolving addresses | | | | Trigger | 1 Trigger task | | # 6.2.5.3 EVENTS\_END Address offset: 0x100 Address resolution procedure complete | Bit number | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW EVENTS_END | | | Address resolution procedure complete | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | # 6.2.5.4 EVENTS\_RESOLVED Address offset: 0x104 Address resolved # 6.2.5.5 EVENTS\_NOTRESOLVED Address offset: 0x108 Address not resolved #### **6.2.5.6 INTENSET** Address offset: 0x304 **Enable interrupt** | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | СВА | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | Value ID | Value | Description | | Α | RW END | | | Write '1' to enable interrupt for event END | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW RESOLVED | | | Write '1' to enable interrupt for event RESOLVED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW NOTRESOLVED | | | Write '1' to enable interrupt for event NOTRESOLVED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | #### **6.2.5.7 INTENCLR** Address offset: 0x308 Disable interrupt | Bit r | number | | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------|----------|---------------------|---------------------------------------------------------------------| | ID | | | | СВА | | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | Description | | Α | RW END | | | Write '1' to disable interrupt for event END | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW RESOLVED | | | Write '1' to disable interrupt for event RESOLVED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW NOTRESOLVED | | | Write '1' to disable interrupt for event NOTRESOLVED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | #### 6.2.5.8 STATUS Address offset: 0x400 Resolution status #### 6.2.5.9 ENABLE Address offset: 0x500 **Enable AAR** ### 6.2.5.10 NIRK Address offset: 0x504 Number of IRKs | | | | structure | |-----|---------------|----------------------|------------------------------------------------------------------| | Α | RW NIRK | [116] | Number of Identity root keys available in the IRK data | | ID | | | | | Res | et 0x00000001 | 0 0 0 0 0 0 0 | $\begin{smallmatrix} 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 $ | | ID | | | АААА | | Bit | number | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | #### 6.2.5.11 IRKPTR Address offset: 0x508 Pointer to IRK data structure #### 6.2.5.12 ADDRPTR Address offset: 0x510 Pointer to the resolvable address ### 6.2.5.13 SCRATCHPTR Address offset: 0x514 Pointer to data area used for temporary storage # 6.2.6 Electrical specification ### 6.2.6.1 AAR Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | |--------------------|---------------------------------------------------------------------|------|------|------|-------| | t <sub>AAR</sub> | Address resolution time per IRK. Total time for several IRKs | | | | μs | | | is given as (1 $\mu s$ + n * t_AAR), where n is the number of IRKs. | | | | | | | (Given priority to the actual destination RAM block). | | | | | | t <sub>AAR,8</sub> | Time for address resolution of 8 IRKs. (Given priority to the | | 48 | | μs | | | actual destination RAM block). | | | | | # 6.3 BPROT — Block protection The mechanism for protecting non-volatile memory can be used to prevent erroneous application code from erasing or writing to protected blocks. Non-volatile memory can be protected from erases and writes depending on the settings in the CONFIG registers. One bit in a CONFIG register represents one protected block of 4 kB. There are multiple CONFIG registers to cover the whole range of the flash. Protected regions of program memory on page 82 illustrates how the CONFIG bits map to the program memory space. **Important:** If an erase or write to a protected block is detected, the CPU will hard fault. If an ERASEALL operation is attempted from the CPU while any block is protected, it will be blocked and the CPU will hard fault. On reset, all the protection bits are cleared. To ensure safe operation, the first task after reset must be to set the protection bits. The only way of clearing protection bits is by resetting the device from any reset source. The protection mechanism is turned off when in debug mode (when a debugger is connected) and the DISABLEINDEBUG register is set to disabled. Figure 25: Protected regions of program memory # 6.3.1 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|---------------|---------------|--| | 0x40000000 | BPROT | BPROT | Block protect | | | Table 24: Instances | Register | Offset | Description | | |----------------|--------|--------------------------------------------|----------| | CONFIG0 | 0x600 | Block protect configuration register 0 | | | CONFIG1 | 0x604 | Block protect configuration register 1 | | | DISABLEINDEBUG | 0x608 | Disable protection mechanism in debug mode | | | UNUSED0 | 0x60C | | Reserved | Table 25: Register overview #### 6.3.1.1 CONFIGO Address offset: 0x600 Block protect configuration register 0 #### 6.3.1.2 CONFIG1 Address offset: 0x604 Block protect configuration register 1 #### 6.3.1.3 DISABLEINDEBUG Address offset: 0x608 Disable protection mechanism in debug mode | Bit n | umber | | 313 | 30 | 29 | 28 | 27 | 26 | 5 25 | 5 24 | 1 2 | 3 2 | 2 2 | 21 2 | 20 | 19 | 18 | 17 | 16 | 5 1! | 5 1 | 4 1 | 3 1 | 2 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------------------|----------|-----|----|----|----|----|----|------|------|-----|-----|-----|------|------|------|-----|------|-----|------|-----|------|-----|-----|------|------|------|------|----|------|----|---|---|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t 0x0000001 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ( | ) ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW DISABLEINDEBUG | | | | | | | | | | D | isa | ble | e th | ne į | pro | te | ctic | n r | me | cha | nis | sm | for | NV | M r | egi | ions | w | hile | in | | | | | | | | | | | | | | | | | d | eb | ug | mo | ode | e. T | his | re | gis | ter | wi | ll o | nly | dis | abl | e th | ne p | orot | ec | tior | 1 | | | | | | | | | | | | | | | | | n | nec | ha | nis | m | if t | he | de | vic | e is | in | de | bu | g m | ode | э. | | | | | | | | | | | | | Disabled | 1 | | | | | | | | D | isa | ble | ed i | in d | deb | oug | | | | | | | | | | | | | | | | | | | | | | Enabled | 0 | | | | | | | | Ε | nal | ble | d ii | n d | leb | ug | | | | | | | | | | | | | | | | | | | # 6.4 CCM — AES CCM mode encryption Cipher block chaining - message authentication code (CCM) mode is an authenticated encryption algorithm designed to provide both authentication and confidentiality during data transfer. CCM combines counter mode encryption and CBC-MAC authentication. The CCM terminology "Message authentication code (MAC)" is called the "Message integrity check (MIC)" in *Bluetooth* terminology and also in this document. The CCM block generates an encrypted keystream that is applied to input data using the XOR operation and generates the 4 byte MIC field in one operation. The CCM and radio can be configured to work synchronously. The CCM will encrypt in time for transmission and decrypt after receiving bytes into memory from the radio. All operations can complete within the packet RX or TX time. CCM on this device is implemented according to *Bluetooth* requirements and the algorithm as defined in IETF RFC3610, and depends on the AES-128 block cipher. A description of the CCM algorithm can also be found in NIST Special Publication 800-38C. The *Bluetooth* specification describes the configuration of counter mode blocks and encryption blocks to implement compliant encryption for BLE. The CCM block uses EasyDMA to load key, counter mode blocks (including the nonce required), and to read/write plain text and cipher text. The AES CCM supports three operations: key-stream generation, packet encryption, and packet decryption. All these operations are done in compliance with the *Bluetooth* specification. <sup>13</sup> Figure 26: Key-stream generation followed by encryption or decryption. The shortcut is optional. # 6.4.1 Key-steam generation A new key-stream needs to be generated before a new packet encryption or packet decryption operation can be started. A key-stream is generated by triggering the KSGEN task and an ENDKSGEN event will be generated when the key-stream has been generated. Key-stream generation, packet encryption, and packet decryption operations utilize the configuration specified in the data structure pointed to by CNFPTR on page 94. It is necessary to configure this pointer and its underlying data structure, and the MODE on page 93 register before the KSGEN task is triggered. NORDIC\* <sup>&</sup>lt;sup>13</sup> Bluetooth AES CCM 128 bit block encryption, see Bluetooth Core specification Version 4.0. The key-stream will be stored in the AES CCM's temporary memory area, specified by the SCRATCHPTR on page 94, where it will be used in subsequent encryption and decryption operations. For default length packets (MODE.LENGTH = Default) the size of the generated key-stream is 27 bytes. When using extended length packets (MODE.LENGTH = Extended) the MAXPACKETSIZE on page 95 register specifies the length of the key-stream to be generated. The length of the generated key-stream must be greater or equal to the length of the subsequent packet payload to be encrypted or decrypted. The maximum length of the key-stream in extended mode is 251 bytes, which means that the maximum packet payload size is 251. If a shortcut is used between ENDKSGEN event and CRYPT task, the INPTR on page 94 pointer and the OUTPTR on page 94 pointers must also be configured before the KSGEN task is triggered. # 6.4.2 Encryption During packet encryption, the AES CCM will read the unencrypted packet located in RAM at the address specified in the INPTR pointer, encrypt the packet and append a four byte long Message Integrity Check (MIC) field to the packet. Encryption is started by triggering the CRYPT task with the MODE on page 93 register set to ENCRYPTION. An ENDCRYPT event will be generated when packet encryption is completed The AES CCM will also modify the length field of the packet to adjust for the appended MIC field, that is, add four bytes to the length, and store the resulting packet back into RAM at the address specified in the OUTPTR on page 94 pointer, see Encryption on page 85. Empty packets (length field is set to 0) will not be encrypted but instead moved unmodified through the AES CCM. The CCM supports different widths of the LENGTH field in the data structure for encrypted packets. This is configured in the MODE on page 93 register. Figure 27: Encryption # 6.4.3 Decryption During packet decryption, the AES CCM will read the encrypted packet located in RAM at the address specified in the INPTR pointer, decrypt the packet, authenticate the packet's MIC field and generate the appropriate MIC status. Decryption is started by triggering the CRYPT task with the MODE on page 93 register set to DECRYPTION. An ENDCRYPT event will be generated when packet decryption is completed The AES CCM will also modify the length field of the packet to adjust for the MIC field, that is, subtract four bytes from the length, and then store the decrypted packet into RAM at the address pointed to by the OUTPTR pointer, see Decryption on page 86. The CCM is only able to decrypt packet payloads that are at least 5 bytes long, that is, 1 byte or more encrypted payload (EPL) and 4 bytes of MIC. The CCM will therefore generate a MIC error for packets where the length field is set to 1, 2, 3 or 4. Empty packets (length field is set to 0) will not be decrypted but instead moved unmodified through the AES CCM, these packets will always pass the MIC check. The CCM supports different widths of the LENGTH field in the data structure for decrypted packets. This is configured in the MODE on page 93 register. Figure 28: Decryption ### 6.4.4 AES CCM and RADIO concurrent operation The CCM module is able to encrypt/decrypt data synchronously to data being transmitted or received on the radio. In order for the CCM module to run synchronously with the radio, the data rate setting in the MODE on page 93 register needs to match the radio data rate. The settings in this register apply whenever either the KSGEN or CRYPT tasks are triggered. The data rate setting of the MODE on page 93 register can also be overridden on-the-fly during an ongoing encrypt/decrypt operation by the contents of the RATEOVERRIDE on page 95 register. The data rate setting in this register applies whenever the RATEOVERRIDE task is triggered. This feature can be useful in cases where the radio data rate is changed during an ongoing packet transaction. # 6.4.5 Encrypting packets on the fly in radio transmit mode When the AES CCM is encrypting a packet on-the-fly at the same time as the radio is transmitting it, the radio must read the encrypted packet from the same memory location as the AES CCM is writing to. The OUTPTR on page 94 pointer in the AES CCM must therefore point to the same memory location as the PACKETPTR pointer in the radio, see Configuration of on-the-fly encryption on page 86. Figure 29: Configuration of on-the-fly encryption In order to match the RADIO's timing, the KSGEN task must be triggered early enough to allow the keystream generation to complete before the encryption of the packet shall start. For short packets (MODE.LENGTH = Default) the KSGEN task must be triggered no later than when the START task in the RADIO is triggered. In addition the shortcut between the ENDKSGEN event and the CRYPT task must be enabled. This use-case is illustrated in On-the-fly encryption of short packets (MODE.LENGTH = Default) using a PPI connection on page 87 using a PPI connection between the READY event in the RADIO and the KSGEN task in the AES CCM. For long packets (MODE.LENGTH = Extended) the key-stream generation will need to be started even earlier, for example at the time when the TXEN task in the RADIO is triggered. NORDIC **Important:** Refer to Timing specification on page 96 for information about the time needed for generating a key-stream. Figure 30: On-the-fly encryption of short packets (MODE.LENGTH = Default) using a PPI connection # 6.4.6 Decrypting packets on-the-fly in radio receive mode When the AES CCM is decrypting a packet on-the-fly at the same time as the RADIO is receiving it, the AES CCM must read the encrypted packet from the same memory location as the RADIO is writing to. The INPTR on page 94 pointer in the AES CCM must therefore point to the same memory location as the PACKETPTR pointer in the RADIO, see Configuration of on-the-fly decryption on page 87. Figure 31: Configuration of on-the-fly decryption In order to match the RADIO's timing, the KSGEN task must be triggered early enough to allow the keystream generation to complete before the decryption of the packet shall start. For short packets (MODE.LENGTH = Default) the KSGEN task must be triggered no later than when the START task in the RADIO is triggered. In addition, the CRYPT task must be triggered no earlier than when the ADDRESS event is generated by the RADIO. If the CRYPT task is triggered exactly at the same time as the ADDRESS event is generated by the RADIO, the AES CCM will guarantee that the decryption is completed no later than when the END event in the RADIO is generated. This use-case is illustrated in On-the-fly decryption of short packets (MODE.LENGTH = Default) using a PPI connection on page 88 using a PPI connection between the ADDRESS event in the RADIO and the CRYPT task in the AES CCM. The KSGEN task is triggered from the READY event in the RADIO through a PPI connection. For long packets (MODE.LENGTH = Extended) the key-stream generation will need to be started even earlier, for example at the time when the RXEN task in the RADIO is triggered. **Important:** Refer to Timing specification on page 96 for information about the time needed for generating a key-stream. Figure 32: On-the-fly decryption of short packets (MODE.LENGTH = Default) using a PPI connection #### 6.4.7 CCM data structure The CCM data structure is located in Data RAM at the memory location specified by the CNFPTR pointer register. | Property | Address offset | Description | |----------|----------------|---------------------------------------------------------------------------------------------| | KEY | 0 | 16 byte AES key | | PKTCTR | 16 | Octet0 (LSO) of packet counter | | | 17 | Octet1 of packet counter | | | 18 | Octet2 of packet counter | | | 19 | Octet3 of packet counter | | | 20 | Bit 6 – Bit 0: Octet4 (7 most significant bits of packet counter, with Bit 6 being the most | | | | significant bit) Bit7: Ignored | | | 21 | Ignored | | | 22 | Ignored | | | 23 | Ignored | | | 24 | Bit 0: Direction bit Bit 7 – Bit 1: Zero padded | | IV | 25 | 8 byte initialization vector (IV) Octet0 (LSO) of IV, Octet1 of IV, , Octet7 (MSO) of IV | Table 26: CCM data structure overview The NONCE vector (as specified by the *Bluetooth* Core Specification) will be generated by hardware based on the information specified in the CCM data structure from CCM data structure overview on page 88. | Property | Address offset | Description | |----------|----------------|----------------------------------------| | HEADER | 0 | Packet Header | | LENGTH | 1 | Number of bytes in unencrypted payload | | RFU | 2 | Reserved Future Use | | PAYLOAD | 3 | Unencrypted payload | Table 27: Data structure for unencrypted packet | Property | Address offset | Description | |----------|--------------------|-------------------------------------------------------------------------------------------| | HEADER | 0 | Packet Header | | LENGTH | 1 | Number of bytes in encrypted payload including length of MIC | | | | Important: LENGTH will be 0 for empty packets since the MIC is not added to empty packets | | RFU | 2 | Reserved Future Use | | PAYLOAD | 3 | Encrypted payload | | MIC | 3 + payload length | ENCRYPT: 4 bytes encrypted MIC | | | | Important: MIC is not added to empty packets | Table 28: Data structure for encrypted packet # 6.4.8 EasyDMA and ERROR event The CCM implements an EasyDMA mechanism for reading and writing to the RAM. In cases where the CPU and other EasyDMA enabled peripherals are accessing the same RAM block at the same time, a high level of bus collisions may cause too slow operation for correct on the fly encryption. In this case the ERROR event will be generated. The EasyDMA will have finished accessing the RAM when the ENDKSGEN and ENDCRYPT events are generated. If the CNFPTR, SCRATCHPTR, INPTR and the OUTPTR are not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 15 for more information about the different memory regions. # 6.4.9 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|----------------------------------------------|---------------|--| | 0x4000F000 | CCM | ССМ | AES CCM mode encryption Table 29: Instances | | | | Register | Offset | Description | | |--------------------|--------|-------------------------------------------------------------------------------------------|------------| | TASKS_KSGEN | 0x000 | Start generation of key-stream. This operation will stop by itself when completed. | | | TASKS_CRYPT | 0x004 | Start encryption/decryption. This operation will stop by itself when completed. | | | TASKS_STOP | 0x008 | Stop encryption/decryption | | | TASKS_RATEOVERRIDE | 0x00C | Override DATARATE setting in MODE register with the contents of the RATEOVERRIDE register | | | | | for any ongoing encryption/decryption | | | EVENTS_ENDKSGEN | 0x100 | Key-stream generation complete | | | EVENTS_ENDCRYPT | 0x104 | Encrypt/decrypt complete | | | EVENTS_ERROR | 0x108 | CCM error event | Deprecated | | SHORTS | 0x200 | Shortcuts between local events and tasks | | | INTENSET | 0x304 | Enable interrupt | | | INTENCLR | 0x308 | Disable interrupt | | | MICSTATUS | 0x400 | MIC check result | | | ENABLE | 0x500 | Enable | | | MODE | 0x504 | Operation mode | | | CNFPTR | 0x508 | Pointer to data structure holding AES key and NONCE vector | | | INPTR | 0x50C | Input pointer | | | OUTPTR | 0x510 | Output pointer | | | SCRATCHPTR | 0x514 | Pointer to data area used for temporary storage | | | Register | Offset | Description | |---------------|--------|-------------------------------------------------------------| | MAXPACKETSIZE | 0x518 | Length of key-stream generated when MODE.LENGTH = Extended. | | RATEOVERRIDE | 0x51C | Data rate override setting. | Table 30: Register overview #### **6.4.9.1 TASKS KSGEN** Address offset: 0x000 Start generation of key-stream. This operation will stop by itself when completed. | Bit n | umber | | 31 | 30 | 29 | 28 2 | 27 2 | 26 2 | 5 2 | 4 2 | 3 2: | 2 2 | 1 2 | 0 1 | 19 : | 18 1 | .7 1 | 16 1 | 15 3 | 14 : | 13 1 | 2 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|---------------|---------|----|----|----|------|------|------|-----|-----|------|------|------------|-----|------|------|------|------|------|------|------|------|------|------|-----|-------|-----|----|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | et 0x00000000 | | 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 ( | 0 | ) ( | ) ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | W TASKS_KSGEN | | | | | | | | | S | tart | t ge | ene | rat | ior | of | ke | y-st | rea | am. | . Th | is o | pera | atio | n w | ill s | top | by | / | | | | | | | Trigger | 1 | | | | | | | | | | her<br>tas | | om | ple | ted | | | | | | | | | | | | | | | | # 6.4.9.2 TASKS\_CRYPT Address offset: 0x004 Start encryption/decryption. This operation will stop by itself when completed. Address offset: 0x008 Stop encryption/decryption | Bit number | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|----------------------|--------------------------------------------------------------------| | ID | | A | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A W TASKS_STOP | | Stop encryption/decryption | | Trigger | 1 | Trigger task | # 6.4.9.4 TASKS\_RATEOVERRIDE Address offset: 0x00C Override DATARATE setting in MODE register with the contents of the RATEOVERRIDE register for any ongoing encryption/decryption | Bit n | umber | | 31 | 30 2 | 29 2 | 8 27 | 7 26 | 25 | 24 2 | 23 2 | 22 2 | 1 2 | 0 19 | 9 18 | 17 | 16 | 15 | 14 | 13 : | 12 1 | 1 10 | 9 | 8 | 7 | 6 | 5 - | 4 3 | 2 | 1 | 0 | |-------|----------------------|---------|----|------|------|------|------|----|------|------|------|------|-------|------|------|------|-----|------|------|-------|------|-------|------|-----|-----|-----|-----|---|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t 0x00000000 | | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | W TASKS_RATEOVERRIDE | | | | | | | | ( | Ove | rrid | de D | )ATA | ARA | TE s | etti | ing | in N | MOI | DE r | egis | ter v | with | th | e | | | | | | | | | | | | | | | | ( | cont | tent | ts o | of th | e R | ATE | OVI | ERR | IDE | re | giste | r fo | r an | y oı | ngo | ing | | | | | | | | | | | | | | | | • | enci | rypt | tion | n/de | ecry | ptic | n | | | | | | | | | | | | | | | | | | Trigger | 1 | | | | | | - | Trig | ger | tas | k | | | | | | | | | | | | | | | | | | # 6.4.9.5 EVENTS\_ENDKSGEN Address offset: 0x100 Key-stream generation complete | | et 0x00000000 | | | 000 | 0 0 | | | 0 | 0 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 0 | 0 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | |-----|--------------------------------|---------------------------|-------|-----|-----|------------------|---|------|-------|------|-----|------|-----|---|-----|-----|---|---|---|-----|---|---|---| | A A | Acce Field RW EVENTS_ENDKSGEN | Value ID | Value | | | script<br>y-stre | | gene | erati | on ( | com | plet | e | | | | | | | | | | | | | | NotGenerated<br>Generated | 0 | | V | ent n | - | | | ı | | | 1 | | | | | | | | | | | # 6.4.9.6 EVENTS\_ENDCRYPT Address offset: 0x104 Encrypt/decrypt complete # 6.4.9.7 EVENTS\_ERROR ( Deprecated ) Address offset: 0x108 CCM error event | Bit n | umber | | 313 | 30 2 | 29 2 | 8 2 | 7 26 | 5 25 | 24 | 1 23 | 22 | 2 2 1 | . 20 | 19 | 18 | 17 1 | 6 1 | 5 14 | 13 | 12 | 11 1 | .0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|-----------------|--------------|-----|------|------|-----|------|------|----|------|-----|-------|-------|-----|------|------|-----|------|----|----|------|------|---|---|---|---|---|-----|------|------| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t 0x00000000 | | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW EVENTS_ERROR | | | | | | | | | CC | M | err | or e | eve | nt | | | | | | | | | | | | | Dep | orec | ated | | | | NotGenerated | 0 | | | | | | | Ev | ent | t no | ot ge | ene | rate | d | | | | | | | | | | | | | | | | | | Generated | 1 | | | | | | | Ev | ent | t ge | ner | ate | d | | | | | | | | | | | | | | | | #### 6.4.9.8 SHORTS Address offset: 0x200 Shortcuts between local events and tasks NORDIC\* | Bit number | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------------------|-------------------|---------------------------------------------------------------------| | ID | | A | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Valu | | Description | | A RW ENDKSGEN_CRYPT | | Shortcut between event ENDKSGEN and task CRYPT | | Disa | abled 0 | Disable shortcut | | Ena | bled 1 | Enable shortcut | # **6.4.9.9 INTENSET** Address offset: 0x304 Enable interrupt | Bit n | umber | | 31 30 29 28 2 | 7 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|----------|---------------|--------------------------------------------------------------------------| | ID | | | | СВА | | Rese | t 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW ENDKSGEN | | | Write '1' to enable interrupt for event ENDKSGEN | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW ENDCRYPT | | | Write '1' to enable interrupt for event ENDCRYPT | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW ERROR | | | Write '1' to enable interrupt for event ERROR Deprecated | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | | | | # 6.4.9.10 INTENCLR Address offset: 0x308 Disable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | 3 2 1 0 | |-------|--------------|----------|-------------------------|---------------------------------------------------------|------------| | ID | | | | | СВА | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 | | ID | | Value ID | | | | | Α | RW ENDKSGEN | | | Write '1' to disable interrupt for event ENDKSGEN | | | | | Clear | 1 | Disable | | | | | Disabled | 0 | Read: Disabled | | | | | Enabled | 1 | Read: Enabled | | | В | RW ENDCRYPT | | | Write '1' to disable interrupt for event ENDCRYPT | | | | | Clear | 1 | Disable | | | | | Disabled | 0 | Read: Disabled | | | | | Enabled | 1 | Read: Enabled | | | С | RW ERROR | | | Write '1' to disable interrupt for event ERROR | Deprecated | | | | Clear | 1 | Disable | | | | | Disabled | 0 | Read: Disabled | | | | | Enabled | 1 | Read: Enabled | | | | | | | | | #### 6.4.9.11 MICSTATUS Address offset: 0x400 MIC check result #### 6.4.9.12 ENABLE Address offset: 0x500 Enable ### 6.4.9.13 MODE Address offset: 0x504 Operation mode | Bit n | number | | 31 30 | 29 | 28 27 | 26 2 | 5 24 | 23 | 3 22 | 21 2 | 20 1 | 19 1 | 8 1 | 7 16 | 5 15 | 5 14 | 13 | 12 1 | 11 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|---------------|------------|----------------------------------|----|-------|------|------|----|------|--------|------|-------|------|------|------|------|-------|--------|-------|-------|------|-----|-----|-----|---|---|---|-----| | ID | | | | | | | С | | | | | | В | В | | | | | | | | | | | | | | Α | | Rese | et 0x00000001 | | 0 0 | 0 | 0 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 1 | | | | Value ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW MODE | | | | | | | Th | ne n | node | of | оре | rat | ion | to | be | use | d. Th | ie se | ttin | gs i | n t | his | | | | | | | | | | | | | | | re | gist | er ap | ppl | y wh | ien | eve | r ei | ithe | r th | e KS | GEN | l or | CR۱ | /PT | tas | sks | | | | | | | | | | | | | | ar | e tr | igge | red | ١. | | | | | | | | | | | | | | | | | | | | Encryption | 0 | | | | | ΑE | ES C | CM | pac | ket | end | ryp | tio | n m | ode | è | | | | | | | | | | | | | | Decryption | 1 AES CCM packet decryption mode | | | | | | | | | | | | | | | | | | | | | | | | | | | В | RW DATARATE | | | | | | | Ra | adic | data | a ra | te t | hat | the | e CO | CM | sha | ll ru | n syı | ıchr | one | ous | wi | th | | | | | | | | 1Mbit | 0 | | | | | 1 | Mb | ps | | | | | | | | | | | | | | | | | | | | | | 2Mbit | 1 | | | | | 2 | Mb | ps | | | | | | | | | | | | | | | | | | | | | | 125Kbps | 2 | | | | | 12 | 25 K | bps | | | | | | | | | | | | | | | | | | | | | | 500Kbps | 3 | | | | | 50 | 00 K | bps | | | | | | | | | | | | | | | | | | | | С | RW LENGTH | | | | | | | Pa | acke | et len | igth | ı coı | nfig | ura | tio | n | | | | | | | | | | | | | | | | Default | 0 | | | | | De | efau | ılt le | ngt | h. E | ffec | tive | e le | ngt | h of | LEN | IGTH | l fie | ld i | n | | | | | | | | | | | | | | | | er | ncry | pted | l/d | ecry | pte | d p | ack | et i | s 5 l | oits. | A ke | ₃y-st | trea | m | for | | | | | | | | | | | | | | | pa | acke | et pa | ylo | ads | up | to 2 | 27 k | yte | s w | ill be | e gei | nera | ted | ١. | | | | | | | #### 6.4.9.14 CNFPTR Address offset: 0x508 Pointer to data structure holding AES key and NONCE vector | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | |------------|----------------------------------------------|--------------------------------------------| | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | טו | | | | ID | | A A A A A A A A A A A A A A A | | Bit number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 | 7 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | the CCM NONCE vector (see Table 1 CCM data structure #### 6.4.9.15 INPTR Address offset: 0x50C Input pointer #### 6.4.9.16 OUTPTR Address offset: 0x510 Output pointer | Bit n | umber | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 5 24 | 23 | 3 22 | 21 | . 20 | 19 | 18 1 | 7 1 | 6 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 2 1 | 0 | |-------|--------------|----|----|----|----|----|----|----|------|----|------|------|------|------|------|-----|------|----|----|----|----|----|---|---|---|---|---|---|-----|-----|-----| | ID | | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | ΑА | . 4 | A | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | A A | 4 / | . A | | Rese | t 0x00000000 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 ( | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW OUTPTR | | | | | | | | | 0 | utpı | ut p | ooir | iter | | | | | | | | | | | | | | | | | | #### **6.4.9.17 SCRATCHPTR** Address offset: 0x514 Pointer to data area used for temporary storage | Bit number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ( | |------------------|---------------------------------------------------------------------------------------| | ID | A A A A A A A A A A A A A A A A A A A | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | A RW SCRATCHPTR | Pointer to a scratch data area used for temporary storage | | | during key-stream generation, MIC generation and | | | encryption/decryption. | | | The scratch area is used for temporary storage of data | | | during key-stream generation and encryption. | | | When MODE.LENGTH = Default, a space of 43 bytes | | | is required for this temporary storage. MODE.LENGTH | | | = Extended (16 + MAXPACKETSIZE) bytes of storage is | | | required. | #### 6.4.9.18 MAXPACKETSIZE Address offset: 0x518 Length of key-stream generated when MODE.LENGTH = Extended. # 6.4.9.19 RATEOVERRIDE Address offset: 0x51C Data rate override setting. Override value to be used instead of the setting of MODE.DATARATE. This override value applies when the RATEOVERRIDE task is triggered. | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|---------|-------------------------|-----------------------------------------------------------------| | ID | | | | A A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW RATEOVERRIDE | | | Data rate override setting. | | | | 1Mbit | 0 | 1 Mbps | | | | 2Mbit | 1 | 2 Mbps | | | | 125Kbps | 2 | 125 Kbps | | | | 500Kbps | 3 | 500 Kbps | # 6.4.10 Electrical specification #### 6.4.10.1 Timing specification | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------|-------------------------------------------------------|------|------|------|-------| | t <sub>kgen</sub> | Time needed for key-stream generation (given priority | | | | μs | | | access to destination RAM block). | | | | | # 6.5 ECB — AES electronic codebook mode encryption The AES electronic codebook mode encryption (ECB) can be used for a range of cryptographic functions like hash generation, digital signatures, and keystream generation for data encryption/decryption. The ECB encryption block supports 128 bit AES encryption (encryption only, not decryption). AES ECB operates with EasyDMA access to system Data RAM for in-place operations on cleartext and ciphertext during encryption. ECB uses the same AES core as the CCM and AAR blocks and is an asynchronous operation which may not complete if the AES core is busy. #### **AES ECB features:** - 128 bit AES encryption - Supports standard AES ECB block encryption - Memory pointer support - DMA data transfer AES ECB performs a 128 bit AES block encrypt. At the STARTECB task, data and key is loaded into the algorithm by EasyDMA. When output data has been written back to memory, the ENDECB event is triggered. AES ECB can be stopped by triggering the STOPECB task. #### 6.5.1 Shared resources The ECB, CCM, and AAR share the same AES module. The ECB will always have lowest priority and if there is a sharing conflict during encryption, the ECB operation will be aborted and an ERRORECB event will be generated. ### 6.5.2 EasyDMA The ECB implements an EasyDMA mechanism for reading and writing to the Data RAM. This DMA cannot access the program memory or any other parts of the memory area except RAM. If the ECBDATAPTR is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 15 for more information about the different memory regions. The EasyDMA will have finished accessing the Data RAM when the ENDECB or ERRORECB is generated. #### 6.5.3 FCB data structure Input to the block encrypt and output from the block encrypt are stored in the same data structure. ECBDATAPTR should point to this data structure before STARTECB is initiated. | Property | Address offset | Description | |------------|----------------|-------------------------------------| | KEY | 0 | 16 byte AES key | | CLEARTEXT | 16 | 16 byte AES cleartext input block | | CIPHERTEXT | 32 | 16 byte AES ciphertext output block | Table 31: ECB data structure overview # 6.5.4 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|-------------------------------|---------------|--| | 0x4000E000 | ECB | ECB | AES Electronic Codebook (ECB) | mode | | | | | | block encryption | | | Table 32: Instances | Register | Offset | Description | |-----------------|--------|------------------------------------------------------------------------| | TASKS_STARTECB | 0x000 | Start ECB block encrypt | | TASKS_STOPECB | 0x004 | Abort a possible executing ECB operation | | EVENTS_ENDECB | 0x100 | ECB block encrypt complete | | EVENTS_ERRORECB | 0x104 | ECB block encrypt aborted because of a STOPECB task or due to an error | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | ECBDATAPTR | 0x504 | ECB block encrypt memory pointers | Table 33: Register overview # 6.5.4.1 TASKS\_STARTECE Address offset: 0x000 Start ECB block encrypt If a crypto operation is already running in the AES core, the STARTECB task will not start a new encryption and an ERRORECB event will be triggered # 6.5.4.2 TASKS\_STOPECB Address offset: 0x004 Abort a possible executing ECB operation If a running ECB operation is aborted by STOPECB, the ERRORECB event is triggered. #### 6.5.4.3 EVENTS\_ENDECB Address offset: 0x100 ECB block encrypt complete #### 6.5.4.4 EVENTS ERRORECB Address offset: 0x104 ECB block encrypt aborted because of a STOPECB task or due to an error #### **6.5.4.5 INTENSET** Address offset: 0x304 Enable interrupt | D.: | 1 | | 24 20 20 20 27 26 25 | 5.24.22.22.24.20.40.40.47.46.45.44.42.42.44.40.00.00.7.6.5.4.2.2.2.4.0 | |-------|---------------|----------|----------------------|------------------------------------------------------------------------| | BIT N | umber | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | ID | | | | B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW ENDECB | | | Write '1' to enable interrupt for event ENDECB | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW ERRORECB | | | Write '1' to enable interrupt for event ERRORECB | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | #### **6.5.4.6 INTENCLR** Address offset: 0x308 Disable interrupt # 6.5.4.7 ECBDATAPTR Address offset: 0x504 ECB block encrypt memory pointers | Bit number | 1 | 31 | 30 2 | 9 28 | 3 27 | 7 26 | 25 | 24 | 23 : | 22 : | 21 2 | 0 19 | 18 | 17 | 16 1 | L5 1 | 4 13 | 3 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 4 | 4 3 | 2 | 1 ( | |------------------|---|-----|------|----------|------|------|----|----|------|------|------|------|----|----|------|------|------|------|----|----|---|---|---|---|-----|-----|---|-----| | ID | | Α | A A | <b>Α</b> | Α | A | Α | Α | Α | Α | Α / | 4 A | Α | Α | Α. | Α , | 4 A | . A | Α | Α | Α | Α | Α | Α | A A | Α Α | A | Α / | | Reset 0x00000000 | | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | ID Acce Field | | Val | | | | | | | | | | | | | | | | | | | | | | | | | | | A RW ECBDATAPTR Pointer to the ECB data structure (see Table 1 ECB data structure overview) # 6.5.5 Electrical specification # 6.5.5.1 ECB Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | | |------------------|-----------------------------------------|------|------|------|-------|--| | t <sub>ECB</sub> | Run time per 16 byte block in all modes | | 6 | | μs | | # 6.6 EGU — Event generator unit The Event generator unit (EGU) provides support for inter-layer signaling. This means support for atomic triggering of both CPU execution and hardware tasks from both firmware (by CPU) and hardware (by PPI). This feature can, for instance, be used for triggering CPU execution at a lower priority execution from a higher priority execution, or to handle a peripheral's ISR execution at a lower priority for some of its events. However, triggering any priority from any priority is possible. Listed here are the main EGU features: - Enables SW triggering of interrupts - Separate interrupt vectors for every EGU instance - Up to 16 separate event flags per interrupt for multiplexing Each instance of The EGU implements a set of tasks which can individually be triggered to generate the corresponding event, i.e., the corresponding event for TASKS\_TRIGGER[n] is EVENTS\_TRIGGERED[n]. Refer to Instances on page 100 for a list of the various EGU instances ### 6.6.1 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|------------------------|---------------|--| | 0x40014000 | EGU | EGU0 | Event generator unit 0 | | | | 0x40015000 | EGU | EGU1 | Event generator unit 1 | | | Table 34: Instances | Register | Offset | Description | |---------------------|--------|--------------------------------------------------------------------------| | TASKS_TRIGGER[0] | 0x000 | Trigger 0 for triggering the corresponding TRIGGERED[0] event | | TASKS_TRIGGER[1] | 0x004 | Trigger 1 for triggering the corresponding TRIGGERED[1] event | | TASKS_TRIGGER[2] | 0x008 | Trigger 2 for triggering the corresponding TRIGGERED[2] event | | TASKS_TRIGGER[3] | 0x00C | Trigger 3 for triggering the corresponding TRIGGERED[3] event | | TASKS_TRIGGER[4] | 0x010 | Trigger 4 for triggering the corresponding TRIGGERED[4] event | | TASKS_TRIGGER[5] | 0x014 | Trigger 5 for triggering the corresponding TRIGGERED[5] event | | TASKS_TRIGGER[6] | 0x018 | Trigger 6 for triggering the corresponding TRIGGERED[6] event | | TASKS_TRIGGER[7] | 0x01C | Trigger 7 for triggering the corresponding TRIGGERED[7] event | | TASKS_TRIGGER[8] | 0x020 | Trigger 8 for triggering the corresponding TRIGGERED[8] event | | TASKS_TRIGGER[9] | 0x024 | Trigger 9 for triggering the corresponding TRIGGERED[9] event | | TASKS_TRIGGER[10] | 0x028 | Trigger 10 for triggering the corresponding TRIGGERED[10] event | | TASKS_TRIGGER[11] | 0x02C | Trigger 11 for triggering the corresponding TRIGGERED[11] event | | TASKS_TRIGGER[12] | 0x030 | Trigger 12 for triggering the corresponding TRIGGERED[12] event | | TASKS_TRIGGER[13] | 0x034 | Trigger 13 for triggering the corresponding TRIGGERED[13] event | | TASKS_TRIGGER[14] | 0x038 | Trigger 14 for triggering the corresponding TRIGGERED[14] event | | TASKS_TRIGGER[15] | 0x03C | Trigger 15 for triggering the corresponding TRIGGERED[15] event | | EVENTS_TRIGGERED[0] | 0x100 | Event number 0 generated by triggering the corresponding TRIGGER[0] task | | EVENTS_TRIGGERED[1] | 0x104 | Event number 1 generated by triggering the corresponding TRIGGER[1] task | | EVENTS_TRIGGERED[2] | 0x108 | Event number 2 generated by triggering the corresponding TRIGGER[2] task | | EVENTS_TRIGGERED[3] | 0x10C | Event number 3 generated by triggering the corresponding TRIGGER[3] task | | EVENTS_TRIGGERED[4] | 0x110 | Event number 4 generated by triggering the corresponding TRIGGER[4] task | | EVENTS_TRIGGERED[5] | 0x114 | Event number 5 generated by triggering the corresponding TRIGGER[5] task | | EVENTS_TRIGGERED[6] | 0x118 | Event number 6 generated by triggering the corresponding TRIGGER[6] task | | EVENTS_TRIGGERED[7] | 0x11C | Event number 7 generated by triggering the corresponding TRIGGER[7] task | | EVENTS_TRIGGERED[8] | 0x120 | Event number 8 generated by triggering the corresponding TRIGGER[8] task | | EVENTS_TRIGGERED[9] | 0x124 | Event number 9 generated by triggering the corresponding TRIGGER[9] task | | | | | | Register | Offset | Description | |----------------------|--------|----------------------------------------------------------------------------| | EVENTS_TRIGGERED[10] | 0x128 | Event number 10 generated by triggering the corresponding TRIGGER[10] task | | EVENTS_TRIGGERED[11] | 0x12C | Event number 11 generated by triggering the corresponding TRIGGER[11] task | | EVENTS_TRIGGERED[12] | 0x130 | Event number 12 generated by triggering the corresponding TRIGGER[12] task | | EVENTS_TRIGGERED[13] | 0x134 | Event number 13 generated by triggering the corresponding TRIGGER[13] task | | EVENTS_TRIGGERED[14] | 0x138 | Event number 14 generated by triggering the corresponding TRIGGER[14] task | | EVENTS_TRIGGERED[15] | 0x13C | Event number 15 generated by triggering the corresponding TRIGGER[15] task | | INTEN | 0x300 | Enable or disable interrupt | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | Table 35: Register overview # 6.6.1.1 TASKS\_TRIGGER[n] (n=0..15) Address offset: $0x000 + (n \times 0x4)$ Trigger n for triggering the corresponding TRIGGERED[n] event # 6.6.1.2 EVENTS TRIGGERED[n] (n=0..15) Address offset: $0x100 + (n \times 0x4)$ Event number n generated by triggering the corresponding TRIGGER[n] task #### 6.6.1.3 INTEN Address offset: 0x300 Enable or disable interrupt | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | PONMLKJIHGFEDCBA | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A-P RW TRIGGERED[i] (i=015) | | | Enable or disable interrupt for event TRIGGERED[i] | | | Disabled | 0 | Disable | | | Enabled | 4 | Enable | #### **6.6.1.4 INTENSET** Address offset: 0x304 **Enable interrupt** | Bit number | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------------------|---------------------|--------------------------------------------------------------------| | ID | | PONMLKJIHGFEDCBA | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A-P RW TRIGGERED[i] (i=015) | | Write '1' to enable interrupt for event TRIGGERED[i] | | Set | 1 | Enable | | Disabled | 0 | Read: Disabled | | Enabled | 1 | Read: Enabled | #### **6.6.1.5 INTENCLR** Address offset: 0x308 Disable interrupt # 6.6.2 Electrical specification # 6.6.2.1 EGU Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | |----------------------|----------------------------------------------------------|------|------|------|--------| | $t_{\text{EGU,EVT}}$ | Latency between setting an EGU event flag and the system | | 1 | | cycles | | | setting an interrupt | | | | | # 6.7 GPIO — General purpose input/output The general purpose input/output pins (GPIOs) are grouped as one or more ports with each port having up to 32 GPIOs. The number of ports and GPIOs per port might vary with product variant and package. Refer to Registers on page 105 and Pin assignments on page 331 for more information about the number of GPIOs that are supported. GPIO has the following user-configurable features: - Up to 32 GPIO pins per GPIO port - · Configurable output drive strength - Internal pull-up and pull-down resistors - · Wake-up from high or low level triggers on all pins - Trigger interrupt on state changes on any pin - All pins can be used by the PPI task/event system - One or more GPIO outputs can be controlled through PPI and GPIOTE channels - All pins can be individually mapped to interface blocks for layout flexibility - GPIO state changes captured on SENSE signal can be stored by LATCH register The GPIO port peripheral implements up to 32 pins, PIN0 through PIN31. Each of these pins can be individually configured in the PIN\_CNF[n] registers (n=0..31). The following parameters can be configured through these registers: - Direction - Drive strength - Enabling of pull-up and pull-down resistors - Pin sensing - Input buffer disconnect - · Analog input (for selected pins) The PIN\_CNF registers are retained registers. See POWER — Power supply on page 46 chapter for more information about retained registers. # 6.7.1 Pin configuration Pins can be individually configured, through the SENSE field in the PIN\_CNF[n] register, to detect either a high level or a low level on their input. When the correct level is detected on any such configured pin, the sense mechanism will set the DETECT signal high. Each pin has a separate DETECT signal. Default behavior, defined by the DETECTMODE register, is that the DETECT signals from all pins in the GPIO port are combined into one common DETECT signal that is routed throughout the system, which then can be utilized by other peripherals. This mechanism is functional in both System ON mode and System OFF mode. See GPIO port and the GPIO pin details on page 103. Figure 33: GPIO port and the GPIO pin details GPIO port and the GPIO pin details on page 103 illustrates the GPIO port containing 32 individual pins, where PINO is illustrated in more detail as a reference. All signals on the left side in the illustration are used by other peripherals in the system and therefore not directly available to the CPU. Make sure that a pin is in a level that cannot trigger the sense mechanism before enabling it. The DETECT signal will go high immediately if the SENSE condition configured in the PIN\_CNF registers is met when the sense mechanism is enabled. This will trigger a PORT event if the DETECT signal was low before enabling the sense mechanism. See GPIOTE — GPIO tasks and events on page 110. See the following peripherals for more information about how the DETECT signal is used: - POWER: uses the DETECT signal to exit from System OFF mode. - GPIOTE: uses the DETECT signal to generate the PORT event. When a pin's PINx.DETECT signal goes high, a flag will be set in the LATCH register. For example, when the PINO.DETECT signal goes high, bit 0 in the LATCH register will be set to '1'. If the CPU performs a clear operation on a bit in the LATCH register when the associated PINx.DETECT signal is high, the bit in the LATCH register will not be cleared. The LATCH register will only be cleared if the CPU explicitly clears it by writing a '1' to the bit that shall be cleared, i.e. the LATCH register will not be affected by a PINx.DETECT signal being set low. The LDETECT signal will be set high when one or more bits in the LATCH register are '1'. The LDETECT signal will be set low when all bits in the LATCH register are successfully cleared to '0'. If one or more bits in the LATCH register are '1' after the CPU has performed a clear operation on the LATCH registers, a rising edge will be generated on the LDETECT signal. This is illustrated in DETECT signal behavior on page 104. **Important:** The CPU can read the LATCH register at any time to check if a SENSE condition has been met on one or more of the the GPIO pins, even if that condition is no longer met at the time the CPU queries the LATCH register. This mechanism will work even if the LDETECT signal is not used as the DETECT signal. The LDETECT signal is by default not connected to the GPIO port's DETECT signal, but via the DETECTMODE register it is possible to change from default behavior to DETECT signal being derived directly from the LDETECT signal instead. See GPIO port and the GPIO pin details on page 103. DETECT signal behavior on page 104 illustrates the DETECT signal behavior for these two alternatives. Figure 34: DETECT signal behavior The input buffer of a GPIO pin can be disconnected from the pin to enable power savings when the pin is not used as an input, see GPIO port and the GPIO pin details on page 103. Inputs must be connected to get a valid input value in the IN register, and for the sense mechanism to get access to the pin. Other peripherals in the system can connect to GPIO pins and override their output value and configuration, or read their analog or digital input value. See GPIO port and the GPIO pin details on page 103. Selected pins also support analog input signals, see ANAIN in GPIO port and the GPIO pin details on page 103. The assignment of the analog pins can be found in Pin assignments on page 331. **Important:** When a pin is configured as digital input, care has been taken to minimize increased current consumption when the input voltage is between $V_{IL}$ and $V_{IH}$ . However, it is a good practice to ensure that the external circuitry does not drive that pin to levels between $V_{IL}$ and $V_{IH}$ for a long period of time. # 6.7.2 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|----------------------------------|---------------| | 0x50000000 | GPIO | P0 | General purpose input and output | | Table 36: Instances | Register | Offset | Description | |-------------|--------|-----------------------------------------------------------------------------------------------------------| | OUT | 0x504 | Write GPIO port | | OUTSET | 0x508 | Set individual bits in GPIO port | | OUTCLR | 0x50C | Clear individual bits in GPIO port | | IN | 0x510 | Read GPIO port | | DIR | 0x514 | Direction of GPIO pins | | DIRSET | 0x518 | DIR set register | | DIRCLR | 0x51C | DIR clear register | | LATCH | 0x520 | Latch register indicating what GPIO pins that have met the criteria set in the PIN_CNF[n].SENSE registers | | DETECTMODE | 0x524 | Select between default DETECT signal behaviour and LDETECT mode | | PIN_CNF[0] | 0x700 | Configuration of GPIO pins | | PIN_CNF[1] | 0x704 | Configuration of GPIO pins | | PIN_CNF[2] | 0x708 | Configuration of GPIO pins | | PIN_CNF[3] | 0x70C | Configuration of GPIO pins | | PIN_CNF[4] | 0x710 | Configuration of GPIO pins | | PIN_CNF[5] | 0x714 | Configuration of GPIO pins | | PIN_CNF[6] | 0x718 | Configuration of GPIO pins | | PIN_CNF[7] | 0x71C | Configuration of GPIO pins | | PIN_CNF[8] | 0x720 | Configuration of GPIO pins | | PIN_CNF[9] | 0x724 | Configuration of GPIO pins | | PIN_CNF[10] | 0x728 | Configuration of GPIO pins | | PIN_CNF[11] | 0x72C | Configuration of GPIO pins | | PIN_CNF[12] | 0x730 | Configuration of GPIO pins | | PIN_CNF[13] | 0x734 | Configuration of GPIO pins | | PIN_CNF[14] | 0x738 | Configuration of GPIO pins | | PIN_CNF[15] | 0x73C | Configuration of GPIO pins | | PIN_CNF[16] | 0x740 | Configuration of GPIO pins | | PIN_CNF[17] | 0x744 | Configuration of GPIO pins | | PIN_CNF[18] | 0x748 | Configuration of GPIO pins | | PIN_CNF[19] | 0x74C | Configuration of GPIO pins | | PIN_CNF[20] | 0x750 | Configuration of GPIO pins | | PIN_CNF[21] | 0x754 | Configuration of GPIO pins | | PIN_CNF[22] | 0x758 | Configuration of GPIO pins | | Register | Offset | Description | |-------------|--------|----------------------------| | PIN_CNF[23] | 0x75C | Configuration of GPIO pins | | PIN_CNF[24] | 0x760 | Configuration of GPIO pins | | PIN_CNF[25] | 0x764 | Configuration of GPIO pins | | PIN_CNF[26] | 0x768 | Configuration of GPIO pins | | PIN_CNF[27] | 0x76C | Configuration of GPIO pins | | PIN_CNF[28] | 0x770 | Configuration of GPIO pins | | PIN_CNF[29] | 0x774 | Configuration of GPIO pins | | PIN_CNF[30] | 0x778 | Configuration of GPIO pins | | PIN_CNF[31] | 0x77C | Configuration of GPIO pins | Table 37: Register overview #### 6.7.2.1 OUT Address offset: 0x504 Write GPIO port #### 6.7.2.2 OUTSET Address offset: 0x508 Set individual bits in GPIO port Read: reads value of OUT register. #### 6.7.2.3 OUTCLR Address offset: 0x50C Clear individual bits in GPIO port Read: reads value of OUT register. | Bit numb | er | | 31 | 30 2 | 29 2 | 28 2 | 27 2 | 26 2 | 25 2 | 24 2 | 23 2 | 22 2 | 21 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |----------|------------------|-------|----|------|------|------|------|------|------|------|------|------|-------|------|-------|------|------|-----|-----|-----|------|-------|-----|-----|-----|----|---|---|---|---|-----| | ID | | | f | e | d | С | b | a i | Z | Υ | X١ | w ' | V U | Т | S | R | Q | Р | 0 | N | М | _ K | J | 1 | Н | G | F | Ε | D | С | ВА | | Reset 0x | 00000000 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID Ac | | | | | | | | | | | Des | | | | | | | | | | | | | | | | | | | | | | A-f RV | V PIN[i] (i=031) | | | | | | | | | 1 | Pin | i | | | | | | | | | | | | | | | | | | | | | | | Low | 0 | | | | | | | - | Rea | d: p | oin d | rive | er is | lov | N | | | | | | | | | | | | | | | | | | High | 1 | | | | | | | 1 | Rea | d: p | oin d | rive | er is | hi | gh | | | | | | | | | | | | | | | | | | Clear | 1 | | | | | | | ١ | Wri | te: | writ | ng | a '1 | ' se | ts t | the | pir | lov | v; w | ritin | g a | '0' | has | no | ) | | | | | | | | | | | | | | | | | effe | ct | | | | | | | | | | | | | | | | | | | | # 6.7.2.4 IN Address offset: 0x510 Read GPIO port | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0 | |----------------------|------|---------------------------------------------------------------------------------|-------| | ID | | fedcbaZYXWVUTSRQPONMLKJIHGFED | | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 | | ID Acce Field | | Value Description | | | A-f R PIN[i] (i=031) | | Pin i | | | | Low | 0 Pin input is low | | | | High | 1 Pin input is high | | #### 6.7.2.5 DIR Address offset: 0x514 Direction of GPIO pins | Bit number | | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------------|----------|-------------------|-----------------------------------------------------------------------| | ID | | f edcba | Z Y X W V U T S R Q P O N M L K J I H G F E D C B A | | Reset 0x00000000 | | 0 0 0 0 0 0 | 000000000000000000000000000000000000000 | | ID Acce Field | Value ID | Value | Description | | A-f RW PIN[i] (i=031) | | | Pin i | | | Input | 0 | Pin set as input | | | Output | 1 | Pin set as output | # 6.7.2.6 DIRSET Address offset: 0x518 DIR set register Read: reads value of DIR register. | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------------|--------|------------------------|-----------------------------------------------------------------| | ID | | | fedcbaZY | 'XWVUTSRQPONMLKJIHGFEDCBA | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | A-f | RW PIN[i] (i=031) | | | Set as output pin i | | | | Input | 0 | Read: pin set as input | | | | Output | 1 | Read: pin set as output | | | | Set | 1 | Write: writing a '1' sets pin to output; writing a '0' has no | | | | | | effect | #### 6.7.2.7 DIRCLR Address offset: 0x51C DIR clear register Read: reads value of DIR register. | Bit numb | ber | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |----------|------------------|--------|----------------------|------------------------------------------------------------------| | ID | | | f e d c b a Z | Y X W V U T S R Q P O N M L K J I H G F E D C B A | | Reset 0x | «00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID A | | | | | | A-f R\ | W PIN[i] (i=031) | | | Set as input pin i | | | | Input | 0 | Read: pin set as input | | | | Output | 1 | Read: pin set as output | | | | Clear | 1 | Write: writing a '1' sets pin to input; writing a '0' has no | | | | | | effect | #### 6.7.2.8 LATCH Address offset: 0x520 Latch register indicating what GPIO pins that have met the criteria set in the PIN\_CNF[n].SENSE registers # 6.7.2.9 DETECTMODE Address offset: 0x524 Select between default DETECT signal behaviour and LDETECT mode | | | | · | | |-------|---------------|---------|-------------------------|-----------------------------------------------------------------| | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | ID | | | | А | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW DETECTMODE | | | Select between default DETECT signal behaviour and | | | | | | LDETECT mode | | | | Default | 0 | DETECT directly connected to PIN DETECT signals | | | | LDETECT | 1 | Use the latched LDETECT behaviour | # 6.7.2.10 PIN\_CNF[n] (n=0..31) Address offset: $0x700 + (n \times 0x4)$ Configuration of GPIO pins | Bit r | umber | | 31 30 29 28 | 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|------------|-------------|------------|------------------------------------------------------------------| | ID | | | | | E E DDD CCBA | | Res | et 0x00000002 | | 0 0 0 0 | 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | A | RW DIR | | | | Pin direction. Same physical register as DIR register | | | | Input | 0 | | Configure pin as an input pin | | | | Output | 1 | | Configure pin as an output pin | | В | RW INPUT | | | | Connect or disconnect input buffer | | | | Connect | 0 | | Connect input buffer | | | | Disconnect | 1 | | Disconnect input buffer | | С | RW PULL | | | | Pull configuration | | | | Disabled | 0 | | No pull | | | | Pulldown | 1 | | Pull down on pin | | | | Pullup | 3 | | Pull up on pin | | D | RW DRIVE | | | | Drive configuration | | | | SOS1 | 0 | | Standard '0', standard '1' | | | | H0S1 | 1 | | High drive '0', standard '1' | | | | S0H1 | 2 | | Standard '0', high drive '1' | | | | H0H1 | 3 | | High drive '0', high 'drive '1" | | | | DOS1 | 4 | | Disconnect '0' standard '1' (normally used for wired-or | | | | | | | connections) | | | | D0H1 | 5 | | Disconnect '0', high drive '1' (normally used for wired-or | | | | | | | connections) | | | | SOD1 | 6 | | Standard '0'. disconnect '1' (normally used for wired-and | | | | | | | connections) | | | | H0D1 | 7 | | High drive '0', disconnect '1' (normally used for wired-and | | | | | | | connections) | | E | RW SENSE | | | | Pin sensing mechanism | | | | Disabled | 0 | | Disabled | | | | High | 2 | 4 | Sense for high level | | | | Low | 3 | | Sense for low level | # 6.7.3 Electrical specification ## 6.7.3.1 GPIO Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------|--------------------------------------------------------------|-------|------|---------|-------| | V <sub>IH</sub> | Input high voltage | 0.7 x | | VDD | V | | | | VDD | | | | | $V_{IL}$ | Input low voltage | VSS | | 0.3 x | V | | | | | | VDD | | | $V_{OH,SD}$ | Output high voltage, standard drive, 0.5 mA, VDD ≥1.7 | VDD- | 0.4 | VDD | V | | V <sub>OH,HDH</sub> | Output high voltage, high drive, 5 mA, VDD >= 2.7 V | VDD- | 0.4 | VDD | V | | $V_{OH,HDL}$ | Output high voltage, high drive, 3 mA, VDD >= 1.7 V | VDD- | 0.4 | VDD | V | | $V_{OL,SD}$ | Output low voltage, standard drive, 0.5 mA, VDD ≥1.7 | VSS | | VSS+0.4 | V | | V <sub>OL,HDH</sub> | Output low voltage, high drive, 5 mA, VDD >= 2.7 V | VSS | | VSS+0.4 | V | | $V_{OL,HDL}$ | Output low voltage, high drive, 3 mA, VDD >= 1.7 V | VSS | | VSS+0.4 | V | | I <sub>OL,SD</sub> | Current at VSS+0.4 V, output set low, standard drive, VDD | 1 | 2 | 4 | mA | | | ≥1.7 | | | | | | I <sub>OL,HDH</sub> | Current at VSS+0.4 V, output set low, high drive, VDD >= 2.7 | 6 | 10 | 15 | mA | | | V | | | | | | I <sub>OL,HDL</sub> | Current at VSS+0.4 V, output set low, high drive, VDD >= 1.7 | 3 | | | mA | | | V | | | | | | Symbol | Description | | Min. | Тур. | Max. | Units | |-----------------------|----------------------------------------------------------------------|--|------|------|------|-------| | I <sub>OH,SD</sub> | Current at VDD-0.4 V, output set high, standard drive, VDD | | 1 | 2 | 4 | mA | | | ≥1.7 | | | | | | | I <sub>OH,HDH</sub> | Current at VDD-0.4 V, output set high, high drive, VDD >= 2.7 | | 6 | 9 | 14 | mA | | | V | | | | | | | I <sub>OH,HDL</sub> | Current at VDD-0.4 V, output set high, high drive, VDD >= 1.7 | | 3 | | | mA | | | V | | | | | | | t <sub>RF,15pF</sub> | Rise/fall time, standard drive mode, 10-90%, 15 pF $load^1$ | | | 9 | | ns | | t <sub>RF,25pF</sub> | Rise/fall time, standard drive mode, 10-90%, 25 pF load <sup>1</sup> | | | 13 | | ns | | t <sub>RF,50pF</sub> | Rise/fall time, standard drive mode, 10-90%, 50 pF $load^1$ | | | 25 | | ns | | t <sub>HRF,15pF</sub> | Rise/Fall time, high drive mode, 10-90%, 15 pF load <sup>1</sup> | | | 4 | | ns | | t <sub>HRF,25pF</sub> | Rise/Fall time, high drive mode, 10-90%, 25 pF load <sup>1</sup> | | | 5 | | ns | | t <sub>HRF,50pF</sub> | Rise/Fall time, high drive mode, 10-90%, 50 pF load <sup>1</sup> | | | 8 | | ns | | $R_{PU}$ | Pull-up resistance | | 11 | 13 | 16 | kΩ | | $R_{PD}$ | Pull-down resistance | | 11 | 13 | 16 | kΩ | | C <sub>PAD</sub> | Pad capacitance | | | 3 | | pF | ### 6.8 GPIOTE — GPIO tasks and events The GPIO tasks and events (GPIOTE) module provides functionality for accessing GPIO pins using tasks and events. Each GPIOTE channel can be assigned to one pin. A GPIOTE block enables GPIOs to generate events on pin state change which can be used to carry out tasks through the PPI system. A GPIO can also be driven to change state on system events using the PPI system. Low power detection of pin state changes is possible when in System ON or System OFF. | Instance | Number of GPIOTE channels | |----------|---------------------------| | GPIOTE | 8 | | GPIOTE | 8 | Table 38: GPIOTE properties Up to three tasks can be used in each GPIOTE channel for performing write operations to a pin. Two tasks are fixed (SET and CLR), and one (OUT) is configurable to perform following operations: - Set - Clear - Toggle An event can be generated in each GPIOTE channel from one of the following input conditions: - Rising edge - · Falling edge - Any change #### 6.8.1 Pin events and tasks The GPIOTE module has a number of tasks and events that can be configured to operate on individual GPIO pins. The tasks (SET[n], CLR[n] and OUT[n]) can be used for writing to individual pins, and the events (IN[n]) can be generated from changes occurring at the inputs of individual pins. The SET task will set the pin selected in CONFIG[n]. PSEL to high. NORDIC\* <sup>&</sup>lt;sup>1</sup> Rise and fall times based on simulations The CLR task will set the pin low. The effect of the OUT task on the pin is configurable in CONFIG[n].POLARITY, and can either set the pin high, set it low, or toggle it. The tasks and events are configured using the CONFIG[n] registers. Every set of SET, CLR and OUT[n] tasks and IN[n] events has one CONFIG[n] register associated with it. As long as a SET[n], CLR[n] and OUT[n] task or an IN[n] event is configured to control a pin **n**, the pin's output value will only be updated by the GPIOTE module. The pin's output value as specified in the GPIO will therefore be ignored as long as the pin is controlled by GPIOTE. Attempting to write a pin as a normal GPIO pin will have no effect. When the GPIOTE is disconnected from a pin, see MODE field in CONFIG[n] register, the associated pin will get the output and configuration values specified in the GPIO module. When conflicting tasks are triggered simultaneously (i.e. during the same clock cycle) in one channel, the precedence of the tasks will be as described in Task priorities on page 111. | Priority | Task | | |----------|------|--| | 1 | OUT | | | 2 | CLR | | | 3 | SET | | Table 39: Task priorities When setting the CONFIG[n] registers, MODE=Disabled does not have the same effect as MODE=Task and POLARITY=None. In the latter case, a CLR or SET task occurring at the exact same time as OUT will end up with no change on the pin, according to the priorities described in the table above. When a GPIOTE channel is configured to operate on a pin as a task, the initial value of that pin is configured in the OUTINIT field of CONFIG[n]. #### 6.8.2 Port event PORT is an event that can be generated from multiple input pins using the GPIO DETECT signal. The event will be generated on the rising edge of the DETECT signal. See GPIO — General purpose input/output on page 102 for more information about the DETECT signal. Putting the system into System ON IDLE while DETECT is high will not cause DETECT to wake the system up again. Make sure to clear all DETECT sources before entering sleep. If the LATCH register is used as a source, if any bit in LATCH is still high after clearing all or part of the register (for instance due to one of the PINx.DETECT signal still high), a new rising edge will be generated on DETECT, see Pin configuration on page 103. Trying to put the system to System OFF while DETECT is high will cause a wakeup from System OFF reset. This feature is always enabled although the peripheral itself appears to be IDLE, that is, no clocks or other power intensive infrastructure have to be requested to keep this feature enabled. This feature can therefore be used to wake up the CPU from a WFI or WFE type sleep in System ON with all peripherals and the CPU idle, that is, lowest power consumption in System ON mode. In order to prevent spurious interrupts from the PORT event while configuring the sources, the user shall first disable interrupts on the PORT event (through INTENCLR.PORT), then configure the sources (PIN\_CNF[n].SENSE), clear any potential event that could have occurred during configuration (write '0' to EVENTS PORT), and finally enable interrupts (through INTENSET.PORT). ### 6.8.3 Tasks and events pin configuration Each GPIOTE channel is associated with one physical GPIO pin through the CONFIG.PSEL field. When Event mode is selected in CONFIG.MODE, the pin specified by CONFIG.PSEL will be configured as an input, overriding the DIR setting in GPIO. Similarly, when Task mode is selected in CONFIG.MODE, the pin specified by CONFIG.PSEL will be configured as an output overriding the DIR setting and OUT value in GPIO. When Disabled is selected in CONFIG.MODE, the pin specified by CONFIG.PSEL will use its configuration from the PIN[n].CNF registers in GPIO. Only one GPIOTE channel can be assigned to one physical pin. Failing to do so may result in unpredictable behavior. ### 6.8.4 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|-----------------------|---------------|--| | 0x40006000 | GPIOTE | GPIOTE | GPIO tasks and events | | | Table 40: Instances | Register | Offset | Description | |--------------|--------|---------------------------------------------------------------------------------------| | TASKS_OUT[0] | 0x000 | Task for writing to pin specified in CONFIG[0].PSEL. Action on pin is configured in | | | | CONFIG[0].POLARITY. | | TASKS_OUT[1] | 0x004 | Task for writing to pin specified in CONFIG[1].PSEL. Action on pin is configured in | | | | CONFIG[1].POLARITY. | | TASKS_OUT[2] | 0x008 | Task for writing to pin specified in CONFIG[2].PSEL. Action on pin is configured in | | | | CONFIG[2].POLARITY. | | TASKS_OUT[3] | 0x00C | Task for writing to pin specified in CONFIG[3].PSEL. Action on pin is configured in | | | | CONFIG[3].POLARITY. | | TASKS_OUT[4] | 0x010 | Task for writing to pin specified in CONFIG[4].PSEL. Action on pin is configured in | | | | CONFIG[4].POLARITY. | | TASKS_OUT[5] | 0x014 | Task for writing to pin specified in CONFIG[5].PSEL. Action on pin is configured in | | | | CONFIG[5].POLARITY. | | TASKS_OUT[6] | 0x018 | Task for writing to pin specified in CONFIG[6].PSEL. Action on pin is configured in | | | | CONFIG[6].POLARITY. | | TASKS_OUT[7] | 0x01C | Task for writing to pin specified in CONFIG[7].PSEL. Action on pin is configured in | | | | CONFIG[7].POLARITY. | | TASKS_SET[0] | 0x030 | Task for writing to pin specified in CONFIG[0].PSEL. Action on pin is to set it high. | | TASKS_SET[1] | 0x034 | Task for writing to pin specified in CONFIG[1].PSEL. Action on pin is to set it high. | | TASKS_SET[2] | 0x038 | Task for writing to pin specified in CONFIG[2].PSEL. Action on pin is to set it high. | | TASKS_SET[3] | 0x03C | Task for writing to pin specified in CONFIG[3].PSEL. Action on pin is to set it high. | | TASKS_SET[4] | 0x040 | Task for writing to pin specified in CONFIG[4].PSEL. Action on pin is to set it high. | | TASKS_SET[5] | 0x044 | Task for writing to pin specified in CONFIG[5].PSEL. Action on pin is to set it high. | | TASKS_SET[6] | 0x048 | Task for writing to pin specified in CONFIG[6].PSEL. Action on pin is to set it high. | | TASKS_SET[7] | 0x04C | Task for writing to pin specified in CONFIG[7].PSEL. Action on pin is to set it high. | | TASKS_CLR[0] | 0x060 | Task for writing to pin specified in CONFIG[0].PSEL. Action on pin is to set it low. | | TASKS_CLR[1] | 0x064 | Task for writing to pin specified in CONFIG[1].PSEL. Action on pin is to set it low. | | TASKS_CLR[2] | 0x068 | Task for writing to pin specified in CONFIG[2].PSEL. Action on pin is to set it low. | | TASKS_CLR[3] | 0x06C | Task for writing to pin specified in CONFIG[3].PSEL. Action on pin is to set it low. | | TASKS_CLR[4] | 0x070 | Task for writing to pin specified in CONFIG[4].PSEL. Action on pin is to set it low. | | TASKS_CLR[5] | 0x074 | Task for writing to pin specified in CONFIG[5].PSEL. Action on pin is to set it low. | | TASKS_CLR[6] | 0x078 | Task for writing to pin specified in CONFIG[6].PSEL. Action on pin is to set it low. | | TASKS_CLR[7] | 0x07C | Task for writing to pin specified in CONFIG[7].PSEL. Action on pin is to set it low. | | EVENTS_IN[0] | 0x100 | Event generated from pin specified in CONFIG[0].PSEL | | EVENTS_IN[1] | 0x104 | Event generated from pin specified in CONFIG[1].PSEL | | EVENTS_IN[2] | 0x108 | Event generated from pin specified in CONFIG[2].PSEL | | EVENTS_IN[3] | 0x10C | Event generated from pin specified in CONFIG[3].PSEL | | EVENTS_IN[4] | 0x110 | Event generated from pin specified in CONFIG[4].PSEL | | Register | Offset | Description | |--------------|--------|----------------------------------------------------------------------------| | EVENTS_IN[5] | 0x114 | Event generated from pin specified in CONFIG[5].PSEL | | EVENTS_IN[6] | 0x118 | Event generated from pin specified in CONFIG[6].PSEL | | EVENTS_IN[7] | 0x11C | Event generated from pin specified in CONFIG[7].PSEL | | EVENTS_PORT | 0x17C | Event generated from multiple input GPIO pins with SENSE mechanism enabled | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | CONFIG[0] | 0x510 | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | | CONFIG[1] | 0x514 | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | | CONFIG[2] | 0x518 | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | | CONFIG[3] | 0x51C | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | | CONFIG[4] | 0x520 | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | | CONFIG[5] | 0x524 | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | | CONFIG[6] | 0x528 | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | | CONFIG[7] | 0x52C | Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | Table 41: Register overview #### 6.8.4.1 TASKS\_OUT[n] (n=0..7) Address offset: $0x000 + (n \times 0x4)$ Task for writing to pin specified in CONFIG[n].PSEL. Action on pin is configured in CONFIG[n].POLARITY. #### 6.8.4.2 TASKS SET[n] (n=0..7) Address offset: $0x030 + (n \times 0x4)$ Task for writing to pin specified in CONFIG[n].PSEL. Action on pin is to set it high. #### 6.8.4.3 TASKS\_CLR[n] (n=0..7) Address offset: $0x060 + (n \times 0x4)$ Task for writing to pin specified in CONFIG[n].PSEL. Action on pin is to set it low. | Bit number | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|---------|----------------|------------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID Acce Field | | | Description | | A W TASKS_CLR | | | Task for writing to pin specified in CONFIG[n].PSEL. Action | | | | | on pin is to set it low. | | | Trigger | 1 | Trigger task | ### 6.8.4.4 EVENTS\_IN[n] (n=0..7) Address offset: $0x100 + (n \times 0x4)$ Event generated from pin specified in CONFIG[n].PSEL | Bit nun | nber | | 31 30 29 28 | 3 27 26 2 | 25 24 | 23 22 | 21 20 | 19 1 | 8 17 | 16 15 | 14 1 | 3 12 | 11 10 | 9 | 8 7 | 6 | 5 | 4 3 | 2 | 1 0 | |---------|--------------|--------------|-------------|-----------|-------|-------|--------|-------|------|---------|-------|--------|-------|-------|------|-----|---|-----|---|-----| | ID | | | | | | | | | | | | | | | | | | | | Δ | | Reset 0 | 0x00000000 | | 0 0 0 0 | 0 0 | 0 0 | 0_0 | 0 0 | 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 | 0 0 | | ID A | | | | | 1 | Descr | iption | 1 | | | | | | | | | | | | | | A F | RW EVENTS_IN | | | | | Event | gene | rated | from | n pin s | pecif | ied ir | CON | IFIG[ | n].P | SEL | | | | | | | | NotGenerated | 0 | | | Event | not g | ener | ated | | | | | | | | | | | | | | | Generated | 1 | 4 | | Event | gene | rated | | | | | | | | | | | | | ### 6.8.4.5 EVENTS\_PORT Address offset: 0x17C Event generated from multiple input GPIO pins with SENSE mechanism enabled | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | Value | Description | | A RW EVENTS_PORT | | | Event generated from multiple input GPIO pins with SENSE | | | | | mechanism enabled | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | #### **6.8.4.6 INTENSET** Address offset: 0x304 Enable interrupt | Bit nu | mber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|-----------------|----------|-------------------------|---------------------------------------------------------------| | ID | | | 1 | HGFEDCBA | | Reset | 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | A-H | RW IN[i] (i=07) | | | Write '1' to enable interrupt for event IN[i] | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | 1 | RW PORT | | | Write '1' to enable interrupt for event PORT | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | ### 6.8.4.7 INTENCLR Address offset: 0x308 Disable interrupt | Bit number | | 31 30 29 28 27 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | 3 2 1 0 | |---------------------|----------|----------------|---------------------------------------------------------------|---------| | ID | | 1 | HGFE | D C B A | | Reset 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 | | ID Acce Field | | | | | | A-H RW IN[i] (i=07) | | | Write '1' to disable interrupt for event IN[i] | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | I RW PORT | | | Write '1' to disable interrupt for event PORT | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | ### 6.8.4.8 CONFIG[n] (n=0..7) Address offset: $0x510 + (n \times 0x4)$ Configuration for OUT[n], SET[n] and CLR[n] tasks and IN[n] event | Bit n | umber | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|----------|----------------------|--------------------------------------------------------------------| | ID | | | | E D D B B B B B A A | | Rese | t 0x00000000 | <b>A</b> | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | Value ID | Value | Description | | Α | RW MODE | 4 | | Mode | | | | Disabled | 0 | Disabled. Pin specified by PSEL will not be acquired by the | | | | | | GPIOTE module. | | | | Event | 1 | Event mode | | | | | | The pin specified by PSEL will be configured as an input and | | | | | | the IN[n] event will be generated if operation specified in | | | | | | POLARITY occurs on the pin. | | | | Task | 3 | Task mode | | | | | | The GPIO specified by PSEL will be configured as an output | | | | | | and triggering the SET[n], CLR[n] or OUT[n] task will | | | | | | perform the operation specified by POLARITY on the pin. | | | | | | When enabled as a task the GPIOTE module will acquire the | | | | | | pin and the pin can no longer be written as a regular output | | | | | | pin from the GPIO module. | | В | RW PSEL | | [031] | GPIO number associated with SET[n], CLR[n] and OUT[n] | | | | | | tasks and IN[n] event | | D | RW POLARITY | | | When In task mode: Operation to be performed on output | | | | | | when OUT[n] task is triggered. When In event mode: | | | | | | Operation on input that shall trigger IN[n] event. | | | | None | 0 | Task mode: No effect on pin from OUT[n] task. Event mode: | | | | | | no IN[n] event generated on pin activity. | | | | LoToHi | 1 | Task mode: Set pin from OUT[n] task. Event mode: Generate | | | | | | IN[n] event when rising edge on pin. | | | | HiToLo | 2 | Task mode: Clear pin from OUT[n] task. Event mode: | | | | | | Generate IN[n] event when falling edge on pin. | | Reset 0x00000000000000000000000000000000000 | Bit num | nber | | 31 | 30 2 | 9 28 | 27 2 | 26 2 | 5 24 | 4 23 | 22 | 21 | 20 | 19 1 | .8 1 | 17 1 | 6 1 | 5 1 | 4 13 | 3 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | . 0 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------|--------|----|------|------|------|------|------|------|------|------|-------|------|------|-------|------|------|------|------|------|------|------|------|-----|-------|------|---|-----|-----|-----| | Toggle | ID | | | | | | | | | | | | Ε | | | D [ | ) | | | В | В | В | В | В | | | | | | A | A A | | Toggle 3 Task mode: Toggle pin from OUT[n]. Event mode: Generate IN[n] when any change on pin. E RW OUTINIT When in task mode: Initial value of the output when the GPIOTE channel is configured. When in event mode: No effect. Low 0 Task mode: Initial value of pin before task triggering is low | Reset 0 | 0x00000000 | | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 | | IN[n] when any change on pin. E RW OUTINIT When in task mode: Initial value of the output when the GPIOTE channel is configured. When in event mode: No effect. Low 0 Task mode: Initial value of pin before task triggering is low | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | E RW OUTINIT When in task mode: Initial value of the output when the GPIOTE channel is configured. When in event mode: No effect. Low 0 Task mode: Initial value of pin before task triggering is low | | | Toggle | 3 | | | | | | Ta | sk n | nod | le: 1 | Togg | gle | pin | fro | m ( | DUT | [n]. | Eve | nt | mo | de: | Ge | ner | rate | e | | | | | GPIOTE channel is configured. When in event mode: No effect. Low 0 Task mode: Initial value of pin before task triggering is low | | | | | | | | | | IN | [n] | whe | en a | any | cha | nge | e oı | n pi | n. | | | | | | | | | | | | | | effect. Low 0 Task mode: Initial value of pin before task triggering is low | E F | RW OUTINIT | | | | | | | | W | hen | in i | tasl | k m | ode | e: In | itia | l va | lue | of 1 | he ( | out | put | wh | en | the | е | | | | | | Low 0 Task mode: Initial value of pin before task triggering is low | | | | | | | | | | GF | PIOT | ГЕ с | han | nnel | is ( | con | figu | irec | l. W | /her | ı in | eve | nt | mod | de: | No | ) | | | | | | | | | | | | | | | | eff | fect | | | | | | | | | | | | | | | | | | | | | | High 1 Task mode: Initial value of pin before task triggering is high | | | Low | 0 | | | | | | Ta | sk n | nod | le: I | niti | al v | alu | e o | f pi | n be | efor | e ta | sk t | rigg | geri | ng | is lo | ow | , | | | | | | | | High | 1 | | | | | | Ta | sk n | nod | le: I | niti | al v | alu | e o | f pi | n be | efor | e ta | sk t | rigg | geri | ng | is h | nigh | h | | | | ### 6.8.5 Electrical specification ## 6.9 PPI — Programmable peripheral interconnect The programmable peripheral interconnect (PPI) enables peripherals to interact autonomously with each other using tasks and events independent of the CPU. The PPI allows precise synchronization between peripherals when real-time application constraints exist and eliminates the need for CPU activity to implement behavior which can be predefined using PPI. Figure 35: PPI block diagram The PPI system has, in addition to the fully programmable peripheral interconnections, a set of channels where the event end point (EEP) and task end points (TEP) are fixed in hardware. These fixed channels can be individually enabled, disabled, or added to PPI channel groups (see CHG[n] registers), in the same way as ordinary PPI channels. | Instance | Channel | Number of channels | |-------------|---------|--------------------| | PPI | 0-9 | 10 | | PPI (fixed) | 20-31 | 12 | Table 42: Configurable and fixed PPI channels The PPI provides a mechanism to automatically trigger a task in one peripheral as a result of an event occurring in another peripheral. A task is connected to an event through a PPI channel. The PPI channel is composed of three end point registers, one EEP and two TEPs. A peripheral task is connected to a TEP using the address of the task register associated with the task. Similarly, a peripheral event is connected to an EEP using the address of the event register associated with the event. On each PPI channel, the signals are synchronized to the 16 MHz clock, to avoid any internal violation of setup and hold timings. As a consequence, events that are synchronous to the 16 MHz clock will be delayed by one clock period, while other asynchronous events will be delayed by up to one 16 MHz clock period. Note that shortcuts (as defined in the SHORTS register in each peripheral) are not affected by this 16 MHz synchronization, and are therefore not delayed. Each TEP implements a fork mechanism that enables a second task to be triggered at the same time as the task specified in the TEP is triggered. This second task is configured in the task end point register in the FORK registers groups, e.g. FORK.TEP[0] is associated with PPI channel CH[0]. There are two ways of enabling and disabling PPI channels: - Enable or disable PPI channels individually using the CHEN, CHENSET, and CHENCLR registers. - Enable or disable PPI channels in PPI channel groups through the groups' ENABLE and DISABLE tasks. Prior to these tasks being triggered, the PPI channel group must be configured to define which PPI channels belong to which groups. Note that when a channel belongs to two groups m and n, and the tasks CHG[m].EN and CHG[n].DIS occur simultaneously (m and n can be equal or different), the CHG[m].EN on that channel has priority. PPI tasks (for example, CHG[0].EN) can be triggered through the PPI like any other task, which means they can be hooked to a PPI channel as a TEP. One event can trigger multiple tasks by using multiple channels and one task can be triggered by multiple events in the same way. ### 6.9.1 Pre-programmed channels Some of the PPI channels are pre-programmed. These channels cannot be configured by the CPU, but can be added to groups and enabled and disabled like the general purpose PPI channels. The FORK TEP for these channels are still programmable and can be used by the application. For a list of pre-programmed PPI channels, see the table below. | Channel | EEP | TEP | |---------|---------------------------|--------------------------| | 20 | TIMERO->EVENTS_COMPARE[0] | RADIO->TASKS_TXEN | | 21 | TIMERO->EVENTS_COMPARE[0] | RADIO->TASKS_RXEN | | 22 | TIMERO->EVENTS_COMPARE[1] | RADIO->TASKS_DISABLE | | 23 | RADIO->EVENTS_BCMATCH | AAR->TASKS_START | | 24 | RADIO->EVENTS_READY | CCM->TASKS_KSGEN | | 25 | RADIO->EVENTS_ADDRESS | CCM->TASKS_CRYPT | | 26 | RADIO->EVENTS_ADDRESS | TIMERO->TASKS_CAPTURE[1] | | 27 | RADIO->EVENTS_END | TIMERO->TASKS_CAPTURE[2] | | 28 | RTC0->EVENTS_COMPARE[0] | RADIO->TASKS_TXEN | | 29 | RTC0->EVENTS_COMPARE[0] | RADIO->TASKS_RXEN | | 30 | RTC0->EVENTS_COMPARE[0] | TIMERO->TASKS_CLEAR | | 31 | RTC0->EVENTS_COMPARE[0] | TIMERO->TASKS_START | Table 43: Pre-programmed channels ## 6.9.2 Registers | Base address | Peripheral | Instance | <b>Description Configuration</b> | |--------------|------------|----------|--------------------------------------| | 0x4001F000 | PPI | PPI | Programmable peripheral interconnect | Table 44: Instances | Register | Offset | Description | | |------------------|--------|-------------------------------|--| | TASKS CHG[0].EN | 0x000 | Enable channel group 0 | | | ASKS_CHG[0].DIS | 0x004 | Disable channel group 0 | | | TASKS_CHG[1].EN | 0x008 | Enable channel group 1 | | | TASKS_CHG[1].DIS | 0x00C | Disable channel group 1 | | | TASKS_CHG[2].EN | 0x010 | Enable channel group 2 | | | TASKS_CHG[2].DIS | 0x014 | Disable channel group 2 | | | TASKS_CHG[3].EN | 0x018 | Enable channel group 3 | | | TASKS_CHG[3].DIS | 0x01C | Disable channel group 3 | | | TASKS_CHG[4].EN | 0x020 | Enable channel group 4 | | | TASKS_CHG[4].DIS | 0x024 | Disable channel group 4 | | | TASKS_CHG[5].EN | 0x028 | Enable channel group 5 | | | rasks_chg[5].dis | 0x02C | Disable channel group 5 | | | CHEN | 0x500 | Channel enable register | | | CHENSET | 0x504 | Channel enable set register | | | CHENCLR | 0x508 | Channel enable clear register | | | CH[0].EEP | 0x510 | Channel 0 event end-point | | | CH[0].TEP | 0x514 | Channel 0 task end-point | | | CH[1].EEP | 0x518 | Channel 1 event end-point | | | CH[1].TEP | 0x51C | Channel 1 task end-point | | | CH[2].EEP | 0x520 | Channel 2 event end-point | | | CH[2].TEP | 0x524 | Channel 2 task end-point | | | CH[3].EEP | 0x528 | Channel 3 event end-point | | | CH[3].TEP | 0x52C | Channel 3 task end-point | | | CH[4].EEP | 0x530 | Channel 4 event end-point | | | CH[4].TEP | 0x534 | Channel 4 task end-point | | | CH[5].EEP | 0x538 | Channel 5 event end-point | | | CH[5].TEP | 0x53C | Channel 5 task end-point | | | CH[6].EEP | 0x540 | Channel 6 event end-point | | | CH[6].TEP | 0x544 | Channel 6 task end-point | | | Register | Offset | Description | |--------------|--------|----------------------------| | CH[7].EEP | 0x548 | Channel 7 event end-point | | CH[7].TEP | 0x54C | Channel 7 task end-point | | CH[8].EEP | 0x550 | Channel 8 event end-point | | CH[8].TEP | 0x554 | Channel 8 task end-point | | CH[9].EEP | 0x558 | Channel 9 event end-point | | CH[9].TEP | 0x55C | Channel 9 task end-point | | CH[10].EEP | 0x560 | Channel 10 event end-point | | CH[10].TEP | 0x564 | Channel 10 task end-point | | CH[11].EEP | 0x568 | Channel 11 event end-point | | CH[11].TEP | 0x56C | Channel 11 task end-point | | CH[12].EEP | 0x570 | Channel 12 event end-point | | CH[12].TEP | 0x574 | Channel 12 task end-point | | CH[13].EEP | 0x578 | Channel 13 event end-point | | CH[13].TEP | 0x57C | Channel 13 task end-point | | CH[14].EEP | 0x580 | Channel 14 event end-point | | CH[14].TEP | 0x584 | Channel 14 task end-point | | CH[15].EEP | 0x588 | Channel 15 event end-point | | CH[15].TEP | 0x58C | Channel 15 task end-point | | CH[16].EEP | 0x590 | Channel 16 event end-point | | CH[16].TEP | 0x594 | Channel 16 task end-point | | CH[17].EEP | 0x598 | Channel 17 event end-point | | CH[17].TEP | 0x59C | Channel 17 task end-point | | CH[18].EEP | 0x5A0 | Channel 18 event end-point | | CH[18].TEP | 0x5A4 | Channel 18 task end-point | | CH[19].EEP | 0x5A8 | Channel 19 event end-point | | CH[19].TEP | 0x5AC | Channel 19 task end-point | | CHG[0] | 0x800 | Channel group 0 | | CHG[1] | 0x804 | Channel group 1 | | CHG[2] | 0x808 | Channel group 2 | | CHG[3] | 0x80C | Channel group 3 | | CHG[4] | 0x810 | Channel group 4 | | CHG[5] | 0x814 | Channel group 5 | | FORK[0].TEP | 0x910 | Channel 0 task end-point | | FORK[1].TEP | 0x914 | Channel 1 task end-point | | FORK[2].TEP | 0x918 | Channel 2 task end-point | | FORK[3].TEP | 0x91C | Channel 3 task end-point | | FORK[4].TEP | 0x920 | Channel 4 task end-point | | FORK[5].TEP | 0x924 | Channel 5 task end-point | | FORK[6].TEP | 0x928 | Channel 6 task end-point | | FORK[7].TEP | 0x92C | Channel 7 task end-point | | FORK[8].TEP | 0x930 | Channel 8 task end-point | | FORK[9].TEP | 0x934 | Channel 9 task end-point | | FORK[10].TEP | 0x938 | Channel 10 task end-point | | FORK[11].TEP | 0x93C | Channel 11 task end-point | | FORK[12].TEP | 0x940 | Channel 12 task end-point | | FORK[13].TEP | 0x944 | Channel 13 task end-point | | FORK[14].TEP | 0x948 | Channel 14 task end-point | | FORK[15].TEP | 0x94C | Channel 15 task end-point | | FORK[16].TEP | 0x950 | Channel 16 task end-point | | FORK[17].TEP | 0x954 | Channel 17 task end-point | | FORK[18].TEP | 0x958 | Channel 18 task end-point | | FORK[19].TEP | 0x95C | Channel 19 task end-point | | FORK[20].TEP | 0x960 | Channel 20 task end-point | | | | | | Register | Offset | Description | |--------------|--------|---------------------------| | FORK[21].TEP | 0x964 | Channel 21 task end-point | | FORK[22].TEP | 0x968 | Channel 22 task end-point | | FORK[23].TEP | 0x96C | Channel 23 task end-point | | FORK[24].TEP | 0x970 | Channel 24 task end-point | | FORK[25].TEP | 0x974 | Channel 25 task end-point | | FORK[26].TEP | 0x978 | Channel 26 task end-point | | FORK[27].TEP | 0x97C | Channel 27 task end-point | | FORK[28].TEP | 0x980 | Channel 28 task end-point | | FORK[29].TEP | 0x984 | Channel 29 task end-point | | FORK[30].TEP | 0x988 | Channel 30 task end-point | | FORK[31].TEP | 0x98C | Channel 31 task end-point | Table 45: Register overview ### 6.9.2.1 TASKS\_CHG[n].EN (n=0..5) Address offset: $0x000 + (n \times 0x8)$ Enable channel group n ### 6.9.2.2 TASKS\_CHG[n].DIS (n=0..5) Address offset: $0x004 + (n \times 0x8)$ Disable channel group n #### 6.9.2.3 CHEN Address offset: 0x500 Channel enable register | Bit number | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|-------------------------|-----------------------------------------------------------------| | ID | fedcbaZY | Y X W V U T S R Q P O N M L K J I H G F E D C B A | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A-f RW CH[i] (i=031) | | Enable or disable channel i | | Disabled | 0 | Disable channel | | Enabled | 1 | Enable channel | #### 6.9.2.4 CHENSET Address offset: 0x504 Channel enable set register Read: reads value of CH{i} field in CHEN register. | Bit n | umber | | 31 | 30 | 29 | 28 2 | 27 2 | 6 2 | 5 2 | 4 2 | 3 2 | 2 2: | 1 20 | 0 19 | 18 | 17 | 16 | 15 | 14 | 13 1 | .2 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 2 1 | 0 | |-------|------------------|----------|----|----|----|------|------|-----|-----|-----|------|-------|------|-------|-------|------|------|------|------|-------|------|------|------|-----|-----|----|---|---|-----|-----|---| | ID | | | f | е | d | С | b a | ı Z | Z Y | ′ > | ( V | V V | / U | Т | S | R | Q | Р | 0 | N I | N | L K | J | 1 | Н | G | F | Е | D ( | C E | A | | Rese | t 0x00000000 | | 0 | 0 | 0 | 0 | 0 ( | ) ( | ) ( | ) ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A-f | RW CH[i] (i=031) | | | | | | | | | С | har | nne | lie | nab | ole s | et i | regi | iste | r. W | /riti | ng | 0' h | as n | ю е | ffe | ct | | | | | | | | | Disabled | 0 | | | | | | | R | ead | d: cl | han | nel | disa | able | ed | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | | | R | eac | d: cl | han | nel | ena | ble | d | | | | | | | | | | | | | | | | | | Set | 1 | | | | | | | ٧ | /rit | e: E | nal | ble ( | chai | nne | 1 | | | | | | | | | | | | | | | #### 6.9.2.5 CHENCLR Address offset: 0x508 Channel enable clear register Read: reads value of CH{i} field in CHEN register. ### 6.9.2.6 CH[n].EEP (n=0..19) Address offset: $0x510 + (n \times 0x8)$ Channel n event end-point | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 | A RW EEP | | Pointer to event register. Accepts only addresses to registers | |---------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------|----------------------------------------------------------------| | ID A A A A A A A A A A A A A A A A A A A | ID Acce Field | | Description | | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | ID | A A A A A A A | A A A A A A A A A A A A A A A A A A A | | | Bit number | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | from the Event group. ### 6.9.2.7 CH[n].TEP (n=0..19) Address offset: $0x514 + (n \times 0x8)$ Channel n task end-point | Bit n | umber | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|---------------------------------------------------------------------------------------| | ID | | A A A A A A A A A A A A A A A A A A A | | Rese | t 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | Value Description | | Α | RW TEP | Pointer to task register. Accepts only addresses to registers | | | | from the Task group. | #### 6.9.2.8 CHG[n] (n=0..5) Address offset: $0x800 + (n \times 0x4)$ Channel group n | Bit number | | 31 30 29 28 | 3 27 26 25 24 23 22 21 20 19 18 | 17 16 15 1 | 4 13 12 11 10 | 9 8 7 6 | 5 4 3 | 2 1 0 | |----------------------|----------|-------------|---------------------------------|-------------|---------------|---------|-------|-------| | ID | | f e d c | baZYXWVUTS | RQPC | N M L K | JIHG | FED | СВА | | Reset 0x00000000 | | 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 | 0000 | 0 0 0 0 | 0 0 0 | 0 0 0 | | ID Acce Field | | | Description | | | | | | | A-f RW CH[i] (i=031) | | | Include or exclude | e channel i | | | | | | | Excluded | 0 | Exclude | | | | | | | | Included | 1 | Include | | | | | | #### 6.9.2.9 FORK[n].TEP (n=0..31) Address offset: $0x910 + (n \times 0x4)$ Channel n task end-point ## 6.10 RADIO — 2.4 GHz radio The 2.4 GHz radio transceiver is compatible with multiple radio standards such as 1 Mbps and 2 Mbps $Bluetooth^{@}$ Low Energy modes, as well as Nordic's proprietary 1 Mbps and 2 Mbps modes. Listed here are main features for the RADIO: - Multidomain 2.4 GHz radio transceiver - 1 Mbps and 2 Mbps Bluetooth® Low Energy modes - 1 Mbps and 2 Mbps Nordic proprietary modes - Best in class link budget and low power operation - Efficient data interface with EasyDMA support - · Automatic address filtering and pattern matching EasyDMA, in combination with an automated packet assembler, packet disassembler, automated CRC generator and CRC checker, makes it easy to configure and use the RADIO. See the following figure for details. Figure 36: RADIO block diagram The RADIO includes a device address match unit and an interframe spacing control unit that can be utilized to simplify address whitelisting and interframe spacing respectively in *Bluetooth*<sup>®</sup> low energy and similar applications. The RADIO also includes a received signal strength indicator (RSSI) and a bit counter. The bit counter generates events when a preconfigured number of bits are sent or received by the RADIO. ### 6.10.1 Packet configuration A RADIO packet contains the following fields: PREAMBLE, ADDRESS, SO, LENGTH, S1, PAYLOAD, and CRC. The content of a RADIO packet is illustrated in the figure below. The RADIO sends the fields in the packet according to the order illustrated in the figure, starting on the left. Figure 37: On-air packet layout Not shown in the figure is the static payload add-on (the length of which is defined in PCNF1.STATLEN, and which is 0 bytes in a standard BLE packet). The static payload add-on is sent between PAYLOAD and CRC fields. The RADIO sends the different fields in the packet in the order they are illustrated above, from left to right. PREAMBLE is sent with least significant bit first on air. The size of the PREAMBLE depends on the mode selected in the MODE register: - The PREAMBLE is one byte for MODE = Ble\_1Mbit as well as all Nordic proprietary operating modes (MODE = Nrf\_1Mbit and MODE = Nrf\_2Mbit), and PCNFO.PLEN has to be set accordingly. If the first bit of the ADDRESS is 0, the preamble will be set to 0xAA. Otherwise the PREAMBLE will be set to 0x55. - For MODE = Ble\_2Mbit, the PREAMBLE must be set to 2 byte through PCNFO.PLEN. If the first bit of the ADDRESS is 0, the preamble will be set to 0xAAAA. Otherwise the PREAMBLE will be set to 0x5555. Radio packets are stored in memory inside instances of a RADIO packet data structure as illustrated below. The PREAMBLE, ADDRESS and CRC fields are omitted in this data structure. Fields SO, LENGTH, and S1 are optional. Figure 38: In-RAM representation of RADIO packet The byte ordering on air is always least significant byte first for the ADDRESS and PAYLOAD fields, and most significant byte first for the CRC field. The ADDRESS fields are always transmitted and received least significant bit first. The CRC field is always transmitted and received most significant bit first. The endianness, i.e. the order in which the bits are sent and received, of the SO, LENGTH, S1, and PAYLOAD fields can be configured via PCNF1.ENDIAN. The sizes of the SO, LENGTH and S1 fields can be individually configured via SOLEN, LFLEN, and S1LEN in PCNFO respectively. If any of these fields are configured to be less than 8 bits, the least significant bits of the fields are used. If SO, LENGTH, or S1 are specified with zero length, their fields will be omitted in memory. Otherwise each field will be represented as a separate byte, regardless of the number of bits in their on-air counterpart. Independent of the configuration of PCNF1.MAXLEN, the combined length of SO, LENGTH, S1, and PAYLOAD cannot exceed 258 bytes. ### 6.10.2 Address configuration The on-air radio ADDRESS field is composed of two parts, the base address field and the address prefix field. The size of the base address field is configurable via PCNF1.BALEN. The base address is truncated from the least significant byte if the PCNF1.BALEN is less than 4. See Definition of logical addresses on page 124. | Logical address | Base address | Prefix byte | |-----------------|--------------|-------------| | 0 | BASEO | PREFIXO.APO | | 1 | BASE1 | PREFIXO.AP1 | | 2 | BASE1 | PREFIXO.AP2 | | 3 | BASE1 | PREFIXO.AP3 | | 4 | BASE1 | PREFIX1.AP4 | | 5 | BASE1 | PREFIX1.AP5 | | 6 | BASE1 | PREFIX1.AP6 | | 7 | BASE1 | PREFIX1.AP7 | Table 46: Definition of logical addresses The on-air addresses are defined in the BASEO/BASE1 and PREFIXO/PREFIX1 registers. It is only when writing these registers that the user must relate to the actual on-air addresses. For other radio address registers, such as the TXADDRESS, RXADDRESSES, and RXMATCH registers, logical radio addresses ranging from 0 to 7 are being used. The relationship between the on-air radio addresses and the logical addresses is described in Definition of logical addresses on page 124. ### 6.10.3 Data whitening The RADIO is able to do packet whitening and de-whitening, enabled in PCNF1.WHITEEN. When enabled, whitening and de-whitening will be handled by the RADIO automatically as packets are sent and received. The whitening word is generated using polynomial $g(D) = D^7 + D^4 + 1$ , which then is XORed with the data packet that is to be whitened, or de-whitened. See the figure below. NORDIC Figure 39: Data whitening and de-whitening Whitening and de-whitening will be performed over the whole packet except for the preamble and the address fields. The linear feedback shift register in the figure above is initialized via DATAWHITEIV. #### 6.10.4 CRC The CRC generator in the RADIO calculates the CRC over the whole packet excluding the preamble. If desirable, the address field can be excluded from the CRC calculation as well. See CRCCNF register for more information. The CRC polynomial is configurable as illustrated in the following figure, where bit 0 in the CRCPOLY register corresponds to $X^0$ and bit 1 corresponds to $X^1$ etc. See CRCPOLY on page 149 for more information. Figure 40: CRC generation of an n bit CRC The figure shows that the CRC is calculated by feeding the packet serially through the CRC generator. Before the packet is clocked through the CRC generator, the CRC generator's latches $b_0$ through $b_n$ will be initialized with a predefined value specified in the CRCINIT register. After the whole packet has been clocked through the CRC generator, $b_0$ through $b_n$ will hold the resulting CRC. This value will be used by the RADIO during both transmission and reception. Latches $b_0$ through $b_n$ are not available to be read by the CPU at any time. However, a received CRC can be read by the CPU via the RXCRC register. The length (n) of the CRC is configurable, see CRCCNF for more information. Once the entire packet, including the CRC, has been received and no errors were detected, the RADIO generates a CRCOK event. If CRC errors were detected, a CRCERROR event is generated. The status of the CRC check can be read from the CRCSTATUS register after a packet has been received. #### 6.10.5 Radio states Tasks and events are used to control the operating state of the RADIO. The RADIO can enter the states described the table below. | State | Description | |-----------|------------------------------------------------------------------------------------------------------| | DISABLED | No operations are going on inside the RADIO and the power consumption is at a minimum | | RXRU | The RADIO is ramping up and preparing for reception | | RXIDLE | The RADIO is ready for reception to start | | RX | Reception has been started and the addresses enabled in the RXADDRESSES register are being monitored | | TXRU | The RADIO is ramping up and preparing for transmission | | TXIDLE | The RADIO is ready for transmission to start | | TX | The RADIO is transmitting a packet | | RXDISABLE | The RADIO is disabling the receiver | | TXDISABLE | The RADIO is disabling the transmitter | Table 47: RADIO state diagram A state diagram showing an overview of the RADIO is shown in the following figure. Figure 41: Radio states This figure shows how the tasks and events relate to the RADIO's operation. The RADIO does not prevent a task from being triggered from the wrong state. If a task is triggered from the wrong state, for example if the RXEN task is triggered from the RXDISABLE state, this may lead to incorrect behavior. The PAYLOAD event is always generated even if the payload is zero. #### 6.10.6 Transmit sequence Before the RADIO is able to transmit a packet, it must first ramp-up in TX mode. See TXRU in Radio states on page 126 and Transmit sequence on page 127. A TXRU ramp-up sequence is initiated when the TXEN task is triggered. After the RADIO has successfully ramped up it will generate the READY event indicating that a packet transmission can be initiated. A packet transmission is initiated by triggering the START task. The START task can first be triggered after the RADIO has entered into the TXIDLE state. The following figure illustrates a single packet transmission where the CPU manually triggers the different tasks needed to control the flow of the RADIO, i.e. no shortcuts are used. If shortcuts are not used, a certain amount of delay caused by CPU execution is expected between READY and START, and between END and DISABLE. As illustrated in Transmit sequence on page 127 the RADIO will by default transmit '1's between READY and START, and between END and DISABLED. What is transmitted can be programmed through the DTX field in the MODECNFO register. Figure 42: Transmit sequence The following figure shows a slightly modified version of the transmit sequence where the RADIO is configured to use shortcuts between READY and START, and between END and DISABLE, which means that no delay is introduced. Figure 43: Transmit sequence using shortcuts to avoid delays The RADIO is able to send multiple packets one after the other without having to disable and re-enable the RADIO between packets, as illustrated in the following figure. Figure 44: Transmission of multiple packets ### 6.10.7 Receive sequence Before the RADIO is able to receive a packet, it must first ramp up in RX mode, see RXRU in Radio states on page 126 and Receive sequence on page 128. An RXRU ramp up sequence is initiated when the RXEN task is triggered. After the RADIO has successfully ramped up it will generate the READY event indicating that a packet reception can be initiated. A packet reception is initiated by triggering the START task. As illustrated in Radio states on page 126, the START task can first be triggered after the RADIO has entered into the RXIDLE state. The following figure shows a single packet reception where the CPU manually triggers the different tasks needed to control the flow of the RADIO, i.e. no shortcuts are used. If shortcuts are not used, a certain amount of delay caused by CPU execution is expected between READY and START, and between END and DISABLE. The RADIO will be listening and possibly receiving undefined data, represented with an 'X', from START and until a packet with valid preamble (P) is received. Figure 45: Receive sequence The following figure shows a slightly modified version of the receive sequence, where the RADIO is configured to use shortcuts between READY and START, and between END and DISABLE, which means that no delay is introduced. Figure 46: Receive sequence using shortcuts to avoid delays The RADIO is able to receive consecutive packets without having to disable and re-enable the RADIO between packets, as illustrated in the figure below. Figure 47: Reception of multiple packets ### 6.10.8 Received signal strength indicator (RSSI) The RADIO implements a mechanism for measuring the power in the received signal. This feature is called received signal strength indicator (RSSI). The RSSI is measured continuously and the value filtered using a single-pole IIR filter. After a signal level change, the RSSI will settle after approximately RSSI<sub>SETTLE</sub>. Sampling of the received signal strength is started by using the RSSISTART task. The sample can be read from the RSSISAMPLE register. The sample period of the RSSI is defined by RSSI<sub>PERIOD</sub>. The RSSISAMPLE will hold the filtered received signal strength after this sample period. For the RSSI sample to be valid, the RADIO has to be enabled in receive mode (RXEN task) and the reception has to be started (READY event followed by START task). ### 6.10.9 Interframe spacing (IFS) Interframe spacing (IFS) is defined as the time, in microseconds, between two consecutive packets, starting from when the end of the last bit of the previous packet is received, to the beginning of the first bit of the subsequent packet that is transmitted. The RADIO is able to enforce this interval, as specified in the TIFS register, as long as the TIFS is not specified to be shorter than the RADIO's turnaround time, i.e. the time needed to switch off the receiver, and then switch the transmitter back on. The TIFS register can be written any time before the last bit on air is received. This timing is illustrated in the figure below. Figure 48: IFS timing detail The TIFS duration starts after the last bit on air (just before the END event), and elapses with first bit being transmitted on air (just after READY event). TIFS is only enforced if the shortcuts END to DISABLE and DISABLED to TXEN or END to DISABLE and DISABLED to RXEN are enabled. TIFS is qualified for use in 1 Mbps and 2 Mbps *Bluetooth*<sup>®</sup> Low Energy modes, using the default ramp-up mode SHORTS and TIFS registers are not double-buffered, and can be updated at any point before the last bit on air is received. The MODE register is double-buffered and sampled at the TXEN or RXEN task. #### 6.10.10 Device address match The device address match feature is tailored for address whitelisting in *Bluetooth*<sup>®</sup> low energy and similar implementations. This feature enables on-the-fly device address matching while receiving a packet on air. This feature only works in receive mode and when the RADIO is configured for little endian, see PCNF1.ENDIAN. The device address match unit assumes that the first 48 bits of the payload are the device address and that bit number 6 in S0 is the TxAdd bit. See the *Bluetooth*<sup>®</sup> Core Specification for more information about device addresses, TxAdd, and whitelisting. The RADIO is able to listen for eight different device addresses at the same time. These addresses are specified in a DAB/DAP register pair, one pair per address, in addition to a TxAdd bit configured in the DACNF register. The DAB register specifies the 32 least significant bits of the device address, while the DAP register specifies the 16 most significant bits of the device address. Each of the device addresses can be individually included or excluded from the matching mechanism. This is configured in the DACNF register. #### 6.10.11 Bit counter The RADIO implements a simple counter that can be configured to generate an event after a specific number of bits have been transmitted or received. By using shortcuts, this counter can be started from different events generated by the RADIO and count relative to these. The bit counter is started by triggering the BCSTART task, and stopped by triggering the BCSTOP task. A BCMATCH event will be generated when the bit counter has counted the number of bits specified in the BCC register. The bit counter will continue to count bits until the DISABLED event is generated or until the BCSTOP task is triggered. The CPU can therefore, after a BCMATCH event, reconfigure the BCC value for new BCMATCH events within the same packet. The bit counter can only be started after the RADIO has received the ADDRESS event. The bit counter will stop and reset on either the BCSTOP, STOP, or DISABLE task, or the END event. The figure below illustrates how the bit counter can be used to generate a BCMATCH event in the beginning of the packet payload, and again generate a second BCMATCH event after sending 2 bytes (16 bits) of the payload. Figure 49: Bit counter example ### 6.10.12 EasyDMA The RADIO uses EasyDMA to read and write packets to RAM without CPU involvement. As illustrated in RADIO block diagram on page 123, the RADIO's EasyDMA utilizes the same PACKETPTR for receiving and transmitting packets. This pointer should be reconfigured by the CPU each time before RADIO is started by the START task. The PACKETPTR register is double-buffered, meaning that it can be updated and prepared for the next transmission. The END event indicates that the last bit has been processed by the RADIO. The DISABLED event is issued to acknowledge that a DISABLE task is done. The structure of a packet is described in detail in Packet configuration on page 123. The data that is stored in Data RAM and transported by EasyDMA consists of the following fields: - S0 - LENGTH - S1 - PAYLOAD In addition, a static add-on is sent immediately after the payload. The size of each of the above fields in the frame is configurable (see Packet configuration on page 123), and the space occupied in RAM depends on these settings. The size of the field can be zero, as long as the resulting frame complies with the chosen RF protocol. All fields are extended in size to align with a byte boundary in RAM. For instance, a 3-bit long field on air will occupy 1 byte in RAM while a 9-bit long field will be extended to 2 bytes. The packet's elements can be configured as follows: - SO is configured through the PCNFO.SOLEN field - LENGTH is configured through the PCNFO.LFLEN field - S1 is configured through the PCNFO.S1LEN field - Payload size is configured through the value in RAM corresponding to the LENGTH field - Static add-on size is configured through the PCNF1.STATLEN field The PCNF1.MAXLEN field configures the maximum packet payload plus add-on size in number of bytes that can be transmitted or received by the RADIO. This feature can be used to ensure that the RADIO does not overwrite, or read beyond, the RAM assigned to the packet payload. This means that if the LENGTH field of the packet payload exceedes PCNF1.STATLEN, and the LENGTH field in the packet specifies a packet larger than configured in PCNF1.MAXLEN, the payload will be truncated to the length specified in PCNF1.MAXLEN. **Note:** The PCNF1.MAXLEN field includes the payload and the add-on, but excludes the size occupied by the SO, LENGTH, and S1 fields. This has to be taken into account when allocating RAM. If the payload and add-on length is specified larger than PCNF1.MAXLEN, the RADIO will still transmit or receive in the same way as before, except the payload is now truncated to PCNF1.MAXLEN. The packet's LENGTH field will not be altered when the payload is truncated. The RADIO will calculate CRC as if the packet length is equal to PCNF1.MAXLEN. **Note:** If PACKETPTR is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 15 for more information about the different memory regions. The END event indicates that the last bit has been processed by the RADIO. The DISABLED event is issued to acknowledge that an DISABLE task is done. ### 6.10.13 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|---------------|---------------|--| | 0x40001000 | RADIO | RADIO | 2.4 GHz radio | | | Table 48: Instances | Register | Offset | Description | |-----------------|--------|--------------------------------------------------------------------------| | TASKS_TXEN | 0x000 | Enable RADIO in TX mode | | TASKS_RXEN | 0x004 | Enable RADIO in RX mode | | TASKS_START | 0x008 | Start RADIO | | TASKS_STOP | 0x00C | Stop RADIO | | TASKS_DISABLE | 0x010 | Disable RADIO | | TASKS_RSSISTART | 0x014 | Start the RSSI and take one single sample of the receive signal strength | | TASKS_RSSISTOP | 0x018 | Stop the RSSI measurement | | TASKS_BCSTART | 0x01C | Start the bit counter | | TASKS_BCSTOP | 0x020 | Stop the bit counter | | EVENTS_READY | 0x100 | RADIO has ramped up and is ready to be started | | EVENTS_ADDRESS | 0x104 | Address sent or received | | EVENTS_PAYLOAD | 0x108 | Packet payload sent or received | | EVENTS_END | 0x10C | Packet sent or received | | EVENTS_DISABLED | 0x110 | RADIO has been disabled | | EVENTS_DEVMATCH | 0x114 | A device address match occurred on the last received packet | | EVENTS_DEVMISS | 0x118 | No device address match occurred on the last received packet | | Dociston | Offset | Description | |-----------------|--------|-----------------------------------------------------------| | Register | | Description Complian of receive signal strength complete | | EVENTS_RSSIEND | 0x11C | Sampling of receive signal strength complete | | EVENTS_BCMATCH | 0x128 | Bit counter reached bit count value | | EVENTS_CRCOK | 0x130 | Packet received with CRC ok | | EVENTS_CRCERROR | 0x134 | Packet received with CRC error | | EVENTS_TXREADY | 0x154 | RADIO has ramped up and is ready to be started TX path | | EVENTS_RXREADY | 0x158 | RADIO has ramped up and is ready to be started RX path | | EVENTS_MHRMATCH | 0x15C | MAC header match found | | EVENTS_PHYEND | 0x16C | Generated when last bit is sent on air | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | CRCSTATUS | 0x400 | CRC status | | RXMATCH | 0x408 | Received address | | RXCRC | 0x40C | CRC field of previously received packet | | DAI | 0x410 | Device address match index | | PDUSTAT | 0x414 | Payload status | | PACKETPTR | 0x504 | Packet pointer | | FREQUENCY | 0x508 | Frequency | | TXPOWER | 0x50C | Output power | | MODE | 0x510 | Data rate and modulation | | PCNF0 | 0x514 | Packet configuration register 0 | | PCNF1 | 0x518 | Packet configuration register 1 | | BASE0 | 0x51C | Base address 0 | | BASE1 | 0x520 | Base address 1 | | PREFIXO | 0x524 | Prefixes bytes for logical addresses 0-3 | | PREFIX1 | 0x528 | Prefixes bytes for logical addresses 4-7 | | TXADDRESS | 0x52C | Transmit address select | | RXADDRESSES | 0x530 | Receive address select | | CRCCNF | 0x534 | CRC configuration | | CRCPOLY | 0x538 | CRC polynomial | | CRCINIT | 0x53C | CRC initial value | | TIFS | 0x544 | Interframe spacing in µs | | RSSISAMPLE | 0x548 | RSSI sample | | STATE | 0x550 | Current radio state | | DATAWHITEIV | 0x554 | Data whitening initial value | | BCC | 0x560 | Bit counter compare | | DAB[n] | 0x600 | Device address base segment n | | DAP[n] | 0x620 | Device address prefix n | | DACNF | 0x640 | Device address match configuration | | MODECNF0 | 0x650 | Radio mode configuration register 0 | | POWER | 0xFFC | Peripheral power control | Table 49: Register overview ### 6.10.13.1 TASKS\_TXEN Address offset: 0x000 Enable RADIO in TX mode | Bit n | umb | per | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | 3 2 1 0 | |-------|------|------------|---------|-------------------------------------------------------------------------------|---------| | ID | | | | | А | | Rese | t Ox | 00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 | | ID | | | | | | | Α | W | TASKS_TXEN | | Enable RADIO in TX mode | | | | | | Trigger | 1 Trigger task | | ### 6.10.13.2 TASKS\_RXEN Address offset: 0x004 Enable RADIO in RX mode | Bit nur | mber | | 31 30 29 28 27 2 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------|--------------|---------|------------------|-----------------------------------------------------------------------| | ID | | | | A | | Reset | 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID . | | | | Description | | Α | W TASKS_RXEN | | | Enable RADIO in RX mode | | | | Trigger | 1 | Trigger task | ### 6.10.13.3 TASKS\_START Address offset: 0x008 Start RADIO ### 6.10.13.4 TASKS STOP Address offset: 0x00C Stop RADIO | Bit no | umber | | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|--------------|---------|---------------------|--------------------------------------------------------------------| | ID | | | | A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_STOP | | | Stop RADIO | | | | Trigger | 1 | Trigger task | ### 6.10.13.5 TASKS\_DISABLE Address offset: 0x010 Disable RADIO #### 6.10.13.6 TASKS\_RSSISTART Address offset: 0x014 Start the RSSI and take one single sample of the receive signal strength | Bit number | | 31 30 29 | 28 27 26 2 | 25 24 23 2 | 22 21 20 1 | 19 18 17 | 16 15 | 14 13 | 12 13 | l 10 9 | 8 | 7 6 | 5 | 4 3 | 2 | 1 0 | |------------------|---------|----------|------------|------------|------------|------------|--------|--------|--------------------|--------|--------|-------|---|-----|---|-----| | ID | | | | | | | | | | | | | | | | Α | | Reset 0x00000000 | | 0 0 0 | 0 0 0 | 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 ( | 0 | 0 0 | | ID Acce Field | | | | Des | cription | <b>7</b> 4 | | | | | | | | | | | | A W TASKS_RSSIST | TART | | | | t the RSS | | ke one | single | e sam <sub>l</sub> | ole of | the re | eceiv | е | | | | | | Trigger | 1 | | Trig | ger task | | | | | | | | | | | | #### 6.10.13.7 TASKS\_RSSISTOP Address offset: 0x018 Stop the RSSI measurement #### **6.10.13.8 TASKS BCSTART** Address offset: 0x01C Start the bit counter | | Reset 0 | x00000000 | 0 0 0 0 0 | 0000 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 ( | 0 ( | 0 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 0 | |------|---------|-----------|---------------|------------|----------|-------|-------|-------|------|--------|------|-----|---|-----|-----|---|-----| | | ID | | | | | | | | | | | | | | | | | | ID , | Bit num | ber | 31 30 29 28 2 | 7 26 25 24 | 23 22 21 | 20 19 | 18 17 | 16 15 | 14 1 | 3 12 1 | 1 10 | 8 | 7 | 6 5 | 5 4 | 3 | 2 1 | #### 6.10.13.9 TASKS BCSTOP Address offset: 0x020 Stop the bit counter | Bit number | | | | | | 28 2 | 27 26 | 6 25 | 5 24 | 23 | 22 | 21 | 20 1 | 9 1 | 3 17 | 16 | 15 | 14 | 13 1 | 2 13 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | |------------------|---|--------------|---------|----------------------|----------------|------|-------|------|------|----|----|----|------|-----|------|----|----|----|------|------|----|---|---|---|---|---|---|-----|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Reset 0x00000000 | | | | | | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | W | TASKS_BCSTOP | | Stop the bit counter | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Trigger | 1 | 1 Trigger task | | | | | | | | | | | | | | | | | | | | | | | | | | #### 6.10.13.10 EVENTS\_READY Address offset: 0x100 RADIO has ramped up and is ready to be started | Bit n | umber | | 31 30 29 28 2 | 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|--------------|---------------|---------------------------------------------------------------------------| | ID | | | | A | | Rese | t 0x0000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW EVENTS_READY | | | RADIO has ramped up and is ready to be started | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | ### 6.10.13.11 EVENTS\_ADDRESS Address offset: 0x104 Address sent or received #### 6.10.13.12 EVENTS PAYLOAD Address offset: 0x108 Packet payload sent or received | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW EVENTS_PAYLOAD | | | Packet payload sent or received | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | #### 6.10.13.13 EVENTS\_END Address offset: 0x10C Packet sent or received | Bit number | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|----------------------|------------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW EVENTS_END | | | Packet sent or received | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | ### 6.10.13.14 EVENTS\_DISABLED Address offset: 0x110 RADIO has been disabled | Bit r | number | | 31 30 29 28 | 27 26 2 | 5 24 : | 23 22 : | 21 20 | 19 1 | 8 17 | 16 15 | 14 1 | 3 12 | 11 10 | 9 | 8 7 | 6 | 5 | 4 | 3 2 | 1 0 | |-------|--------------------|--------------|-------------|---------|--------|---------|---------|-------|-------|-------|------|------|-------|---|-----|---|---|---|-----|-----| | ID | | | | | | | | | | | | | | | | | | | | А | | Rese | et 0x00000000 | | 0 0 0 0 | 0 0 0 | 0 | 0_0 | 0 0 | 0 ( | 0 0 | 0 0 | 0 0 | 0 ( | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 0 | | ID | | | | | | Descri | ption | 1 | | | | | | | | | | | | | | Α | RW EVENTS_DISABLED | | | | - 7 | RADIO | ) has I | oeen | disal | oled | | | | | | | | | | | | | | NotGenerated | 0 | | | Event | not g | enera | ated | | | | | | | | | | | | | | | Generated | 1 | | | Event | gener | ated | | | | | | | | | | | | | ### 6.10.13.15 EVENTS\_DEVMATCH Address offset: 0x114 A device address match occurred on the last received packet ### 6.10.13.16 EVENTS DEVMISS Address offset: 0x118 No device address match occurred on the last received packet | Bit r | number | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW EVENTS_DEVMISS | | | No device address match occurred on the last received | | | | | | packet | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | #### 6.10.13.17 EVENTS\_RSSIEND Address offset: 0x11C Sampling of receive signal strength complete A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register #### 6.10.13.18 EVENTS BCMATCH Address offset: 0x128 Bit counter reached bit count value Bit counter value is specified in the RADIO.BCC register ### 6.10.13.19 EVENTS\_CRCOK Address offset: 0x130 Packet received with CRC ok #### 6.10.13.20 EVENTS CRCERROR Address offset: 0x134 Packet received with CRC error ### 6.10.13.21 EVENTS\_TXREADY Address offset: 0x154 RADIO has ramped up and is ready to be started TX path | Bit r | number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 | 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------------|--------------|----------------------------------------------------------------|------------------------| | ID | | | | А | | Res | et 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | Value Description | | | Α | RW EVENTS_TXREADY | | RADIO has ramped up and is ready to be | e started TX path | | | | NotGenerated | 0 Event not generated | | | | | Generated | 1 Event generated | | #### 6.10.13.22 EVENTS\_RXREADY Address offset: 0x158 RADIO has ramped up and is ready to be started RX path #### 6.10.13.23 EVENTS MHRMATCH Address offset: 0x15C MAC header match found | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | | А | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW EVENTS_MHRMATCH | | | MAC header match found | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | #### 6.10.13.24 EVENTS\_PHYEND Address offset: 0x16C 4454\_187 v0.5 Generated when last bit is sent on air | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|------------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW EVENTS_PHYEND | | | Generated when last bit is sent on air | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | ### 6.10.13.25 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Di+ m | number. | | 21 20 20 20 27 26 25 2 | M 22 22 21 20 10 10 17 1C 1F 1M 12 12 11 10 0 0 7 C F M 2 2 1 0 | |-------|----------------------|----------|------------------------|-----------------------------------------------------------------| | | number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | ID | | | | UTSR H GFEDCBA | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | | | ID | Acce Field | Value ID | Value | Description | | Α | RW READY_START | | | Shortcut between event READY and task START | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | В | RW END_DISABLE | | | Shortcut between event END and task DISABLE | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | С | RW DISABLED_TXEN | | | Shortcut between event DISABLED and task TXEN | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | D | RW DISABLED_RXEN | | | Shortcut between event DISABLED and task RXEN | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | Ε | RW ADDRESS_RSSISTART | | | Shortcut between event ADDRESS and task RSSISTART | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | F | RW END_START | | | Shortcut between event END and task START | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | G | RW ADDRESS_BCSTART | | | Shortcut between event ADDRESS and task BCSTART | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | Н | RW DISABLED_RSSISTOP | | | Shortcut between event DISABLED and task RSSISTOP | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | R | RW TXREADY_START | | | Shortcut between event TXREADY and task START | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | S | RW RXREADY_START | | | Shortcut between event RXREADY and task START | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | Т | RW PHYEND_DISABLE | | | Shortcut between event PHYEND and task DISABLE | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | U | RW PHYEND_START | | | Shortcut between event PHYEND and task START | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | | | | | | ### 6.10.13.26 INTENSET Address offset: 0x304 Enable interrupt | The composition of composi | אנו ווע | umber | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------|----------|-------------------|---------------------------------------------------------------------| | D Accc Field Value D Value Description | D | | | Z | VUT LKI HGFEDCBA | | A RW READY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled B RW ADDRESS Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled B RW ADDRESS Set 1 Enable Enabled 1 Read: Enabled C RW PAYLOAD Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled D RW END Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Re | leset | t 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | A RW READY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled B RW ADDRESS Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled B RW ADDRESS Set 1 Enable Enabled 1 Read: Enabled C RW PAYLOAD Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled D RW END Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Re | | Acce Field | Value ID | | Description | | Set 1 Read: Disabled 0 Read: Disabled 1 Read: Enabled 1 Read: Enabled 1 Read: Enabled 2 Read: Enabled 3 Read: Enabled 4 Read: Enabled 4 Read: Enabled 4 Read: Enabled 5 Read: Enabled 6 Read: Enabled 7 Read: Enabled 7 Read: Enabled 7 Read: Enabled 8 Read: Disabled 8 Read: Disabled 8 Read: Disabled 8 Read: Disabled 8 Read: Disabled 9 Enabled 9 Read: Enabled 9 Read: Disabled | \ | | | | | | Disabled Disabled Disabled Read: Disabled | | | Set | 1 | | | B RW ADDRESS Set 1 Enable Disabled 0 Red: Enable Enable Enable RW PAYLOAD RW PAYLOAD Set 1 Read: Enable Enable Enable Disabled 0 Red: Disabled Enable Enable Disabled 0 Red: Disabled Enable Enable Disabled 0 Read: Disabled Enable Enable 1 Read: Enable Enable Disabled 0 Read: Disabled Enable Enable 0 Read: Disabled Enable 1 Read: Enabled Disabled Enable 1 Read: Enabled Enable 1 Read: Enabled Enable Enable 1 Read: Enabled Enable Enab | | | | | | | B RW ADDRESS Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled C RW PAYLOAD Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Disabled | | | | | | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled C RW PAYLOAD Set 1 Enable Disabled 0 Read: Disabled Enable 0 Read: Disabled Enable 1 Read: Enabled Disabled 0 Read: Disabled Enable 1 Read: Enabled Disabled 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 1 Read: Enabled Enable Disabled 0 Read: Disabled Enable 1 Read: Enabled Enable Disabled 1 Read: Enabled Enable Disabled 1 Read: Disabled Enable Enabled FRW DEVMISS Set 1 Enable Disabled 0 Read: Disabled Enable 1 Read: Enabled H RW RSSIEND Write '1' to enable interrupt for event DEVMISS Enable 1 Read: Enabled H RW RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register RADIO.RSSISAMPLE register | ł | RW ADDRESS | 21102100 | - | | | Disabled 0 Read: Disabled 1 Read: Enabled C Read: Enabled C Read: Enabled C Read: Enabled Enabled Enabled Enabled Disabled 0 Read: Disabled Read: Enabled Enabled Enabled 1 Read: Enabled Enabled Enabled 1 Read: Enabled Enabled Enabled Disabled 0 Read: Enabled Enabled Enabled 1 I Read: Disabled Enabled Enabled I Read: Disabled Enabled I Read: Disabled Enabled I Read: Enabled I Read: Disabled Enabled I Read: Enable I Read: Enable I Read: Enable I Read: Enable I Read: Enable I Read: Enable I Read | | 7.55.1.255 | Set | 1 | | | Enabled 1 Read: Enabled C RW PAYLOAD Set 1 Enable Disabled 0 Read: Disabled Enable Enable Set 1 Read: Enabled Disabled 1 Read: Enabled Enable Enable Enable Set 1 Enable Enable Enable Disabled 0 Read: Disabled Enabled Enabled 1 Read: Enabled Enabled Enabled 1 Read: Enabled Enabled Enabled 0 Read: Disabled Enabled Enabled 1 Read: Enabled Enable Enable Set 1 Enable Disabled 0 Read: Disabled Enable Enable Enable Enable Set 1 Enable Enable Enable Enable Enable FRW DEVMATCH Set 1 Enable Disabled 0 Read: Disabled Enable Enable Enable Write "1" to enable interrupt for event DEVMATCH Enable Enable Enable Disabled 0 Read: Disabled Enable Enable Enable Enable Freed: Enabled Read: Enabled Freed: A Read: Enabled Freed: Enabled Freed: Enabled Freed: Enabled A Read: Enabled Freed: Enabled Freed: Enabled Freed: Enabled A Read: Enabled Freed: Enabled Freed: Enabled Freed: Enabled A Read: Enabled Freed: Enabled Freed: Enabled Freed: Enabled A Read: Enabled Freed: En | | | | | | | C RW PAYLOAD Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled D RW END Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled D RW END Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled E RW DISABLED Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled F RW DEVMATCH Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled F RW DEVMATCH Set 1 Enable Set 1 Enable Enabled 0 Read: Disabled Enabled 1 Read: Enabled F Enabl | | | | | | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled DISABLED Set 1 Enable Enabled 0 Read: Disabled Enabled 0 Read: Disabled Enable En | | DW DAVIOAD | Eliableu | 1 | | | Disabled Enabled 1 Read: Enabled Disabled 1 Read: Enabled Disabled 5 Read: Disabled Enable Betwork Enabled 5 Read: Disabled Enable 6 Read: Disabled 6 Read: Disabled 6 Read: Disabled 6 Read: Disabled 6 Read: Disabled 7 Read: Enabled 7 Read: Enabled 7 Read: Enabled 8 Read: Disabled 7 Read: Disabled 8 9 Dis | • | RW PATLOAD | Cat | 1 | | | Enabled 1 Read: Enabled D RW END Set 1 Enable Enable Read: Disabled Enable Read: Disabled Enable Read: Disabled Enable Disabled 1 Read: Enabled Enable Enabled 1 Read: Enabled Enable Enable Read: Disabled Enable Disabled 0 Read: Disabled Enable Disabled 1 Read: Enabled FRW DEVMATCH Set 1 Read: Enabled For an Devmatch Set 1 Enable Enabl | | | | | | | D RW END Set Disabled Disabled Enabled Enabled Disabled Enabled Disabled Enabled Disabled Enabled Disabled Disabled Disabled Disabled Disabled Disabled Enabled Disabled Disabled Enabled Disabled Disabled Disabled Disabled Enabled Disabled | | | | | | | Set 1 Read: Disabled 0 Read: Disabled 1 Read: Enabled | | D | Enabled | 1 | | | Disabled Enabled 1 Read: Enabled E RW DISABLED Set 1 Enable Disabled 0 Read: Disabled interrupt for event DISABLED Set 1 Enable F RW DEVMATCH Set 1 Enable Disabled 0 Read: Disabled interrupt for event DEVMATCH Set 1 Enable Disabled 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled F RW DEVMISS Set 1 Enable Disabled 0 Read: Disabled Enable 0 Read: Disabled F Read: Enable Interrupt for event DEVMISS Set 1 Enable Disabled 1 Read: Enabled H RW RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Enable Set 1 Enable | ) | RW END | | | | | Enabled E RW DISABLED Set Disabled Disabled Enabled Disabled Dis | | | | 1 | | | E RW DISABLED Set Disabled Disabled Enable Disabled Disa | | | | | | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled F RW DEVMATCH Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled G RW DEVMISS Set 1 Read: Enabled G RW DEVMISS Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event DEVMISS Enable Enabled 0 Read: Disabled Enabled 1 Read: Enabled H RW RSSIEND Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Enabled | 1 | | | Disabled 0 Read: Disabled Enabled 1 Read: Enabled F RW DEVMATCH Set 1 Enable Disabled 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Enabled G RW DEVMISS Set 1 Enable Disabled 0 Read: Disabled Enable 0 Read: Disabled Finable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Disabled Enable 0 Read: Enabled H RW RSSIEND Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | RW DISABLED | <b>X</b> | | | | Enabled 1 Read: Enabled F RW DEVMATCH Set Disabled Disa | | | Set | 1 | Enable | | F RW DEVMATCH Set Disabled Enable Enable Read: Disabled Enabled Fenable Write '1' to enable interrupt for event DEVMATCH Read: Disabled Enabled Write '1' to enable interrupt for event DEVMISS Set Disabled Enable Disabled Enable The read: Enabled Write '1' to enable interrupt for event DEVMISS Fenable Write '1' to enable interrupt for event RESIEND A new RESSIEND A new RESSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Disabled | 0 | Read: Disabled | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled G RW DEVMISS Set 1 Enable Disabled 0 Read: Disabled Enable Enable Write '1' to enable interrupt for event DEVMISS Enable Read: Disabled Enabled 1 Read: Enabled H RW RSSIEND Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Enabled | 1 | Read: Enabled | | Disabled 0 Read: Disabled Enabled 1 Read: Enabled G RW DEVMISS Set 1 Enable Disabled 0 Read: Disabled Enable Disabled 1 Read: Disabled Enabled 1 Read: Enabled H RW RSSIEND Write '1' to enable interrupt for event DEVMISS Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | RW DEVMATCH | | | Write '1' to enable interrupt for event DEVMATCH | | Enabled 1 Read: Enabled Write '1' to enable interrupt for event DEVMISS Set Disabled Enabled Disabled Enabled Disabled Enabled Disabled Enabled Disabled Enabled Disabled EnableD Disabled Enable Disabled Enable Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Enable | | | Set | 1 | Enable | | G RW DEVMISS Set 1 Enable Disabled Enabled 1 Read: Disabled Enabled H RW RSSIEND Write '1' to enable interrupt for event DEVMISS Read: Disabled Fenabled Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Disabled | 0 | Read: Disabled | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled H RW RSSIEND Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Enabled | 1 | Read: Enabled | | Disabled 0 Read: Disabled Enabled 1 Read: Enabled H RW RSSIEND Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | à | RW DEVMISS | | | Write '1' to enable interrupt for event DEVMISS | | Enabled 1 Read: Enabled Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Set | 1 | Enable | | H RW RSSIEND Write '1' to enable interrupt for event RSSIEND A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Disabled | 0 | Read: Disabled | | A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register Set 1 Enable | | | Enabled | 1 | Read: Enabled | | RADIO.RSSISAMPLE register Set 1 Enable | ł | RW RSSIEND | | • | Write '1' to enable interrupt for event RSSIEND | | RADIO.RSSISAMPLE register Set 1 Enable | | | | | A new RSSI sample is ready for readout from the | | Set 1 Enable | | | | | | | | | | Cot | 1 | | | | | | | | | | | | | | | | | Enabled 1 Read: Enabled | | DIAL DOMATCH | Enabled | 1 | | | I RW BCMATCH Write '1' to enable interrupt for event BCMATCH | | RW BCMAICH | | | Write '1' to enable interrupt for event BCMAICH | | Bit counter value is specified in the RADIO.BCC register | | | | | Bit counter value is specified in the RADIO.BCC register | | Set 1 Enable | | | Set | 1 | Enable | | Disabled 0 Read: Disabled | | | Disabled | 0 | Read: Disabled | | Enabled 1 Read: Enabled | | | Enabled | 1 | Read: Enabled | | K RW CRCOK Write '1' to enable interrupt for event CRCOK | | RW CRCOK | | | Write '1' to enable interrupt for event CRCOK | | | | | Set | 1 | Enable | | Set 1 Enable | | | Disabled | 0 | Read: Disabled | | | | | | | | | | | | Enabled | 1 | Read: Enabled | | Bit n | umber | | 31 30 | 29 28 | 3 27 2 | 26 25 | 5 24 | 23 | 22 2 | 21 2 | 20 19 | 9 18 | 17 | 16 | 15 1 | .4 1 | 3 1 | 2 1 | 1 10 | 9 | 8 | 7 | 6 | 5 4 | 4 3 | 2 | 1 | 0 | |-------|---------------|----------|-------|-------|--------|-------|------|-------------------------------------|--------|-------|-------|------|-------|-----|----------|------|-----|-----|------|-----|-----|---|---|-----|-----|---|---|---| | ID | | | | | Z | | | ٧ | U | Т | | | | | | L | . k | < | -1 | | | Н | G | F | E D | С | В | Α | | Rese | et 0x00000000 | | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | | | 0 | 0 ( | 0 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Set | 1 | | | | | Ena | able | 9 | | | | | | | | | | | | | | | | | | | | | | Disabled | 0 | | | | | Rea | ad: [ | Disa | able | d | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | Rea | ad: I | Ena | bled | I | | | | | | | | | | | | | | | | | | Т | RW TXREADY | | | | | | | Wr | rite ' | '1' t | o en | able | e int | err | upt | for | eve | ent | TXR | EAC | Υ | | | | | | | | | | | Set | 1 | | | | | Ena | able | 9 | | | | | | | | | | | | | | | | | | | | | | Disabled | 0 | | | | | Rea | ad: [ | Disa | able | d | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | Rea | ad: I | Ena | bled | ı | | | | | | | | | | | | | | | | | | U | RW RXREADY | | | | | | | Wr | rite ' | '1' t | o en | able | e int | err | upt | for | eve | ent | RXR | EAD | Υ | | | | | | | | | | | Set | 1 | | | | | Ena | able | 9 | | | | | | | | | | | | | | | | | | | | | | Disabled | 0 | | | | | Rea | ad: [ | Disa | able | d 🖣 | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | Rea | ad: I | Ena | bled | I _ | | | | | | | | | | | | | | | | | | V | RW MHRMATCH | | | | | | | Wr | rite ' | '1' t | o en | able | e int | err | upt | for | eve | ent | МН | RM | ATC | Н | | | | | | | | | | Set | 1 | | | | | Ena | able | 9 | | | | | <b>)</b> | | | | | | | | | | | | | | | | | Disabled | 0 | | | | - | Rea | ad: I | Disa | able | d | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | Rea | ad: I | Ena | bled | | | | | | | | | | | | | | | | | | | Z | RW PHYEND | | | | | | | Wr | rite ' | '1' t | o en | able | e int | err | upt | for | eve | ent | PHY | ENI | ) | | | | | | | | | | | Set | 1 | | • | ¥ | | Ena | able | 2 | | | | | | | V | | 7 | | | | | | | | | | | | | Disabled | 0 | | | | | Rea | ad: [ | Disa | able | d | | | | | | V | | | | | | | | | | | | | | Enabled | 1 | | | | | Rea | ad: E | Ena | bled | | | | | | | ٦ | | | | | | | | | | | ### 6.10.13.27 INTENCLR Address offset: 0x308 Disable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|-------------|---------------|------------------------|-----------------------------------------------------------------| | ID | | | Z | VUT LKI HGFEDCBA | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | | | | ID | Acce Field | | Value | Description | | Α | RW READY | | | Write '1' to disable interrupt for event READY | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | , 1 | Read: Enabled | | В | RW ADDRESS | | | Write '1' to disable interrupt for event ADDRESS | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW PAYLOAD | | | Write '1' to disable interrupt for event PAYLOAD | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW END | | | Write '1' to disable interrupt for event END | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Ε | RW DISABLED | | | Write '1' to disable interrupt for event DISABLED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | | | | | Bit nu | umber | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|--------------|----------|----------------------|------------------------------------------------------------------| | ID | | | Z | VUT LKI HGFEDCBA | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | F | RW DEVMATCH | | | Write '1' to disable interrupt for event DEVMATCH | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | G | RW DEVMISS | | | Write '1' to disable interrupt for event DEVMISS | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Н | RW RSSIEND | | | Write '1' to disable interrupt for event RSSIEND | | | | | | A new RSSI sample is ready for readout from the | | | | | | RADIO.RSSISAMPLE register | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | 1 | RW BCMATCH | Ellableu | 1 | Write '1' to disable interrupt for event BCMATCH | | ' | KW BCIVIATCH | | | | | | | | | Bit counter value is specified in the RADIO.BCC register | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | K | RW CRCOK | | | Write '1' to disable interrupt for event CRCOK | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | L | RW CRCERROR | | | Write '1' to disable interrupt for event CRCERROR | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Т | RW TXREADY | | | Write '1' to disable interrupt for event TXREADY | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | U | RW RXREADY | | | Write '1' to disable interrupt for event RXREADY | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | V | RW MHRMATCH | | | Write '1' to disable interrupt for event MHRMATCH | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Z | RW PHYEND | | | Write '1' to disable interrupt for event PHYEND | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | | | | ### 6.10.13.28 CRCSTATUS Address offset: 0x400 CRC status | Bit number | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|----------------------|--------------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A R CRCSTATUS | | | CRC status of packet received | | | CRCError | 0 | Packet received with CRC error | | | CRCOk | 1 | Packet received with CRC ok | #### 6.10.13.29 RXMATCH Address offset: 0x408 Received address | Bit number | | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | |------------------|--|---------------------|-------------------------------------------------------------------| | ID | | | A A | | Reset 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A R RXMATCH | | | Received address | Logical address of which previous packet was received #### 6.10.13.30 RXCRC Address offset: 0x40C CRC field of previously received packet #### 6.10.13.31 DAI Address offset: 0x410 Device address match index | A R DAI | | Device address match index | |------------------|----------------------|------------------------------------------------------------------| | ID Acce Field | | | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | A A A | | Bit number | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | Index (n) of device address, see DAB[n] and DAP[n], that got an address match #### 6.10.13.32 PDUSTAT Address offset: 0x414 Payload status | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|-------------|------------------------|-----------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A R PDUSTAT | | | Status on payload length vs. PCNF1.MAXLEN | | | LessThan | 0 | Payload less than PCNF1.MAXLEN | | | GreaterThan | 1 | Payload greater than PCNF1.MAXLEN | #### 6.10.13.33 PACKETPTR Address offset: 0x504 Packet pointer | Bit number | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | |------------------|----------|----------------------|------------------------------------------------------------------| | ID | | A A A A A A | | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | Value | Description | RW PACKETPTR Packet pointer Packet address to be used for the next transmission or reception. When transmitting, the packet pointed to by this address will be transmitted and when receiving, the received packet will be written to this address. This address is a byte aligned RAM address. **Note:** See the memory chapter for details about which memories are available for EasyDMA. # 6.10.13.34 FREQUENCY Address offset: 0x508 Frequency | Bit n | umber | | 31 | 30 | 29 | 28 2 | 27 2 | 26 2 | 5 24 | 4 2 | 3 22 | 21 | . 20 | 19 | 18 1 | .7 1 | 6 15 | 5 14 | 13 | 12 | 11 1 | 0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|---------------|----------|----|-----|-----|------|------|------|------|-----|------|-----|------|------|------|------|------|------|-------|-----|------|-----|----|---|---|---|---|---|----|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | В | | Α | Α | Α | Α | Α. | А А | | Rese | et 0x00000002 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | ) ( | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 0 | | ID | | Value ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW FREQUENCY | | [0 | .10 | 00] | | | | | R | adic | ch | ann | el f | req | uen | су | | | | | | | | | | | | | | | | | | | | | | | | | F | requ | ıen | cy = | 24 | 00 + | - FR | EQI | JEN | CY | (M | Ηz). | | | | | | | | | | | В | RW MAP | | | | | | | | | С | han | nel | ma | p se | lec | tior | ١. | | | | | | | | | | | | | | | | | Default | 0 | | | | | | | С | han | nel | ma | p b | etw | een | 240 | 1 00 | ИΗΖ | 2 | 2500 | MH | łz | | | | | | | | | | | | | | | | | | | F | requ | ıen | cy = | 24 | 00 + | - FR | EQI | JEN | ICY ( | (MH | łz) | | | | | | | | | | | | | Low | 1 | | | | | | | С | han | nel | ma | p b | etw | een | 236 | 1 0 | ИΗΖ | 2 | 2460 | MH | łz | | | | | | | | | | | | | | | | | | | F | requ | uen | су = | 23 | 60 + | - FR | EQI | JEN | ICY | (M | Hz) | | | | | | | | | | #### 6.10.13.35 TXPOWER Address offset: 0x50C Output power | Bit r | umber | | 31 30 29 28 27 | <sup>7</sup> 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 | |-------|---------------|----------|----------------|-----------------------------------------------------------------------------------|------| | ID | | | | A A A A A A | A | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | ID | | | | | | | Α | RW TXPOWER | | | RADIO output power | | | | | | | Output power in number of dBm, i.e. if the value -20 is | | | | | | | specified the output power will be set to -20 dBm. | | | | | Pos4dBm | 0x4 | +4 dBm | | | | | Pos3dBm | 0x3 | +3 dBm | | | | | 0dBm | 0x0 | 0 dBm | | | | | Neg4dBm | 0xFC | -4 dBm | | | | | Neg8dBm | 0xF8 | -8 dBm | | | | | Neg12dBm | 0xF4 | -12 dBm | | | | | Neg16dBm | 0xF0 | -16 dBm | | | | | Neg20dBm | 0xEC | -20 dBm | | | | | Neg30dBm | 0xE2 | -40 dBm Depreca | ited | | | | Neg40dBm | 0xD8 | -40 dBm | | # 6.10.13.36 MODE Address offset: 0x510 Data rate and modulation # 6.10.13.37 PCNF0 Address offset: 0x514 Packet configuration register 0 | Bit n | umber | | 31 30 29 28 27 26 | 25 2 | 4 2 | 3 22 2 | 21 2 | 0 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 1 | .0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---------------|-----------|-------------------|------|-----|--------|-------|-------|-------|-------|-------|-------|------|------|------|------|-------|------|-----|-----|-------|-----|---|---|----|---| | ID | | | 1 | н | 4 | | ı | F E | Ε | Ε | Ε | | | | | | | С | | | | | Α | Α | Α. | Α | | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 ( | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW LFLEN | | | | L | ength | on | air d | of LE | NG | тн | l fie | ld i | n n | um | ber | of b | its. | | | | | | | | | | С | RW SOLEN | | | | L | ength | on | air d | of S | ) fie | eld | in r | num | nbe | r of | f by | tes. | | | | | | | | | | | E | RW S1LEN | | | | L | ength | on | air d | of S | 1 fie | eld | in r | num | nbe | r of | fbit | s. | | | | | | | | | | | F | RW S1INCL | | | | Ir | nclude | e or | excl | ude | S1 | fie | ld i | n R | ΑM | 1 | | | | | | | | | | | | | | | Automatic | 0 | | Ir | nclude | e S1 | field | d in | RA | M c | only | if : | S1L | .EN | > 0 | | | | | | | | | | | | | | Include | 1 | | Α | lways | s inc | lude | S1 | fiel | ld ir | n RA | ٩M | ind | dep | end | ent | of S | 1LE | ΕN | | | | | | | | Н | RW PLEN | | | | L | ength | of | prea | mb | le o | n a | ir. C | Dec | isio | n p | oin | t: TA | SKS | S_S | TAR | RT ta | ask | | | | | | | | 8bit | 0 | | 8 | -bit p | rea | mble | 9 | | | | | | | | | | | | | | | | | | | | | 16bit | 1 | | 1 | 6-bit | prea | amb | le | | | | | | | | | | | | | | | | | | | Bit nu | umber | | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|--------------|---------|-------------------|-----------------------------------------------------------------------| | ID | | | 1 | H H F E E E E C A A A A | | Reset | t 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | 1 | RW CRCINC | | | Indicates if LENGTH field contains CRC or not | | | | Exclude | 0 | LENGTH does not contain CRC | | | | Include | 1 | LENGTH includes CRC | # 6.10.13.38 PCNF1 Address offset: 0x518 Packet configuration register 1 | Bit n | umber | | 31 30 29 | 9 28 27 | 7 26 2 | 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|----------|---------|--------|-------|-----------------------------------------------------------------| | ID | | | | | | E D | C C C B B B B B B B A A A A A A A A | | Rese | et 0x00000000 | | 0 0 0 | 0 0 | 0 | 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | | Description | | Α | RW MAXLEN | | [0255] | | | | Maximum length of packet payload. If the packet payload is | | | | | | | | | larger than MAXLEN, the radio will truncate the payload to | | | | | | | 4 | | MAXLEN. | | В | RW STATLEN | | [0255] | | | | Static length in number of bytes | | | | | | | 7. | | The static length parameter is added to the total length | | | | | | K | | | of the payload when sending and receiving packets, e.g. if | | | | | | | | | the static length is set to N the radio will receive or send N | | | | | | | | | bytes more than what is defined in the LENGTH field of the | | | | XI | | | | | packet. | | С | RW BALEN | | [24] | | | | Base address length in number of bytes | | | | | | | | | The address field is composed of the base address and the | | | | | | | | ٦ | one byte long address prefix, e.g. set BALEN=2 to get a total | | | | | | | 7 | | address of 3 bytes. | | D | RW ENDIAN | | | V | | | On-air endianness of packet, this applies to the SO, LENGTH, | | | | | | | | | S1, and the PAYLOAD fields. | | | | Little | 0 | | , | | Least significant bit on air first | | | | Big | 1 | | | | Most significant bit on air first | | E | RW WHITEEN | | | | | | Enable or disable packet whitening | | | | Disabled | 0 | | | | Disable | | | | Enabled | 1 | | | | Enable | ## 6.10.13.39 BASEO Address offset: 0x51C Base address 0 | tion | |--------------------------------------------------------| | | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | A A A A A A A A A A A A A A A A A A A | | 1 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | # 6.10.13.40 BASE1 Address offset: 0x520 #### Base address 1 #### 6.10.13.41 PREFIXO Address offset: 0x524 Prefixes bytes for logical addresses 0-3 #### 6.10.13.42 PREFIX1 Address offset: 0x528 Prefixes bytes for logical addresses 4-7 # 6.10.13.43 TXADDRESS Address offset: 0x52C Transmit address select | Bit number | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | |------------------|-------------------------|---------------------------------------------------------------| | ID | | A A . | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | A RW TXADDRESS Transmit address select Logical address to be used when transmitting a packet ## 6.10.13.44 RXADDRESSES Address offset: 0x530 Receive address select | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | HGFEDCBA | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A-H RW ADDR[i] (i=07) | | | Enable or disable reception on logical address i. | | | Disabled | 0 | Disable | | | Enabled | 1 | Enable | ## 6.10.13.45 CRCCNF Address offset: 0x534 CRC configuration | Bit r | umber | | 31 30 | 29 | 28 2 | 7 26 | 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------|----|------|------|------|------------------------------------------------------------------| | ID | | | | | | | | в в АА | | Rese | et 0x00000000 | | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | | | Description | | Α | RW LEN | | [13] | | | | | CRC length in number of bytes. | | | | Disabled | 0 | | | | | CRC length is zero and CRC calculation is disabled | | | | One | 1 | | | | | CRC length is one byte and CRC calculation is enabled | | | | Two | 2 | | | | ٩ | CRC length is two bytes and CRC calculation is enabled | | | | Three | 3 | | 9 | 7 | | CRC length is three bytes and CRC calculation is enabled | | В | RW SKIPADDR | | | | | | | Include or exclude packet address field out of CRC | | | | | | | | | | calculation. | | | | Include | 0 | | | | | CRC calculation includes address field | | | | Skip | 1 | | | | | CRC calculation does not include address field. The CRC | | | | | | | | | | calculation will start at the first byte after the address. | # 6.10.13.46 CRCPOLY Address offset: 0x538 CRC polynomial | Bit r | number | | 31 | 30 2 | 9 28 | 27 | 26 25 | 5 24 | 23 | 22 | 21 2 | 20 19 | 9 18 | 17 | 16 | 15 : | 14 1 | 3 12 | 2 11 | 10 | 9 | 8 | 7 | 6 | 5 . | 4 3 | 2 | 1 | 0 | |-------|---------------|----------|----|------|------|----|-------|------|----|-----|------|-------|------|----|----|------|------|------|------|----|---|---|---|---|-----|-----|---|---|---| | ID | | | | | | | | | Α | Α | A | ΑА | Α | Α | Α | Α | A A | A A | Α | Α | Α | Α | Α | Α | A , | Α Α | A | Α | Α | | Rese | et 0x00000000 | | 0 | 0 ( | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | ID | | Value ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW CRCPOLY | | | | | | | | CR | Сро | olyn | omi | al | | | | | | | | | | | | | | | | | Each term in the CRC polynomial is mapped to a bit in this register which index corresponds to the term's exponent. The least significant term/bit is hardwired internally to 1, and bit number 0 of the register content is ignored by the hardware. The following example is for an 8 bit CRC polynomial: $x8 + x7 + x3 + x2 + 1 = 1\,1000\,1101$ . ## 6.10.13.47 CRCINIT Address offset: 0x53C CRC initial value | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ID | |----------------------------------------------------------------------------------------------------| | ID A A A A A A A A A A A A A A A A A A A | | | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | | | Initial value for CRC calculation #### 6.10.13.48 TIFS Address offset: 0x544 Interframe spacing in µs | ID | Acce Field | Value ID | Value | Description | P | | | | | | | | | | |-------|---------------|----------|---------------------|----------------------------|------|-----------|----------|----|-----|---|-----|-----|---|-----| | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 | 0 0 | 0 0 0 | 0 | 0 0 | 0 | 0 ( | 0 | 0 | 0 0 | | ID | | | | | | | | Α. | 4 A | Α | A A | A A | Α | А А | | Bit r | umber | | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 | 16 1 | 5 14 13 : | 12 11 10 | 9 | 8 7 | 6 | 5 4 | 1 3 | 2 | 1 0 | A RW TIFS Interframe spacing in $\mu$ s Interframe space is the time interval between two consecutive packets. It is defined as the time, in microseconds, from the end of the last bit of the previous packet to the start of the first bit of the subsequent packet. # 6.10.13.49 RSSISAMPLE Address offset: 0x548 RSSI sample | Bit number | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------| | ID | | A A A A A A | | Reset 0x00000000 | 0 0 0 0 0 0 0 | | | ID Acce Field Value ID | Value | Description | | A R RSSISAMPLE | [0127] | RSSI sample | | | | RSSI sample result. The value of this register is read as a positive value while the actual received signal strength is a | | | | negative value. Actual received signal strength is therefore | | | | as follows: received signal strength = -A dBm | ## 6.10.13.50 STATE Address offset: 0x550 Current radio state #### 6.10.13.51 DATAWHITEIV Address offset: 0x554 Data whitening initial value #### 6.10.13.52 BCC Address offset: 0x560 Bit counter compare Bit counter compare register # 6.10.13.53 DAB[n] (n=0..7) Address offset: $0x600 + (n \times 0x4)$ Device address base segment n # 6.10.13.54 DAP[n] (n=0..7) Address offset: $0x620 + (n \times 0x4)$ Device address prefix n | ID A | | | | | | on | | | | | | | | | | | | | | |---------|-----------|-------------|------------|-------|-------|-------|-------|--------|------|------|-------|----|-----|---|---|----|-----|-----|-----| | | | | | | | | | | | | | | | | | | | | | | Reset 0 | (00000000 | 0 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 ( | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 ( | 0 0 | | ID | | | | | | | | | A A | A | A A | Α. | А А | A | Α | Α. | А А | A A | A A | | Bit num | ber | 31 30 29 28 | 3 27 26 25 | 24 23 | 22 21 | 20 19 | 18 17 | 7 16 : | 15 1 | 4 13 | 12 11 | 10 | 9 8 | 7 | 6 | 5 | 4 3 | 2 1 | 1 0 | #### 6.10.13.55 DACNF Address offset: 0x640 Device address match configuration # 6.10.13.56 MODECNFO Address offset: 0x650 Radio mode configuration register 0 | Bit number | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|---------|----------------------|------------------------------------------------------------------| | ID | | | C C A | | Reset 0x00000200 | | 0 0 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID Acce Field | | | | | A RW RU | | | Radio ramp-up time | | | Default | 0 | Default ramp-up time (tRXEN and tTXEN), compatible with | | | | | firmware written for nRF51 | | | Fast | 1 | Fast ramp-up (tRXEN,FAST and tTXEN,FAST), see electrical | | | | | specification for more information | | | | | When enabled, TIFS is not enforced by hardware and | | | | | software needs to control when to turn on the Radio. | | | | | | | Bit number | | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------|------------------|-----------------------------------------------------------------------| | ID | | | C C A | | Reset 0x00000200 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | C RW DTX | | | Default TX value | | | | | Specifies what the RADIO will transmit when it is not | | | | | started, i.e. between: | | | | | RADIO.EVENTS_READY and RADIO.TASKS_START | | | | | RADIO.EVENTS_END and RADIO.TASKS_START | | | | | RADIO.EVENTS_END and RADIO.EVENTS_DISABLED | | | B1 | 0 | Transmit '1' | | | ВО | 1 | Transmit '0' | | | Center | 2 | Transmit center frequency | | | | | When tuning the crystal for center frequency, the RADIO | | | | | must be set in DTX = Center mode to be able to achieve the | | | | | expected accuracy | #### 6.10.13.57 POWER Address offset: 0xFFC Peripheral power control # 6.10.14 Electrical specification # 6.10.14.1 General radio characteristics | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------------|----------------------------------|------|------|------|-------| | f <sub>OP</sub> | Operating frequencies | 2360 | | 2500 | MHz | | f <sub>PLL,CH,SP</sub> | PLL channel spacing | | 1 | | MHz | | f <sub>DELTA,1M</sub> | Frequency deviation @ 1 Mbps | | ±170 | | kHz | | f <sub>DELTA,BLE,1M</sub> | Frequency deviation @ BLE 1 Mbps | | ±250 | | kHz | | f <sub>DELTA,2M</sub> | Frequency deviation @ 2 Mbps | | ±320 | | kHz | | f <sub>DELTA,BLE,2M</sub> | Frequency deviation @ BLE 2 Mbps | | ±500 | | kHz | | fsk <sub>BPS</sub> | On-the-air data rate | 125 | | 2000 | kbps | # 6.10.14.2 Radio current consumption (transmitter) | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------------|-----------------------------------------------------------|------|------|------|-------| | I <sub>TX,PLUS4dBM,DCDC</sub> | TX only run current (DC/DC, 3 V) P <sub>RF</sub> = +4 dBm | | 7.0 | | mA | | I <sub>TX,PLUS4dBM</sub> | TX only run current P <sub>RF</sub> = +4 dBm | | 15.4 | | mA | | Symbol | Description | | Min. | Тур. | Max. | Units | |---------------------------------|---------------------------------------------------------|---|------|------|------|-------| | I <sub>TX,0dBM,DCDC</sub> | TX only run current (DC/DC, 3 V)P <sub>RF</sub> = 0 dBm | | | 4.6 | | mA | | I <sub>TX,0dBM</sub> | TX only run current P <sub>RF</sub> = 0 dBm | | | 10.1 | | mA | | I <sub>TX,MINUS4dBM,DCDC</sub> | TX only run current DC/DC, 3 V $P_{RF}$ = -4 dBm | | | 3.6 | | mA | | I <sub>TX,MINUS4dBM</sub> | TX only run current P <sub>RF</sub> = -4 dBm | | | 7.8 | | mA | | I <sub>TX,MINUS8dBM,DCDC</sub> | TX only run current DC/DC, 3 V $P_{RF}$ = -8 dBm | | | 3.2 | | mA | | I <sub>TX,MINUS8dBM</sub> | TX only run current P <sub>RF</sub> = -8 dBm | | | 6.8 | | mA | | I <sub>TX,MINUS12dBM,DCDC</sub> | TX only run current DC/DC, 3 V $P_{RF}$ = -12 dBm | | | 2.9 | | mA | | I <sub>TX,MINUS12dBM</sub> | TX only run current P <sub>RF</sub> = -12 dBm | | | 6.2 | | mA | | I <sub>TX,MINUS16dBM,DCDC</sub> | TX only run current DC/DC, 3 V $P_{RF}$ = -16 dBm | | | 2.7 | | mA | | I <sub>TX,MINUS16dBM</sub> | TX only run current P <sub>RF</sub> = -16 dBm | | | 5.7 | | mA | | I <sub>TX,MINUS20dBM,DCDC</sub> | TX only run current DC/DC, 3 V $P_{RF}$ = -20 dBm | | | 2.5 | | mA | | I <sub>TX,MINUS20dBM</sub> | TX only run current P <sub>RF</sub> = -20 dBm | | | 5.4 | | mA | | I <sub>TX,MINUS40dBM,DCDC</sub> | TX only run current DC/DC, 3 V $P_{RF}$ = -40 dBm | | | 2.1 | | mA | | I <sub>TX,MINUS40dBM</sub> | TX only run current P <sub>RF</sub> = -40 dBm | | | 4.3 | | mA | | I <sub>START,TX,DCDC</sub> | TX start-up current DC/DC, 3 V, P <sub>RF</sub> = 4 dBm | | | | | mA | | I <sub>START,TX</sub> | TX start-up current, P <sub>RF</sub> = 4 dBm | • | | | | mA | # 6.10.14.3 Radio current consumption (Receiver) | Symbol | Description | Mir | 1. | Тур. Мах. | Units | |-------------------------------|----------------------------------------------------|-----|----|-----------|-------| | I <sub>RX,1M,DCDC</sub> | RX only run current (DC/DC, 3 V) 1 Mbps/1 Mbps BLE | | | 4.6 | mA | | I <sub>RX,1M</sub> | RX only run current (LDO, 3 V) 1 Mbps/1 Mbps BLE | | | 10.0 | mA | | I <sub>RX,2M,DCDC</sub> | RX only run current (DC/DC, 3 V) 2 Mbps/2 Mbps BLE | | | 5.2 | mA | | I <sub>RX,2M</sub> | RX only run current (LDO, 3 V) 2 Mbps/2 Mbps BLE | | | 11.2 | mA | | I <sub>START,RX,1M,DCDC</sub> | RX start-up current (DC/DC, 3 V) 1 Mbps/1 Mbps BLE | | | 3.5 | mA | | I <sub>START,RX,1M</sub> | RX start-up current 1 Mbps/1 Mbps BLE | | | 6.7 | mA | # 6.10.14.4 Transmitter specification | Symbol | Description | Min. | Тур. | Max. | Units | |--------------------|----------------------------------------------------|------|------|------|-------| | P <sub>RF</sub> | Maximum output power | | 4.0 | | dBm | | P <sub>RFC</sub> | RF power control range | | 24 | | dB | | P <sub>RFCR</sub> | RF power accuracy | | | ±4 | dB | | P <sub>RF1,1</sub> | 1st Adjacent Channel Transmit Power 1 MHz (1 Mbps) | | -25 | | dBc | | P <sub>RF2,1</sub> | 2nd Adjacent Channel Transmit Power 2 MHz (1 Mbps) | | -50 | | dBc | | P <sub>RF1,2</sub> | 1st Adjacent Channel Transmit Power 2 MHz (2 Mbps) | | -25 | | dBc | | P <sub>RF2,2</sub> | 2nd Adjacent Channel Transmit Power 4 MHz (2 Mbps) | | -50 | | dBc | Figure 50: Output power, 1 Mbps Bluetooth low energy mode, at maximum TXPOWER setting (typical values) Figure 51: Output power, 1 Mbps Bluetooth low energy mode, at 0 dBm TXPOWER setting (typical values) ## 6.10.14.5 Receiver operation | Symbol | Description | Min. | Тур. | Max. | Units | |--------------------------------|----------------------------------------------------------------|------|------|------|-------| | P <sub>RX,MAX</sub> | Maximum received signal strength at < 0.1% PER | | 0 | | dBm | | P <sub>SENS,IT,1M</sub> | Sensitivity, 1 Mbps nRF mode ideal transmitter <sup>14</sup> | | -92 | | dBm | | P <sub>SENS,IT,2M</sub> | Sensitivity, 2 Mbps nRF mode ideal transmitter <sup>15</sup> | | -89 | | dBm | | P <sub>SENS,IT,SP,1M,BLE</sub> | Sensitivity, 1 Mbps BLE ideal transmitter, packet length ≤ 37 | | -95 | | dBm | | | bytes BER=1E-3 <sup>16</sup> | | | | | | P <sub>SENS,IT,LP,1M,BLE</sub> | Sensitivity, 1 Mbps BLE ideal transmitter, packet length ≥ 128 | | -94 | | dBm | | | bytes BER=1E-4 <sup>17</sup> | | | | | | P <sub>SENS,IT,SP,2M,BLE</sub> | Sensitivity, 2 Mbps BLE ideal transmitter, packet length ≤ 37 | | -92 | | dBm | | | bytes | | | | | Figure 52: Sensitivity, 1 Mbps Bluetooth low energy mode, Regulator = LDO (typical values) #### 6.10.14.6 RX selectivity RX selectivity with equal modulation on interfering signal<sup>18</sup> <sup>&</sup>lt;sup>14</sup> Typical sensitivity applies when ADDR0 is used for receiver address correlation. When ADDR[1...7] are used for receiver address correlation, the typical sensitivity for this mode is degraded by 3 dB. Typical sensitivity applies when ADDR0 is used for receiver address correlation. When ADDR[1..7] are used for receiver address correlation, the typical sensitivity for this mode is degraded by 3 dB. As defined in the Bluetooth Core Specification v4.0 Volume 6: Core System Package (Low Energy Controller Volume) <sup>&</sup>lt;sup>17</sup> Equivalent BER limit < 10E-04 Desired signal level at PIN = -67 dBm. One interferer is used, having equal modulation as the desired signal. The input power of the interferer where the sensitivity equals BER = 0.1% is presented | Symbol | Description | Min. | Тур. | Max. | Units | |----------------------------------|----------------------------------------------------------|------|------|------|-------| | C/I <sub>1M,co-channel</sub> | 1Mbps mode, Co-Channel interference | | 9 | | dB | | C/I <sub>1M,-1MHz</sub> | 1 Mbps mode, Adjacent (-1 MHz) interference | | -2 | | dB | | C/I <sub>1M,+1MHz</sub> | 1 Mbps mode, Adjacent (+1 MHz) interference | | -10 | | dB | | C/I <sub>1M,-2MHz</sub> | 1 Mbps mode, Adjacent (-2 MHz) interference | | -19 | | dB | | C/I <sub>1M,+2MHz</sub> | 1 Mbps mode, Adjacent (+2 MHz) interference | | -42 | | dB | | C/I <sub>1M,-3MHz</sub> | 1 Mbps mode, Adjacent (-3 MHz) interference | | -38 | | dB | | C/I <sub>1M,+3MHz</sub> | 1 Mbps mode, Adjacent (+3 MHz) interference | | -48 | | dB | | C/I <sub>1M,±6MHz</sub> | 1 Mbps mode, Adjacent (≥6 MHz) interference | | -50 | | dB | | C/I <sub>1MBLE,co-channel</sub> | 1 Mbps BLE mode, Co-Channel interference | | 6 | | dB | | C/I <sub>1MBLE,-1MHz</sub> | 1 Mbps BLE mode, Adjacent (-1 MHz) interference | | -2 | | dB | | C/I <sub>1MBLE,+1MHz</sub> | 1 Mbps BLE mode, Adjacent (+1 MHz) interference | | -9 | | dB | | C/I <sub>1MBLE,-2MHz</sub> | 1 Mbps BLE mode, Adjacent (-2 MHz) interference | | -22 | | dB | | C/I <sub>1MBLE,+2MHz</sub> | 1 Mbps BLE mode, Adjacent (+2 MHz) interference | | -46 | | dB | | C/I <sub>1MBLE,&gt;3MHz</sub> | 1 Mbps BLE mode, Adjacent (≥3 MHz) interference | | -50 | | dB | | C/I <sub>1MBLE,image</sub> | Image frequency interference | | -22 | | dB | | C/I <sub>1MBLE,image,1MHz</sub> | Adjacent (1 MHz) interference to in-band image frequency | | -35 | | dB | | C/I <sub>2M,co-channel</sub> | 2 Mbps mode, Co-Channel interference | | 10 | | dB | | C/I <sub>2M,-2MHz</sub> | 2 Mbps mode, Adjacent (-2 MHz) interference | | 6 | | dB | | C/I <sub>2M,+2MHz</sub> | 2 Mbps mode, Adjacent (+2 MHz) interference | | -14 | | dB | | C/I <sub>2M,-4MHz</sub> | 2 Mbps mode, Adjacent (-4 MHz) interference | | -20 | | dB | | C/I <sub>2M,+4MHz</sub> | 2 Mbps mode, Adjacent (+4 MHz) interference | | -44 | | dB | | C/I <sub>2M,-6MHz</sub> | 2 Mbps mode, Adjacent (-6 MHz) interference | | -42 | | dB | | C/I <sub>2M,+6MHz</sub> | 2 Mbps mode, Adjacent (+6 MHz) interference | | -47 | | dB | | C/I <sub>2M,≥12MHz</sub> | 2 Mbps mode, Adjacent (≥12 MHz) interference | | -52 | | dB | | C/I <sub>2MBLE,co-channel</sub> | 2 Mbps BLE mode, Co-Channel interference | | 6 | | dB | | C/I <sub>2MBLE,±2MHz</sub> | 2 Mbps BLE mode, Adjacent (±2 MHz) interference | | -2 | | dB | | C/I <sub>2MBLE,±4MHz</sub> | 2 Mbps BLE mode, Adjacent (±4 MHz) interference | | -48 | | dB | | C/I <sub>2MBLE,≥6MHz</sub> | 2 Mbps BLE mode, Adjacent (≥6 MHz) interference | | -50 | | dB | | C/I <sub>2MBLE,image</sub> | Image frequency interference | | -29 | | dB | | C/I <sub>2MBLE,image, 2MHz</sub> | Adjacent (2 MHz) interference to in-band image frequency | | -44 | | dB | | | | | | | | # 6.10.14.7 RX intermodulation # RX intermodulation<sup>19</sup> | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------------------|------------------------------------------------------------|------|------|------|-------| | P <sub>IMD,5TH,1M</sub> | IMD performance, 1 Mbps, 5th offset channel, packet length | | -33 | | dBm | | | ≤ 37 bytes | | | | | | P <sub>IMD,5TH,1M,BLE</sub> | IMD performance, BLE 1 Mbps, 5th offset channel, packet | | -30 | | dBm | | | length ≤ 37 bytes | | | | | | P <sub>IMD,5TH,2M</sub> | IMD performance, 2 Mbps, 5th offset channel, packet length | | -33 | | dBm | | | ≤ 37 bytes | | | | | | P <sub>IMD,5TH,2M,BLE</sub> | IMD performance, BLE 2 Mbps, 5th offset channel, packet | | -31 | | dBm | | | length ≤ 37 bytes | | | | | NORDIC\* Desired signal level at PIN = -64 dBm. Two interferers with equal input power are used. The interferer closest in frequency is not modulated, the other interferer is modulated equal with the desired signal. The input power of the interferers where the sensitivity equals BER = 0.1% is presented. # 6.10.14.8 Radio timing | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------------|----------------------------------------------------------|------|------|------|-------| | t <sub>TXEN,BLE,1M</sub> | Time between TXEN task and READY event after channel | 140 | | 140 | μs | | | FREQUENCY configured (1 Mbps BLE and 150 $\mu s$ TIFS) | | | | | | t <sub>TXEN,FAST,BLE,1M</sub> | Time between TXEN task and READY event after channel | 40 | | 40 | μs | | | FREQUENCY configured (1 Mbps BLE with fast ramp-up and | | | | | | | 150 μs TIFS) | | | | | | t <sub>TXDIS,BLE,1M</sub> | When in TX, delay between DISABLE task and DISABLED | 6 | | 6 | μs | | | event for MODE = Nrf_1Mbit and MODE = Ble_1Mbit | | | | | | t <sub>RXEN,BLE,1M</sub> | Time between the RXEN task and READY event after channel | 140 | | 140 | μs | | | FREQUENCY configured (1 Mbps BLE) | | | | | | t <sub>RXEN,FAST,BLE,1M</sub> | Time between the RXEN task and READY event after channel | 40 | | 40 | μs | | | FREQUENCY configured (1 Mbps BLE with fast ramp-up) | | | | | | t <sub>RXDIS,BLE,1M</sub> | When in RX, delay between DISABLE task and DISABLED | 0 | | 0 | μs | | | event for MODE = Nrf_1Mbit and MODE = Ble_1Mbit | | | | | | t <sub>TXDIS,BLE,2M</sub> | When in TX, delay between DISABLE task and DISABLED | 4 | | 4 | μs | | | event for MODE = Nrf_2Mbit and MODE = Ble_2Mbit | | | | | | t <sub>RXDIS,BLE,2M</sub> | When in RX, delay between DISABLE task and DISABLED | 0 | | 0 | μs | | | event for MODE = Nrf_2Mbit and MODE = Ble_2Mbit | | | | | # 6.10.14.9 Received signal strength indicator (RSSI) specifications | Symbol | Description | Min. | Тур. | Max. Units | |----------------------------|----------------------------------------------|------|------|------------| | RSSI <sub>ACC</sub> | RSSI accuracy valid range -90 to -20 dBm | | ±2 | dB | | RSSI <sub>RESOLUTION</sub> | RSSI resolution | | 1 | dB | | RSSI <sub>PERIOD</sub> | RSSI sampling time from RSSI_START task | | 0.25 | μs | | RSSI <sub>SETTLE</sub> | RSSI settling time after signal level change | | 15 | μs | #### 6.10.14.10 Jitter | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------------------|-------------------------------------------------------------------------------------------------|------|------|------|-------| | t <sub>disabledjitter</sub> | Jitter on DISABLED event relative to END event when shortcut between END and DISABLE is enabled | | 0.25 | | μs | | t <sub>READYJITTER</sub> | Jitter on READY event relative to TXEN and RXEN task | | 0.25 | | μs | # 6.11 RNG — Random number generator The Random number generator (RNG) generates true non-deterministic random numbers based on internal thermal noise that are suitable for cryptographic purposes. The RNG does not require a seed value. Figure 53: Random number generator The RNG is started by triggering the START task and stopped by triggering the STOP task. When started, new random numbers are generated continuously and written to the VALUE register when ready. A VALRDY event is generated for every new random number that is written to the VALUE register. This means that after a VALRDY event is generated the CPU has the time until the next VALRDY event to read out the random number from the VALUE register before it is overwritten by a new random number. #### 6.11.1 Bias correction A bias correction algorithm is employed on the internal bit stream to remove any bias toward '1' or '0'. The bits are then queued into an eight-bit register for parallel readout from the VALUE register. It is possible to enable bias correction in the CONFIG register. This will result in slower value generation, but will ensure a statistically uniform distribution of the random values. # 6.11.2 Speed The time needed to generate one random byte of data is unpredictable, and may vary from one byte to the next. This is especially true when bias correction is enabled. # 6.11.3 Registers | Base address | Peripheral | Instance | Description | |--------------|------------|----------|-------------------------| | 0x4000D000 | RNG | RNG | Random number generator | Table 50: Instances | Register | Offset | Description | |---------------|--------|---------------------------------------------------------------------------------| | TASKS_START | 0x000 | Task starting the random number generator | | TASKS_STOP | 0x004 | Task stopping the random number generator | | EVENTS_VALRDY | 0x100 | Event being generated for every new random number written to the VALUE register | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | CONFIG | 0x504 | Configuration register | | VALUE | 0x508 | Output random number | Table 51: Register overview #### 6.11.3.1 TASKS START Address offset: 0x000 Task starting the random number generator | Bit | number | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----|---------------|---------|-------------------|---------------------------------------------------------------------| | ID | | | | А | | Res | et 0x00000000 | | 0 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID | | | | Description | | Α | W TASKS_START | | | Task starting the random number generator | | | | Trigger | 1 | Trigger task | #### 6.11.3.2 TASKS STOP Address offset: 0x004 Task stopping the random number generator # 6.11.3.3 EVENTS\_VALRDY Address offset: 0x100 Event being generated for every new random number written to the VALUE register | Bit r | number | | 31 30 29 28 | 27 26 25 | 5 24 2 | 23 22 | 21 20 | 19 | 18 1 | 7 16 | 5 15 | 14 1 | .3 12 | 11 1 | .0 9 | 8 | 7 | 6 | 5 4 | 3 | 2 | 1 | 0 | |-------|------------------|--------------|-------------|----------|--------|--------|--------|-------|-------|------|-------|------|-------|-------|------|-----|-----|----|-----|---|---|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | Δ | | Rese | et 0x00000000 | | 0 0 0 0 | 0 0 0 | 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | D | | ID | | | | | | Descri | iption | | | | | | | | | | | | | | | | ı | | Α | RW EVENTS_VALRDY | | | | N | Event | being | g ger | nerat | ed 1 | for e | very | / nev | v ran | dom | nuı | mbe | er | | | | | _ | | | | | | | | writte | n to t | the \ | /ALU | E re | giste | er | | | | | | | | | | | | | | | NotGenerated | 0 | | | Event | not g | ene | rated | ł | | | | | | | | | | | | | | | | | Generated | 1 | 4 | ì | Event | gene | rate | d | | | | | | h | | | | | | | | | #### 6.11.3.4 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit n | umber | | | 313 | 0 29 : | 28 27 | 26 | 25 2 | 24 : | 23 22 | 2 21 | 20 | 19 1 | 8 17 | 16 | 15 1 | 4 13 | 3 12 | 11 | 10 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | . 0 | |-------|----------------|----------|---|------|--------|-------|----|------|------|-------|-------|------|------|------|-----|------|------|------|-------|-------|----|---|---|---|---|-----|-----|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t 0x00000000 | | Ť | 0 ( | 0 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | | ID | Acce Field | Value ID | | Valu | | | | 7 | ì | Desc | | | | | | | | | | | | | | | | | | | | Α | RW VALRDY_STOP | | | | | V | | | : | Shor | tcut | bet | wee | n ev | ent | VAL | .RDY | and | d tas | sk ST | ОР | | | | | | | | | | | Disabled | | 0 | | | | | - | Disal | ole s | hor | tcut | | | | | | | | | | | | | | | | | | | Enabled | | 1 | | ア | | | - | Enab | le sl | hort | cut | | | | | | | | | | | | | | | | #### **6.11.3.5 INTENSET** Address offset: 0x304 Enable interrupt | Bit number | | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|------------------|------------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW VALRDY | | | Write '1' to enable interrupt for event VALRDY | | | Set | 1 | Enable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | #### 6.11.3.6 INTENCLR Address offset: 0x308 Disable interrupt 4454\_187 v0.5 160 NORDI | Bit number | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW VALRDY | | | Write '1' to disable interrupt for event VALRDY | | | Clear | 1 | Disable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | ## 6.11.3.7 CONFIG Address offset: 0x504 Configuration register | Bit number | | 31 30 2 | 9 28 27 26 25 | 24 23 22 21 20 | 19 18 17 | 16 15 1 | 4 13 12 | 2 11 10 ! | 987 | 7 6 | 5 4 | 3 | 2 1 0 | |------------------|----------|---------|---------------|----------------|----------|---------|---------|-----------|-------|-----|-----|---|-------| | ID | | | | • | | | | | | | | | A | | Reset 0x00000000 | | 0 0 0 | 0 0 0 0 | 0 0 0 0 0 | 0 0 0 | 00 | 0 0 0 | 0 0 | 0 0 0 | 0 0 | 0 0 | 0 | 0 0 0 | | | | | | Description | | | | | | | | | | | A RW DERCEN | | | | Bias correct | ion | | | | | | | | | | | Disabled | 0 | | Disabled | | | | | | | | | | | | Enabled | 1 | | Enabled | | | | | | | | | | #### 6.11.3.8 VALUE Address offset: 0x508 Output random number # 6.11.4 Electrical specification # 6.11.4.1 RNG Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | |------------------------|--------------------------------------------------------------|------|------|------|-------| | t <sub>RNG,START</sub> | Time from setting the START task to generation begins. | | 128 | | μs | | | This is a one-time delay on START signal and does not apply | | | | | | | between samples. | | | | | | t <sub>RNG,RAW</sub> | Run time per byte without bias correction. Uniform | | 30 | | μs | | | distribution of 0 and 1 is not guaranteed. | | | | | | t <sub>RNG,BC</sub> | Run time per byte with bias correction. Uniform distribution | | 120 | | μs | | | of 0 and 1 is guaranteed. Time to generate a byte cannot be | | | | | | | guaranteed. | | | | | # 6.12 RTC — Real-time counter The Real-time counter (RTC) module provides a generic, low power timer on the low-frequency clock source (LFCLK). Figure 54: RTC block schematic The RTC module features a 24-bit COUNTER, a 12-bit (1/X) prescaler, capture/compare registers, and a tick event generator for low power, tickless RTOS implementation. #### 6.12.1 Clock source The RTC will run off the LFCLK. The COUNTER resolution will therefore be 30.517 $\mu$ s. Depending on the source, the RTC is able to run while the HFCLK is OFF and PCLK16M is not available. The software has to explicitely start LFCLK before using the RTC. See CLOCK — Clock control on page 60 for more information about clock sources. # 6.12.2 Resolution versus overflow and the PRESCALER Counter increment frequency: ``` f_{RTC} [kHz] = 32.768 / (PRESCALER + 1 ) ``` The PRESCALER register is read/write when the RTC is stopped. The PRESCALER register is read-only once the RTC is STARTed. Writing to the PRESCALER register when the RTC is started has no effect. The PRESCALER is restarted on START, CLEAR and TRIGOVRFLW, that is, the prescaler value is latched to an internal register (<<PRESC>>) on these tasks. #### Examples: 1. Desired COUNTER frequency 100 Hz (10 ms counter period) ``` PRESCALER = round(32.768 kHz / 100 Hz) - 1 = 327 f_{RTC} = 99.9 Hz ``` 10009.576 μs counter period 2. Desired COUNTER frequency 8 Hz (125 ms counter period) PRESCALER = round(32.768 kHz / 8 Hz) - 1 = 4095 $f_{RTC} = 8 Hz$ 125 ms counter period | Prescaler | Counter resolution | Overflow | |--------------------|--------------------|----------------| | 0 | 30.517 μs | 512 seconds | | 2 <sup>8</sup> -1 | 7812.5 μs | 131072 seconds | | 2 <sup>12</sup> -1 | 125 ms | 582.542 hours | Table 52: RTC resolution versus overflow # 6.12.3 COUNTER register The COUNTER increments on LFCLK when the internal PRESCALER register (<<PRESC>>) is 0x00. <<PRESC>> is reloaded from the PRESCALER register. If enabled, the TICK event occurs on each increment of the COUNTER. The TICK event is disabled by default. Figure 55: Timing diagram - COUNTER PRESCALER 0 Figure 56: Timing diagram - COUNTER\_PRESCALER 1 #### 6.12.4 Overflow features The TRIGOVRFLW task sets the COUNTER value to 0xFFFFF0 to allow SW test of the overflow condition. OVRFLW occurs when COUNTER overflows from 0xFFFFFF to 0. **Important:** The OVRFLW event is disabled by default. ## 6.12.5 TICK event The TICK event enables low power "tick-less" RTOS implementation as it optionally provides a regular interrupt source for a RTOS without the need to use the ARM<sup>®</sup> SysTick feature. Using the RTC TICK event rather than the SysTick allows the CPU to be powered down while still keeping RTOS scheduling active. Important: The TICK event is disabled by default. #### 6.12.6 Event control feature To optimize RTC power consumption, events in the RTC can be individually disabled to prevent PCLK16M and HFCLK being requested when those events are triggered. This is managed using the EVTEN register. For example, if the TICK event is not required for an application, this event should be disabled as it is frequently occurring and may increase power consumption if HFCLK otherwise could be powered down for long durations. This means that the RTC implements a slightly different task and event system compared to the standard system described in Peripheral interface on page 73. The RTC task and event system is illustrated in Tasks, events and interrupts in the RTC on page 164. Figure 57: Tasks, events and interrupts in the RTC # 6.12.7 Compare feature There are a number of Compare registers. For more information, see Registers on page 169. When setting a compare register, the following behavior of the RTC compare event should be noted: • If a CC register value is 0 when a CLEAR task is set, this will not trigger a COMPARE event. Figure 58: Timing diagram - COMPARE\_CLEAR • If a CC register is N and the COUNTER value is N when the START task is set, this will not trigger a COMPARE event. Figure 59: Timing diagram - COMPARE START • COMPARE occurs when a CC register is N and the COUNTER value transitions from N-1 to N. Figure 60: Timing diagram - COMPARE • If the COUNTER is N, writing N+2 to a CC register is guaranteed to trigger a COMPARE event at N+2. Figure 61: Timing diagram - COMPARE\_N+2 • If the COUNTER is N, writing N or N+1 to a CC register may not trigger a COMPARE event. Figure 62: Timing diagram - COMPARE N+1 • If the COUNTER is N and the current CC register value is N+1 or N+2 when a new CC value is written, a match may trigger on the previous CC value before the new value takes effect. If the current CC value greater than N+2 when the new value is written, there will be no event due to the old value. Figure 63: Timing diagram - COMPARE\_N-1 # 6.12.8 TASK and EVENT jitter/delay Jitter or delay in the RTC is due to the peripheral clock being a low frequency clock (LFCLK) which is not synchronous to the faster PCLK16M. Registers in the peripheral interface, part of the PCLK16M domain, have a set of mirrored registers in the LFCLK domain. For example, the COUNTER value accessible from the CPU is in the PCLK16M domain and is latched on read from an internal register called COUNTER in the LFCLK domain. COUNTER is the register which is actually modified each time the RTC ticks. These registers must be synchronised between clock domains (PCLK16M and LFCLK). The following is a summary of the jitter introduced on tasks and events. Figures illustrating jitter follow. Table 53: RTC jitter magnitudes on tasks | Operation/Function | Jitter | |----------------------------------|-------------| | START to COUNTER increment | +/- 15 μs | | COMPARE to COMPARE <sup>20</sup> | +/- 62.5 ns | Table 54: RTC jitter magnitudes on events 1. CLEAR and STOP (and TRIGOVRFLW; not shown) will be delayed as long as it takes for the peripheral to clock a falling edge and rising of the LFCLK. This is between 15.2585 $\mu$ s and 45.7755 $\mu$ s – rounded to 15 $\mu$ s and 46 $\mu$ s for the remainder of the section. Figure 64: Timing diagram - DELAY\_CLEAR Figure 65: Timing diagram - DELAY\_STOP 2. The START task will start the RTC. Assuming that the LFCLK was previously running and stable, the first increment of COUNTER (and instance of TICK event) will be typically after 30.5 $\mu$ s +/-15 $\mu$ s. In some cases, in particular if the RTC is STARTed before the LFCLK is running, that timing can be up to ~250 $\mu$ s. The software should therefore wait for the first TICK if it has to make sure the RTC is running. Note: 32.768 kHz clock jitter is additional to the numbers provided above. NORDIC Assumes RTC runs continuously between these events. Sending a TRIGOVRFLW task sets the COUNTER to a value close to overflow. However, since the update of COUNTER relies on a stable LFCLK, sending this task while LFCLK is not running will start LFCLK, but the update will then be delayed by the same amount of time of up to ~250 us. The figures show the smallest and largest delays to on the START task which appears as a +/-15 $\mu$ s jitter on the first COUNTER increment. Figure 66: Timing diagram - JITTER START- Figure 67: Timing diagram - JITTER\_START+ # 6.12.9 Reading the COUNTER register To read the COUNTER register, the internal <<COUNTER>> value is sampled. To ensure that the <<COUNTER>> is safely sampled (considering an LFCLK transition may occur during a read), the CPU and core memory bus are halted for three cycles by lowering the core PREADY signal. The Read takes the CPU 2 cycles in addition resulting in the COUNTER register read taking a fixed five PCLK16M clock cycles. Figure 68: Timing diagram - COUNTER\_READ # 6.12.10 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|---------------------|-------------------------------| | 0x4000B000 | RTC | RTC0 | Real-time counter 0 | CC[02] implemented, CC[3] not | | | | | | implemented | | 0x40011000 | RTC | RTC1 | Real-time counter 1 | CC[03] implemented | Table 55: Instances | egister C | Offset | Description | |-------------------|--------|-------------------------------------------------------------------------------------------| | KS_START 0 | 0x000 | Start RTC COUNTER | | SKS_STOP 0 | 0x004 | Stop RTC COUNTER | | SKS_CLEAR 0 | 0x008 | Clear RTC COUNTER | | KS_TRIGOVRFLW 0 | 0x00C | Set COUNTER to 0xFFFFF0 | | ENTS_TICK 0 | 0x100 | Event on COUNTER increment | | NTS_OVRFLW 0 | 0x104 | Event on COUNTER overflow | | NTS_COMPARE[0] 0 | 0x140 | Compare event on CC[0] match | | NTS_COMPARE[1] 0 | 0x144 | Compare event on CC[1] match | | NTS_COMPARE[2] 0 | 0x148 | Compare event on CC[2] match | | ENTS_COMPARE[3] 0 | 0x14C | Compare event on CC[3] match | | TENSET 0 | 0x304 | Enable interrupt | | TENCLR 0 | 0x308 | Disable interrupt | | TEN 0 | 0x340 | Enable or disable event routing | | TENSET 0 | 0x344 | Enable event routing | | TENCLR 0 | 0x348 | Disable event routing | | OUNTER 0 | 0x504 | Current COUNTER value | | ESCALER 0 | 0x508 | 12 bit prescaler for COUNTER frequency (32768/(PRESCALER+1)). Must be written when RTC is | | | | stopped | | C[0] 0 | 0x540 | Compare register 0 | | [1] | 0x544 | Compare register 1 | | C[2] 0 | 0x548 | Compare register 2 | | [3] | 0x54C | Compare register 3 | Table 56: Register overview # 6.12.10.1 TASKS\_START Address offset: 0x000 Start RTC COUNTER | Bit n | umber | | 31 30 29 28 27 2 | 6 25 2 | 4 23 | 22 2 | 21 20 | 19 1 | 8 17 | ' 16 1 | L5 1 | 4 13 | 12 | 11 1 | 0 9 | 8 | 7 | 6 | 5 | 4 3 | 2 | 1 | 0 | |-------|---------------|---------|------------------|--------|------|------|-------|------|------|--------|------|------|----|------|-----|---|---|---|---|-----|---|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 | 0 | 0 | 0 0 | 0 ( | 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | Α | W TASKS_START | | | | Sta | rt R | тс сс | OUN | ΓER | | | | | | | | | | | | | | | | | | Trigger | 1 | | Trig | ger | task | | | | | | | | | | | | | | | | | 169 # 6.12.10.2 TASKS\_STOP Address offset: 0x004 Stop RTC COUNTER | Bit n | umbe | er | | 31 30 29 28 27 26 | 25 2 | 4 23 | 3 22 | 21 2 | 0 19 | 9 18 | 17 | 16 1 | 15 1 | 14 13 | 3 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|-------|------------|---------|-------------------|------|--------------|------|------|------|------|----|------|------|-------|------|----|----|---|---|---|---|---|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t 0x0 | 0000000 | | 0 0 0 0 0 0 | 0 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | W | TASKS_STOP | | | | St | op F | TC ( | COU | NTE | R | | | | | | | | | | | | | | | | | | | | Trigger | 1 | | Trigger task | | | | | | | | | | | | | | | | | | | | | # 6.12.10.3 TASKS\_CLEAR Address offset: 0x008 Clear RTC COUNTER | Bit n | umber | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 | |-------|---------------|---------|----------------|--------------------------------------------------------------------|-----| | ID | | | | | Α | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 | | ID | | | | Description | | | Α | W TASKS_CLEAR | | | Clear RTC COUNTER | | | | | Trigger | 1 | Trigger task | | # 6.12.10.4 TASKS\_TRIGOVRFLW Address offset: 0x00C Set COUNTER to 0xFFFFF0 # 6.12.10.5 EVENTS\_TICK Address offset: 0x100 Event on COUNTER increment | Bit number | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|----------------------|--------------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW EVENTS_TICK | | | Event on COUNTER increment | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | # 6.12.10.6 EVENTS\_OVRFLW Address offset: 0x104 Event on COUNTER overflow | Bit numbe | er | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------|---------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | | А | | Reset 0x0 | 0000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acc | | | | Description | | A RW | EVENTS_OVRFLW | | | Event on COUNTER overflow | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | # 6.12.10.7 EVENTS\_COMPARE[n] (n=0..3) Address offset: $0x140 + (n \times 0x4)$ Compare event on CC[n] match | Bit r | number | | 31 30 29 2 | 8 27 26 25 | 5 24 23 22 | 21 20 19 | 18 17 | 16 15 | 14 13 | 3 12 11 | . 10 9 | 8 | 7 6 | 5 5 | 4 | 3 | 2 1 | 0 | |-------|-------------------|--------------|------------|------------|------------|----------|---------|-------|-------|---------|--------|---|-----|-----|---|-----|-----|---| | ID | | | | | | | | | | | | | | | | | | Α | | Res | et 0x00000000 | | 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 0 | 0 | | ID | | | | | Descri | iption | | 7 | | | | | | | | | | | | Α | RW EVENTS_COMPARE | | | | Comp | are even | t on Co | [n] m | atch | | | | | | | | | | | | | NotGenerated | 0 | | Event | not gen | erated | | 4 | | | | | | | | | | | | | Generated | 1 | 4 | Event | generate | ed | | | | | | | | | | | | #### 6.12.10.8 INTENSET Address offset: 0x304 Enable interrupt | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------------------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | F E D C B A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | Value | Description | | A RW TICK | | | Write '1' to enable interrupt for event TICK | | | Set | 1 | Enable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | | B RW OVRFLW | | | Write '1' to enable interrupt for event OVRFLW | | | Set | 1 | Enable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | | C-F RW COMPARE[i] (i=03) | | | Write '1' to enable interrupt for event COMPARE[i] | | | Set | 1 | Enable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | ## 6.12.10.9 INTENCLR Address offset: 0x308 Disable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | F E D C B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | Α | RW TICK | | | Write '1' to disable interrupt for event TICK | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW OVRFLW | | | Write '1' to disable interrupt for event OVRFLW | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | C-F | RW COMPARE[i] (i=03) | | | Write '1' to disable interrupt for event COMPARE[i] | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | #### 6.12.10.10 EVTEN Address offset: 0x340 Enable or disable event routing # 6.12.10.11 EVTENSET Address offset: 0x344 Enable event routing | Bit number | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|-----------------------------------------|-----------------------------------------------------------------| | ID | | F E D C | | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | ID Acce Field | | | Description | | A RW TICK | | | Write '1' to enable event routing for event TICK | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | | | Set | 1 | Enable | | B RW OVRFLW | | | Write '1' to enable event routing for event OVRFLW | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | | | Set | 1 | Enable | | Bit number | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | |--------------------------|---------------------|--------------------------------------------------------------------|--| | ID. | 3130232027202 | F E D C B A | | | | | | | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | ID Acce Field Value ID | | Description | | | C-F RW COMPARE[i] (i=03) | | Write '1' to enable event routing for event COMPARE[i] | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | | | Set | 1 | Enable | | ## 6.12.10.12 EVTENCLR Address offset: 0x348 Disable event routing | Bit n | umber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------------|----------|-------------------------|---------------------------------------------------------------| | ID | | | F E D C B A | | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | Value | Description | | Α | RW TICK | | | Write '1' to disable event routing for event TICK | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | Clear | 1 | Disable | | В | RW OVRFLW | , | | Write '1' to disable event routing for event OVRFLW | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | Clear | 1 | Disable | | C-F | RW COMPARE[i] (i=03) | | | Write '1' to disable event routing for event COMPARE[i] | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | Clear | 1 | Disable | | | | , | | | # 6.12.10.13 COUNTER Address offset: 0x504 Current COUNTER value | A R COUNTER | Counter value | |------------------|---------------------------------------------------------------------------------------| | ID Acce Field | Value Description | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | A A A A A A A A A A A A A A A A A A A | | Bit number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | ## 6.12.10.14 PRESCALER Address offset: 0x508 12 bit prescaler for COUNTER frequency (32768/(PRESCALER+1)). Must be written when RTC is stopped | Α | RW PRESCALER | | Prescaler value | | |-------|---------------|-------------------------|-------------------------------------------------------------|-----| | ID | | | | | | Res | et 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 | | ID | | | A A A A A A A A A A A A A A A A A A A | A A | | Bit r | umber | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 | ## 6.12.10.15 CC[n] (n=0..3) Address offset: $0x540 + (n \times 0x4)$ Compare register n # 6.12.11 Electrical specification # 6.13 SAADC — Successive approximation analog-to-digital converter The ADC is a differential successive approximation register (SAR) analog-to-digital converter. Listed here are the main features of SAADC: - 8/10/12-bit resolution, 14-bit resolution with oversampling - Up to eight input channels - One channel per single-ended input and two channels per differential input - Scan mode can be configured with both single-ended channels and differential channels. - Full scale input range (0 to VDD) - Sampling triggered via a task from software or a PPI channel for full flexibility on sample frequency source from low power 32.768kHz RTC or more accurate 1/16MHz Timers - One-shot conversion mode to sample a single channel - Scan mode to sample a series of channels in sequence. Sample delay between channels is t<sub>ack</sub> + t<sub>conv</sub> which may vary between channels according to user configuration of t<sub>ack</sub>. - Support for direct sample transfer to RAM using EasyDMA - Interrupts on single sample and full buffer events - Samples stored as 16-bit 2's complement values for differential and single-ended sampling - Continuous sampling without the need of an external timer - Internal resistor string - Limit checking on the fly #### 6.13.1 Shared resources The ADC can coexist with COMP and other peripherals using one of AIN0-AIN7, provided these are assigned to different pins. It is not recommended to select the same analog input pin for both modules. #### 6.13.2 Overview The ADC supports up to eight external analog input channels, depending on package variant. It can be operated in a one-shot mode with sampling under software control, or a continuous conversion mode with a programmable sampling rate. The analog inputs can be configured as eight single-ended inputs, four differential inputs or a combination of these. Each channel can be configured to select AINO to AIN7 pins, or the VDD pin. Channels can be sampled individually in one-shot or continuous sampling modes, or, using scan mode, multiple channels can be sampled in sequence. Channels can also be oversampled to improve noise performance. Figure 69: Simplified ADC block diagram Internally, the ADC is always a differential analog-to-digital converter, but by default it is configured with single-ended input in the MODE field of the CH[n].CONFIG register. In single-ended mode, the negative input will be shorted to ground internally. The assumption in single-ended mode is that the internal ground of the ADC is the same as the external ground that the measured voltage is referred to. The ADC is thus sensitive to ground bounce on the PCB in single-ended mode. If this is a concern we recommend using differential measurement. # 6.13.3 Digital output The output result of the ADC depends on the settings in the CH[n].CONFIG and RESOLUTION registers as follows: ``` RESULT = [V(P) - V(N)] * GAIN/REFERENCE * 2 (RESOLUTION - m) ``` where V(P) is the voltage at input P V(N) is the voltage at input N **GAIN** is the selected gain setting #### REFERENCE is the selected reference voltage and m=0 if CONFIG.MODE=SE, or m=1 if CONFIG.MODE=Diff. The result generated by the ADC will deviate from the expected due DC errors like offset, gain, differential non-linearity (DNL), and integral non-linearity (INL). See Electrical specification for details on these parameters. The result can also vary due to AC errors like non-linearities in the GAIN block, settling errors due to high source impedance and sampling jitter. For battery measurement the DC errors are most noticeable. The ADC has a wide selection of gains controlled in the GAIN field of the CH[n].CONFIG register. If CH[n].CONFIG.REFSEL=0, the input range of the ADC core is nominally $\pm 0.6$ V differential and the input must be scaled accordingly. The ADC has a temperature dependent offset. If the ADC is to operate over a large temperature range, we recommend running CALIBRATEOFFSET at regular intervals, a CALIBRATEDONE event will be fired when the calibration is complete # 6.13.4 Analog inputs and channels Up to eight analog input channels, CH[n](n=0..7), can be configured. See Shared resources on page 174 for shared input with comparators. Any one of the available channels can be enabled for the ADC to operate in one-shot mode. If more than one CH[n] is configured, the ADC enters scan mode. An analog input is selected as a positive converter input if CH[n].PSELP is set, setting CH[n].PSELP also enables the particular channel. An analog input is selected as a negative converter input if CH[n]. PSELN is set. The CH[n]. PSELN register will have no effect unless differential mode is enabled, see MODE field in CH[n]. CONFIG register. If more than one of the CH[n].PSELP registers is set, the device enters scan mode. Input selections in scan mode are controlled by the CH[n].PSELP and CH[n].PSELN registers, where CH[n].PSELN is only used if the particular scan channel is specified as differential, see MODE field in CH[n].CONFIG register. **Important:** Channels selected for COMP cannot be used at the same time for ADC sampling, though channels not selected for use by these blocks can be used by the ADC. | Channel input | Sour | ce | Connectivity | |---------------|------|------|--------------| | CH[n].PSELP | AINO | AIN7 | Yes(any) | | CH[n].PSELP | VDD | | Yes | | CH[n].PSELN | AINO | AIN7 | Yes(any) | | CH[n].PSELN | VDD | | Yes | Table 57: Legal connectivity CH[n] vs. analog input # 6.13.5 Operation modes The ADC input configuration supports one-shot mode, continuous mode and scan mode. Scan mode and oversampling cannot be combined. #### 6.13.5.1 One-shot mode One-shot operation is configured by enabling only one of the available channels defined by CH[n].PSELP, CH[n].PSELN, and CH[n].CONFIG registers. Upon a SAMPLE task, the ADC starts to sample the input voltage. The CH[n].CONFIG.TACQ controls the acquisition time. A DONE event signals that one sample has been taken. In this mode, the RESULTDONE event has the same meaning as DONE when no oversampling takes place. Note that both events may occur before the actual value has been transferred into RAM by EasyDMA. For more information, see EasyDMA on page 178. #### 6.13.5.2 Continuous mode Continuous sampling can be achieved by using the internal timer in the ADC, or triggering the SAMPLE task from one of the general purpose timers through the PPI. Care shall be taken to ensure that the sample rate fulfils the following criteria, depending on how many channels are active: ``` f_{SAMPLE} < 1/[t_{ACO} + t_{conv}] ``` The SAMPLERATE register can be used as a local timer instead of triggering individual SAMPLE tasks. When SAMPLERATE.MODE is set to Timers, it is sufficient to trigger SAMPLE task only once in order to start the SAADC and triggering the STOP task will stop sampling. The SAMPLERATE.CC field controls the sample rate. The SAMPLERATE timer mode cannot be combined with SCAN mode, and only one channel can be enabled in this mode. A DONE event signals that one sample has been taken. In this mode, the RESULTDONE event has the same meaning as DONE when no oversampling takes place. Note that both events may occur before the actual value has been transferred into RAM by EasyDMA. #### 6.13.5.3 Oversampling An accumulator in the ADC can be used to average noise on the analog input. In general, oversampling improves the signal-to-noise ratio (SNR). Oversampling, however, does not improve the integral non-linearity (INL), or differential non-linearity (DNL). Oversampling and scan should not be combined, since oversampling and scan will average over input channels. The accumulator is controlled in the OVERSAMPLE register. The SAMPLE task must be set 2<sup>OVERSAMPLE</sup> number of times before the result is written to RAM. This can be achieved by: - Configuring a fixed sampling rate using the local timer or a general purpose timer and PPI to trigger a SAMPLE task - Triggering SAMPLE 2<sup>OVERSAMPLE</sup> times from software - Enabling BURST mode CH[n].CONFIG.BURST can be enabled to avoid setting SAMPLE task $2^{OVERSAMPLE}$ times. With BURST = 1 the ADC will sample the input $2^{OVERSAMPLE}$ times as fast as it can (actual timing: $<(t_{ACQ}+t_{CONV})\times 2^{OVERSAMPLE})$ . Thus, for the user it will just appear like the conversion took a bit longer time, but other than that, it is similar to one-shot mode. Scan mode can be combined with BURST=1, if burst is enabled on all channels. A DONE event signals that one sample has been taken. In this mode, the RESULTDONE event signals that enough conversions have taken place for an oversampled result to get transferred into RAM. Note that both events may occur before the actual value has been transferred into RAM by EasyDMA. #### 6.13.5.4 Scan mode A channel is considered enabled if CH[n].PSELP is set. If more than one channel, CH[n], is enabled, the ADC enters scan mode. In scan mode, one SAMPLE task will trigger one conversion per enabled channel. The time it takes to sample all channels is: ``` Total time < Sum(CH[x].t_{ACQ}+t_{CONV}), x=0..enabled channels ``` A DONE event signals that one sample has been taken. In this mode, the RESULTDONE event signals has the same meaning as DONE when no oversampling takes place. Note that both events may occur before the actual values have been transferred into RAM by EasyDMA. Example of RAM placement (even RESULT.MAXCNT), channels 1, 2 and 5 enabled on page 178 provides an example of results placement in Data RAM, with an even RESULT.MAXCNT. In this example, channels 1, 2 and 5 are enabled, all others are disabled. | | 31 16 | 15 0 | |------------------------------------|------------------------------|------------------------------| | RESULT.PTR | CH[2] 1 <sup>st</sup> result | CH[1] 1 <sup>st</sup> result | | RESULT.PTR + 4 | CH[1] 2 <sup>nd</sup> result | CH[5] 1 <sup>st</sup> result | | RESULT.PTR + 8 | CH[5] 2 <sup>nd</sup> result | CH[2] 2 <sup>nd</sup> result | | | ( | ) | | RESULT.PTR + 2*(RESULT.MAXCNT – 2) | CH[5] last result | CH[2] last result | Figure 70: Example of RAM placement (even RESULT.MAXCNT), channels 1, 2 and 5 enabled Example of RAM placement (odd RESULT.MAXCNT), channels 1, 2 and 5 enabled on page 178 provides an example of results placement in Data RAM, with an odd RESULT.MAXCNT. In this example, channels 1, 2 and 5 are enabled, all others are disabled. The last 32-bit word is populated only with one 16-bit result. Figure 71: Example of RAM placement (odd RESULT.MAXCNT), channels 1, 2 and 5 enabled ## 6.13.6 EasyDMA After configuring RESULT.PTR and RESULT.MAXCNT, the ADC resources are started by triggering the START task. The ADC is using EasyDMA to store results in a Result buffer in RAM. The Result buffer is located at the address specified in the RESULT.PTR register. The RESULT.PTR register is double-buffered and it can be updated and prepared for the next START task immediately after the STARTED event is generated. The size of the Result buffer is specified in the RESULT.MAXCNT register and the ADC will generate an END event when it has filled up the Result buffer, see ADC on page 179. Results are stored in little-endian byte order in Data RAM. Every sample will be sign extended to 16 bit before stored in the Result buffer. The ADC is stopped by triggering the STOP task. The STOP task will terminate an ongoing sampling. The ADC will generate a STOPPED event when it has stopped. If the ADC is already stopped when the STOP task is triggered, the STOPPED event will still be generated. Figure 72: ADC If the RESULT.PTR is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 15 for more information about the different memory regions. The EasyDMA will have finished accessing the RAM when the END or STOPPED event has been generated. The RESULT.AMOUNT register can be read following an END event or a STOPPED event to see how many results have been transferred to the Result buffer in RAM since the START task was triggered. In scan mode, SAMPLE tasks can be triggered once the START task is triggered. The END event is generated when the number of samples transferred to memory reaches the value specified by RESULT.MAXCNT. After an END event, the START task needs to be triggered again before new samples can be taken. Also make sure that the size of the Result buffer is large enough to have space for minimum one result from each of the enabled channels, by specifying RESULT.MAXCNT >= number of channels enabled. For more information about the scan mode, see Scan mode on page 177. # 6.13.7 Resistor ladder The ADC has an internal resistor string for positive and negative input. See Resistor ladder for positive input (negative input is equivalent, using RESN instead of RESP) on page 180. The resistors are controlled in the CH[n].CONFIG.RESP and CH[n].CONFIG.RESN registers. Figure 73: Resistor ladder for positive input (negative input is equivalent, using RESN instead of RESP) #### 6.13.8 Reference The ADC can use two different references, controlled in the REFSEL field of the CH[n]. CONFIG register. #### These are: - Internal reference - · VDD as reference The internal reference results in an input range of $\pm 0.6$ V on the ADC core. VDD as reference results in an input range of $\pm VDD/4$ on the ADC core. The gain block can be used to change the effective input range of the ADC. ``` Input range = (+- 0.6 V or +-VDD/4)/Gain ``` For example, choosing VDD as reference, single ended input (grounded negative input), and a gain of 1/4 the input range will be: ``` Input range = (VDD/4)/(1/4) = VDD ``` With internal reference, single ended input (grounded negative input), and a gain of 1/6 the input range will be: ``` Input range = (0.6 \text{ V})/(1/6) = 3.6 \text{ V} ``` The AINO-AIN7 inputs cannot exceed VDD, or be lower than VSS. # 6.13.9 Acquisition time To sample the input voltage, the ADC connects a capacitor to the input. For illustration, see Simplified ADC sample network on page 181. The acquisition time indicates how long the capacitor is connected, see TACQ field in CH[n].CONFIG register. The required acquisition time depends on the source (R<sub>source</sub>) resistance. For high source resistance the acquisition time should be increased, see Acquisition time on page 181. Figure 74: Simplified ADC sample network | TACQ [µs] | Maximum source resistance [kOhm] | |-----------|----------------------------------| | 3 | 10 | | 5 | 40 | | 10 | 100 | | 15 | 200 | | 20 | 400 | | 40 | 800 | Table 58: Acquisition time # 6.13.10 Limits event monitoring A channel can be event monitored by configuring limit register CH[n].LIMIT. If the conversion result is higher than the defined high limit, or lower than the defined low limit, the appropriate event will get fired. Figure 75: Example of limits monitoring on channel 'n' Note that when setting the limits, CH[n].LIMIT.HIGH shall always be higher than or equal to CH[n].LIMIT.LOW . In other words, an event can be fired only when the input signal has been sampled outside of the defined limits. It is not possible to fire an event when the input signal is inside a defined range by swapping high and low limits. The comparison to limits always takes place, there is no need to enable it. If comparison is not required on a channel, the software shall simply ignore the related events. In that situation, the value of the limits registers is irrelevant, so it does not matter if CH[n].LIMIT.LOW is lower than CH[n].LIMIT.HIGH or not. # 6.13.11 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|-----------------------------|---------------|--| | 0x40007000 | SAADC | SAADC | Analog-to-digital converter | | | Table 59: Instances | Register | Offset | Description | |-----------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------| | TASKS START | 0x000 | Start the ADC and prepare the result buffer in RAM | | TASKS SAMPLE | 0x000 | Take one ADC sample, if scan is enabled all channels are sampled | | TASKS STOP | 0x004<br>0x008 | Stop the ADC and terminate any on-going conversion | | TASKS CALIBRATEOFFSET | 0x008 | Starts offset auto-calibration | | _ | 0x100 | The ADC has started | | EVENTS_STARTED | 0x100<br>0x104 | | | EVENTS_END | 0x104<br>0x108 | The ADC has filled up the Result buffer A source in task has been considered. Depending on the mode, multiple conversions wight be | | EVENTS_DONE | 0X109 | A conversion task has been completed. Depending on the mode, multiple conversions might be | | EVENTS DESIREDONE | 0.400 | needed for a result to be transferred to RAM. | | EVENTS_RESULTDONE | 0x10C | A result is ready to get transferred to RAM. | | EVENTS_CALIBRATEDONE | 0x110 | Calibration is complete | | EVENTS_STOPPED | 0x114 | The ADC has stopped | | EVENTS_CH[0].LIMITH | 0x118 | Last results is equal or above CH[0].LIMIT.HIGH | | EVENTS_CH[0].LIMITL | 0x11C | Last results is equal or below CH[0].LIMIT.LOW | | EVENTS_CH[1].LIMITH | 0x120 | Last results is equal or above CH[1].LIMIT.HIGH | | EVENTS_CH[1].UMITL | 0x124 | Last results is equal or below CH[1].LIMIT.LOW | | EVENTS_CH[2].LIMITH | 0x128 | Last results is equal or above CH[2].LIMIT.HIGH | | EVENTS_CH[2].LIMITL | 0x12C | Last results is equal or below CH[2].LIMIT.LOW | | EVENTS_CH[3].LIMITH | 0x130 | Last results is equal or above CH[3].LIMIT.HIGH | | EVENTS_CH[3].LIMITL | 0x134 | Last results is equal or below CH[3].LIMIT.LOW | | EVENTS_CH[4].LIMITH | 0x138 | Last results is equal or above CH[4].LIMIT.HIGH | | EVENTS_CH[4].LIMITL | 0x13C | Last results is equal or below CH[4].LIMIT.LOW | | EVENTS_CH[5].LIMITH | 0x140 | Last results is equal or above CH[5].LIMIT.HIGH | | EVENTS_CH[5].LIMITL | 0x144 | Last results is equal or below CH[5].LIMIT.LOW | | EVENTS_CH[6].LIMITH | 0x148 | Last results is equal or above CH[6].LIMIT.HIGH | | EVENTS_CH[6].LIMITL | 0x14C | Last results is equal or below CH[6].LIMIT.LOW | | EVENTS_CH[7].LIMITH | 0x150 | Last results is equal or above CH[7].LIMIT.HIGH | | EVENTS_CH[7].LIMITL | 0x154 | Last results is equal or below CH[7].LIMIT.LOW | | INTEN | 0x300 | Enable or disable interrupt | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | STATUS | 0x400 | Status | | ENABLE | 0x500 | Enable or disable ADC | | CH[0].PSELP | 0x510 | Input positive pin selection for CH[0] | | CH[0].PSELN | 0x514 | Input negative pin selection for CH[0] | | CH[0].CONFIG | 0x518 | Input configuration for CH[0] | | CH[0].LIMIT | 0x51C | High/low limits for event monitoring a channel | | CH[1].PSELP | 0x520 | Input positive pin selection for CH[1] | | | | | | Register | Offset | Description | |---------------|--------|--------------------------------------------------------------------------------------| | CH[1].PSELN | 0x524 | Input negative pin selection for CH[1] | | CH[1].CONFIG | 0x528 | Input configuration for CH[1] | | CH[1].LIMIT | 0x52C | High/low limits for event monitoring a channel | | CH[2].PSELP | 0x530 | Input positive pin selection for CH[2] | | CH[2].PSELN | 0x534 | Input negative pin selection for CH[2] | | CH[2].CONFIG | 0x538 | Input configuration for CH[2] | | CH[2].LIMIT | 0x53C | High/low limits for event monitoring a channel | | CH[3].PSELP | 0x540 | Input positive pin selection for CH[3] | | CH[3].PSELN | 0x544 | Input negative pin selection for CH[3] | | CH[3].CONFIG | 0x548 | Input configuration for CH[3] | | CH[3].LIMIT | 0x54C | High/low limits for event monitoring a channel | | CH[4].PSELP | 0x550 | Input positive pin selection for CH[4] | | CH[4].PSELN | 0x554 | Input negative pin selection for CH[4] | | CH[4].CONFIG | 0x558 | Input configuration for CH[4] | | CH[4].LIMIT | 0x55C | High/low limits for event monitoring a channel | | CH[5].PSELP | 0x560 | Input positive pin selection for CH[5] | | CH[5].PSELN | 0x564 | Input negative pin selection for CH[5] | | CH[5].CONFIG | 0x568 | Input configuration for CH[5] | | CH[5].LIMIT | 0x56C | High/low limits for event monitoring a channel | | CH[6].PSELP | 0x570 | Input positive pin selection for CH[6] | | CH[6].PSELN | 0x574 | Input negative pin selection for CH[6] | | CH[6].CONFIG | 0x578 | Input configuration for CH[6] | | CH[6].LIMIT | 0x57C | High/low limits for event monitoring a channel | | CH[7].PSELP | 0x580 | Input positive pin selection for CH[7] | | CH[7].PSELN | 0x584 | Input negative pin selection for CH[7] | | CH[7].CONFIG | 0x588 | Input configuration for CH[7] | | CH[7].LIMIT | 0x58C | High/low limits for event monitoring a channel | | RESOLUTION | 0x5F0 | Resolution configuration | | OVERSAMPLE | 0x5F4 | Oversampling configuration. OVERSAMPLE should not be combined with SCAN. The | | | | RESOLUTION is applied before averaging, thus for high OVERSAMPLE a higher RESOLUTION | | | | should be used. | | SAMPLERATE | 0x5F8 | Controls normal or continuous sample rate | | RESULT.PTR | 0x62C | Data pointer | | RESULT.MAXCNT | 0x630 | Maximum number of buffer words to transfer | | RESULT.AMOUNT | 0x634 | Number of buffer words transferred since last START | | | | | Table 60: Register overview # 6.13.11.1 TASKS\_START Address offset: 0x000 Start the ADC and prepare the result buffer in RAM | Bit n | umber | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|---------|-------------------|---------------------------------------------------------------------| | ID | | | | A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID | | | | | | Α | W TASKS_START | | | Start the ADC and prepare the result buffer in RAM | | | | Trigger | 1 | Trigger task | # 6.13.11.2 TASKS\_SAMPLE Address offset: 0x004 Take one ADC sample, if scan is enabled all channels are sampled #### 6.13.11.3 TASKS STOP Address offset: 0x008 Stop the ADC and terminate any on-going conversion | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ID | | A CONTRACTOR OF THE PROPERTY O | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | Value Description | | A W TASKS_S | ТОР | Stop the ADC and terminate any on-going conversion | | | Trigger | 1 Trigger task | # 6.13.11.4 TASKS\_CALIBRATEOFFSET Address offset: 0x00C Starts offset auto-calibration #### 6.13.11.5 EVENTS STARTED Address offset: 0x100 The ADC has started #### 6.13.11.6 EVENTS END Address offset: 0x104 The ADC has filled up the Result buffer | Bit number | | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|---------------------|--------------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW EVENTS_END | | | The ADC has filled up the Result buffer | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | #### 6.13.11.7 EVENTS\_DONE Address offset: 0x108 A conversion task has been completed. Depending on the mode, multiple conversions might be needed for a result to be transferred to RAM. #### 6.13.11.8 EVENTS\_RESULTDONE Address offset: 0x10C A result is ready to get transferred to RAM. # 6.13.11.9 EVENTS CALIBRATEDONE Address offset: 0x110 Calibration is complete # 6.13.11.10 EVENTS\_STOPPED Address offset: 0x114 The ADC has stopped | Bit number | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW EVENTS_STOPPED | | | The ADC has stopped | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | # 6.13.11.11 EVENTS\_CH[n].LIMITH (n=0..7) Address offset: $0x118 + (n \times 0x8)$ Last results is equal or above CH[n].LIMIT.HIGH | Bit number | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 | |------------------|--------------|----------------------|------------------------------------------------------------------|---| | ID | | | | Α | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | ID Acce Field | | Value | Description | | | A RW LIMITH | | | Last results is equal or above CH[n].LIMIT.HIGH | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | | # 6.13.11.12 EVENTS\_CH[n].LIMITL (n=0..7) Address offset: $0x11C + (n \times 0x8)$ Last results is equal or below CH[n].LIMIT.LOW | Bit numb | per | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------|----------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | | А | | Reset 0x0 | 00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Ac | | Value ID | Value | Description | | A RW | V LIMITL | | | Last results is equal or below CH[n].LIMIT.LOW | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | #### 6.13.11.13 INTEN Address offset: 0x300 Enable or disable interrupt | Bit n | umbe | r | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------|---------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | | V U T S R Q P O N M L K J I H G F E D C B A | | Rese | t 0x00 | 0000000 | | 0 0 0 0 0 0 0 0 | 000000000000000000000000000000000000000 | | | | | | | | | В | RW | END | | | Enable or disable interrupt for event END | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | С | RW | DONE | | | Enable or disable interrupt for event DONE | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | D | RW | RESULTDONE | | | Enable or disable interrupt for event RESULTDONE | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | E | RW | CALIBRATEDONE | | | Enable or disable interrupt for event CALIBRATEDONE | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | F | RW | STOPPED | | | Enable or disable interrupt for event STOPPED | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | G | RW | CHOLIMITH | | | Enable or disable interrupt for event CH0LIMITH | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | Н | RW | CHOLIMITL | | | Enable or disable interrupt for event CHOLIMITL | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | I | RW | CH1LIMITH | | | Enable or disable interrupt for event CH1LIMITH | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | J | RW | CH1LIMITL | | | Enable or disable interrupt for event CH1LIMITL | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | K | RW | CH2LIMITH | | <b>\</b> (/1 | Enable or disable interrupt for event CH2LIMITH | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | L | RW | CH2LIMITL | | | Enable or disable interrupt for event CH2LIMITL | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | M | RW | CH3LIMITH | | | Enable or disable interrupt for event CH3LIMITH | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | N | RW | CH3LIMITL | | | Enable or disable interrupt for event CH3LIMITL | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | 0 | RW | CH4LIMITH | | | Enable or disable interrupt for event CH4LIMITH | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | Р | RW | CH4LIMITL | | | Enable or disable interrupt for event CH4LIMITL | | | | | Disabled | 0 | Disable | | | | CUELIA AITT | Enabled | 1 | Enable | | Q | RW | CH5LIMITH | 5 | | Enable or disable interrupt for event CH5LIMITH | | | | | Disabled | 0 | Disable | | _ | | | Enabled | 1 | Enable | | R | RW | CH5LIMITL | Disabled | 0 | Enable or disable interrupt for event CH5LIMITL | | | | | Disabled | 0 | Disable | | Bit r | number | | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------------------|-----------------------------------------------------------------------| | ID | | | | V U T S R Q P O N M L K J I H G F E D C B A | | Res | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | | | Enabled | 1 | Enable | | S | RW CH6LIMITH | | | Enable or disable interrupt for event CH6LIMITH | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | Т | RW CH6LIMITL | | | Enable or disable interrupt for event CH6LIMITL | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | U | RW CH7LIMITH | | | Enable or disable interrupt for event CH7LIMITH | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | V | RW CH7LIMITL | | | Enable or disable interrupt for event CH7LIMITL | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | #### 6.13.11.14 INTENSET Address offset: 0x304 Enable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|------------------|----------|------------------------|------------------------------------------------------------------| | ID | | | | V U T S R Q P O N M L K J I H G F E D C B A | | Rese | et 0x00000000 | CI | 0000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | Value ID | Value | Description | | Α | RW STARTED | | | Write '1' to enable interrupt for event STARTED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW END | | | Write '1' to enable interrupt for event END | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW DONE | | | Write '1' to enable interrupt for event DONE | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW RESULTDONE | | | Write '1' to enable interrupt for event RESULTDONE | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Е | RW CALIBRATEDONE | | | Write '1' to enable interrupt for event CALIBRATEDONE | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | F | RW STOPPED | | | Write '1' to enable interrupt for event STOPPED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | G | RW CHOLIMITH | | | Write '1' to enable interrupt for event CHOLIMITH | | | | Set | 1 | Enable | | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | V U T S R Q P O N M L K J I H G F E D C B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 0 | 000000000000000000000000000000000000000 | | ID | | | | | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Н | RW CHOLIMITL | | | Write '1' to enable interrupt for event CHOLIMITL | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | ı | RW CH1LIMITH | | | Write '1' to enable interrupt for event CH1LIMITH | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | J | RW CH1LIMITL | | | Write '1' to enable interrupt for event CH1LIMITL | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | K | RW CH2LIMITH | | , | Write '1' to enable interrupt for event CH2LIMITH | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | L | RW CH2LIMITL | | | Write '1' to enable interrupt for event CH2LIMITL | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | М | RW CH3LIMITH | | | Write '1' to enable interrupt for event CH3LIMITH | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | N | RW CH3LIMITL | | | Write '1' to enable interrupt for event CH3LIMITL | | | | Set | 4 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | 0 | RW CH4LIMITH | | | Write '1' to enable interrupt for event CH4LIMITH | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Р | RW CH4LIMITL | | | Write '1' to enable interrupt for event CH4LIMITL | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Q | RW CH5LIMITH | | | Write '1' to enable interrupt for event CH5LIMITH | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | R | RW CH5LIMITL | | | Write '1' to enable interrupt for event CH5LIMITL | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | S | RW CH6LIMITH | | | Write '1' to enable interrupt for event CH6LIMITH | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | | | | | Bit r | number | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------------------|---------------------------------------------------------------------| | ID | | | | V U T S R Q P O N M L K J I H G F E D C B A | | Res | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Т | RW CH6LIMITL | | | Write '1' to enable interrupt for event CH6LIMITL | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | U | RW CH7LIMITH | | | Write '1' to enable interrupt for event CH7LIMITH | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | V | RW CH7LIMITL | | | Write '1' to enable interrupt for event CH7LIMITL | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | # 6.13.11.15 INTENCLR Address offset: 0x308 Disable interrupt | | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |----|------------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | V U T S R Q P O N M L K J I H G F E D C B A | | | et 0x00000000 | <b>*</b> | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | Acce Field | Value ID | Value | Description | | Α | RW STARTED | | | Write '1' to disable interrupt for event STARTED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW END | | A (74 | Write '1' to disable interrupt for event END | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW DONE | | | Write '1' to disable interrupt for event DONE | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW RESULTDONE | | | Write '1' to disable interrupt for event RESULTDONE | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Е | RW CALIBRATEDONE | | | Write '1' to disable interrupt for event CALIBRATEDONE | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | F | RW STOPPED | | | Write '1' to disable interrupt for event STOPPED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | G | RW CHOLIMITH | | | Write '1' to disable interrupt for event CHOLIMITH | | | | | | | | | | Clear | 1 | Disable | | Bit nu | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|--------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | V U T S R Q P O N M L K J I H G F E D C B A | | | t 0x00000000 | | 0 0 0 0 0 0 0 | 000000000000000000000000000000000000000 | | ID | Acce Field | | Value | Description | | טו | Acce Field | Enabled | 1 | Read: Enabled | | Н | RW CHOLIMITL | Lilabieu | 1 | Write '1' to disable interrupt for event CHOLIMITL | | •• | NW CHOLINITE | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | 1 | RW CH1LIMITH | Litablea | - | Write '1' to disable interrupt for event CH1LIMITH | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | J | RW CH1LIMITL | | | Write '1' to disable interrupt for event CH1LIMITL | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | K | RW CH2LIMITH | | | Write '1' to disable interrupt for event CH2LIMITH | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | L | RW CH2LIMITL | | | Write '1' to disable interrupt for event CH2LIMITL | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | М | RW CH3LIMITH | | | Write '1' to disable interrupt for event CH3LIMITH | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | N | RW CH3LIMITL | | - 4 | Write '1' to disable interrupt for event CH3LIMITL | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | 0 | RW CH4LIMITH | | | Write '1' to disable interrupt for event CH4LIMITH | | | | Clear | | Disable | | | | Disabled | 0 | Read: Disabled | | Р | RW CH4LIMITL | Enabled | 1 | Read: Enabled | | r | NW CH4LIMITE | Clear | 1 | Write '1' to disable interrupt for event CH4LIMITL Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Q | RW CH5LIMITH | Litabica | • | Write '1' to disable interrupt for event CH5LIMITH | | ~ | 652 | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | R | RW CH5LIMITL | | | Write '1' to disable interrupt for event CH5LIMITL | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | S | RW CH6LIMITH | | | Write '1' to disable interrupt for event CH6LIMITH | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | T | RW CH6LIMITL | | | Write '1' to disable interrupt for event CH6LIMITL | | | | | | | | Bit r | umber | | 31 30 29 28 27 | 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|----------------|---------------------------------------------|-----------------------------------------------------------------| | ID | | | | V U T S R Q P O N M L K J I H G F E D C B A | | | Res | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | U | RW CH7LIMITH | | | | Write '1' to disable interrupt for event CH7LIMITH | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | V | RW CH7LIMITL | | | | Write '1' to disable interrupt for event CH7LIMITL | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | #### 6.13.11.16 STATUS Address offset: 0x400 Status #### 6.13.11.17 ENABLE Address offset: 0x500 Enable or disable ADC # 6.13.11.18 CH[n].PSELP (n=0..7) Address offset: $0x510 + (n \times 0x10)$ Input positive pin selection for CH[n] | Bit number | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|----------------------|--------------------------------------------------------------------| | ID | | | A A A A | | Reset 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW PSELP | | | Analog positive input channel | | | NC | 0 | Not connected | | | AnalogInput0 | 1 | AIN0 | | | AnalogInput1 | 2 | AIN1 | | | AnalogInput2 | 3 | AIN2 | | | AnalogInput3 | 4 | AIN3 | | | AnalogInput4 | 5 | AIN4 | | | AnalogInput5 | 6 | AIN5 | | | AnalogInput6 | 7 | AIN6 | | | AnalogInput7 | 8 | AIN7 | | | VDD | 9 | VDD | # 6.13.11.19 CH[n].PSELN (n=0..7) Address offset: 0x514 + (n × 0x10) Input negative pin selection for CH[n] # 6.13.11.20 CH[n].CONFIG (n=0..7) Address offset: $0x518 + (n \times 0x10)$ Input configuration for CH[n] | Bit number | 31 | . 30 29 28 27 26 25 24 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------------------|----------|------------------------|------------------------------------------------------------------| | ID | | G | G F E E E D C C C B B A A | | Reset 0x00020000 | 0 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Val | | | | | A RW RESP | | | Positive channel resistor control | | Вуј | pass 0 | | Bypass resistor ladder | | Pul | lldown 1 | | Pull-down to GND | | Pul | llup 2 | | Pull-up to VDD | | VD | D1_2 3 | | Set input at VDD/2 | | B RW RESN | | | Negative channel resistor control | | Вуј | pass 0 | | Bypass resistor ladder | | Bit n | umber | | 31 30 29 28 27 26 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | 3 2 | 1 | |-------|--------------|----------|-------------------|-------------------------------------------------------------|-----|---| | ID | | | | G F E E E D C C C B B | | Α | | Rese | t 0x00020000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 | 0 | | | | | | | | | | | | Pulldown | 1 | Pull-down to GND | | | | | | Pullup | 2 | Pull-up to VDD | | | | | | VDD1_2 | 3 | Set input at VDD/2 | | | | С | RW GAIN | | | Gain control | | | | | | Gain1_6 | 0 | 1/6 | | | | | | Gain1_5 | 1 | 1/5 | | | | | | Gain1_4 | 2 | 1/4 | | | | | | Gain1_3 | 3 | 1/3 | | | | | | Gain1_2 | 4 | 1/2 | | | | | | Gain1 | 5 | 1 | | | | | | Gain2 | 6 | 2 | | | | | | Gain4 | 7 | 4 | | | | D | RW REFSEL | | | Reference control | | | | | | Internal | 0 | Internal reference (0.6 V) | | | | | | VDD1_4 | 1 | VDD/4 as reference | | | | E | RW TACQ | | | Acquisition time, the time the ADC uses to sample the input | | | | | | | | voltage | | | | | | 3us | 0 | 3 us | | | | | | 5us | 1 | 5 us | | | | | | 10us | 2 | 10 us | | | | | | 15us | 3 | 15 us | | | | | | 20us | 4 | 20 us | | | | | | 40us | 5 | 40 us | | | | | RW MODE | | | Enable differential mode | | | | | | SE | 0 | Single ended, PSELN will be ignored, negative input to ADC | | | | | | | | shorted to GND | | | | | | Diff | 1 | Differential | | | | G | RW BURST | | | Enable burst mode | | | | | | Disabled | 0 | Burst mode is disabled (normal operation) | | | | | 1 | Enabled | 1 | Burst mode is enabled. SAADC takes 2^OVERSAMPLE | | | | | | 7 | | number of samples as fast as it can, and sends the average | | | | | | | | to Data RAM. | | | # 6.13.11.21 CH[n].LIMIT (n=0..7) Address offset: $0x51C + (n \times 0x10)$ High/low limits for event monitoring a channel | Bit n | number | | 313 | 30 2 | 29 2 | 28 2 | 7 26 | 5 25 | 5 24 | 1 23 | 22 | 21 | 20 | 19 1 | 18 1 | .7 1 | 6 1 | 5 14 | 13 | 12 | 11 : | 10 9 | 9 8 | 3 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | |-------|---------------|--|------|------|------|------|------|------|------|------|------|------|--------|------|------|------|-----|------|----|----|------|------|-----|-----|---|---|---|-----|---|---| | ID | ID | | В | В | В | ВЕ | 3 B | В | В | В | В | В | В | В | В | ВЕ | 3 Δ | A | Α | Α | Α | A | 4 4 | A | Α | Α | Α | Α Α | Α | Α | | Rese | et 0x7FFF8000 | | 0 | 1 | 1 | 1 1 | l 1 | 1 | . 1 | 1 | 1 | 1 | 1 | 1 | 1 : | 1 1 | L 1 | . 0 | 0 | 0 | 0 | 0 ( | 0 ( | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW LOW | | [-32 | 276 | 8 to | +3 | 276 | 7] | | Lo | w l | eve | l lin | nit | | | | | | | | | | | | | | | | _ | | В | RW HIGH | | [-32 | 276 | 8 to | +3 | 276 | 7] | | Hi | gh l | leve | el lir | nit | | | | | | | | | | | | | | | | | # 6.13.11.22 RESOLUTION Address offset: 0x5F0 Resolution configuration #### 6.13.11.23 OVERSAMPLE Address offset: 0x5F4 Oversampling configuration. OVERSAMPLE should not be combined with SCAN. The RESOLUTION is applied before averaging, thus for high OVERSAMPLE a higher RESOLUTION should be used. #### 6.13.11.24 SAMPLERATE Address offset: 0x5F8 Controls normal or continuous sample rate #### 6.13.11.25 RESULT.PTR Address offset: 0x62C Data pointer | D | |----------------------------------------------------------------------------------------------| | | | ID A A A A A A A A A A A A A A A A A A A | | | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | #### 6.13.11.26 RESULT.MAXCNT Address offset: 0x630 Maximum number of buffer words to transfer | Bit r | umber | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 1 | 17 1 | 6 15 | 14 1 | .3 12 | 2 11 | 10 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 1 | 0 | |-------|---------------|------------------------|------------------------|------|-------|------|-------|-------|------|-----|---|---|---|-----|-----|---|---| | ID | | | • | | | Α . | А А | A | A A | A A | Α | Α | Α | Α , | Α Α | A | Α | | Res | et 0x00000000 | 0 0 0 0 0 0 0 | 0000000 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | ID | | | Description | 7 | | | | | | | | | | | | | | | Α | RW MAXCNT | | Maximum number | of b | ouffe | r wo | rds | to tr | ansf | er | | | | | | | | #### 6.13.11.27 RESULT.AMOUNT Address offset: 0x634 Number of buffer words transferred since last START # 6.13.12 Electrical specification # 6.13.12.1 SAADC Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------------|------------------------------------------------------------------------|-------|------|------|--------| | DNL <sub>10</sub> | Differential non-linearity, 10-bit resolution | -0.95 | <1 | | LSB10b | | INL <sub>10</sub> | Integral non-linearity, 10-bit resolution | | 1 | | LSB1( | | $V_{OS}$ | Differential offset error (calibrated), 10-bit resolution <sup>a</sup> | | +-2 | | LSB10b | | DNL <sub>12</sub> | Differential non-linearity, 12-bit resolution | -0.95 | 1.3 | | LSB12 | | INL <sub>12</sub> | Integral non-linearity, 12-bit resolution | | 4.7 | | LSB12b | | C <sub>EG</sub> | Gain error temperature coefficient | | 0.02 | | %/°C | | f <sub>SAMPLE</sub> | Maximum sampling rate | | | 200 | kHz | | t <sub>ACQ,10k</sub> | Acquisition time (configurable), source Resistance <= | | 3 | | μs | | | 10kOhm | | | | | | t <sub>ACQ,40k</sub> | Acquisition time (configurable), source Resistance <= | | 5 | | μs | | | 40kOhm | | | | | | t <sub>ACQ,100k</sub> | Acquisition time (configurable), source Resistance <= | | 10 | | μs | | | 100kOhm | | | | | | t <sub>ACQ,200k</sub> | Acquisition time (configurable), source Resistance <= | | 15 | | μs | | | 200kOhm | | | | | <sup>&</sup>lt;sup>a</sup> Digital output code at zero volt differential input. | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------------|---------------------------------------------------------------|------|------|------|-------| | t <sub>ACQ,400k</sub> | Acquisition time (configurable), source Resistance <= | | 20 | | μs | | | 400kOhm | | | | | | t <sub>ACQ,800k</sub> | Acquisition time (configurable), source Resistance <= | | 40 | | μs | | | 800kOhm | | | | | | t <sub>CONV</sub> | Conversion time | | <2 | | μs | | E <sub>G1/6</sub> | Error <sup>b</sup> for Gain = 1/6 | -3 | | 3 | % | | E <sub>G1/4</sub> | Error <sup>b</sup> for Gain = 1/4 | -3 | | 3 | % | | E <sub>G1/2</sub> | Error <sup>b</sup> for Gain = 1/2 | -3 | | 4 | % | | E <sub>G1</sub> | Error <sup>b</sup> for Gain = 1 | -3 | | 4 | % | | C <sub>SAMPLE</sub> | Sample and hold capacitance at maximum gain <sup>21</sup> | | 2.5 | | pF | | R <sub>INPUT</sub> | Input resistance | | >1 | | ΜΩ | | E <sub>NOB</sub> | Effective number of bits, differential mode, 12-bit | | 9 | | Bit | | | resolution, 1/1 gain, 3 μs acquisition time, crystal HFCLK, | | | | | | | 200 ksps | | | | | | S <sub>NDR</sub> | Peak signal to noise and distortion ratio, differential mode, | | 56 | | dB | | | 12-bit resolution, 1/1 gain, 3 μs acquisition time, crystal | | | | | | | HFCLK, 200 ksps | | | | | | S <sub>FDR</sub> | Spurious free dynamic range, differential mode, 12-bit | | 70 | | dBc | | | resolution, 1/1 gain, 3 μs acquisition time, crystal HFCLK, | | | | | | | 200 ksps | | | | | | R <sub>LADDER</sub> | Ladder resistance | | 160 | | kΩ | # 6.13.13 Performance factors Clock jitter, affecting sample timing accuracy, and circuit noise can affect ADC performance. Jitter can be between START tasks or from START task to acquisition. START timer accuracy and startup times of regulators and references will contribute to variability. Sources of circuit noise may include CPU activity and the DC/DC regulator. Best ADC performance is achieved using START timing based on the TIMER module, HFXO clock source, and Constant Latency mode. # 6.14 SPI — Serial peripheral interface master The SPI master provides a simple CPU interface which includes a TXD register for sending data and an RXD register for receiving data. This section is added for legacy support for now. <sup>&</sup>lt;sup>b</sup> Does not include temperature drift <sup>&</sup>lt;sup>21</sup> Maximum gain corresponds to highest capacitance. Figure 76: SPI master RXD-1 and TXD+1 illustrate the double buffered version of RXD and TXD respectively. #### 6.14.1 Functional description The TXD and RXD registers are double-buffered to enable some degree of uninterrupted data flow in and out of the SPI master. The SPI master does not implement support for chip select directly. Therefore, the CPU must use available GPIOs to select the correct slave and control this independently of the SPI master. The SPI master supports SPI modes 0 through 3. | Clock polarity | Clock phase | |----------------|----------------------------------------------| | CPOL | СРНА | | 0 (Leading) | 0 (Active high) | | 0 (Leading) | 1 (Active low) | | 1 (Trailing) | 0 (Active high) | | 1 (Trailing) | 1 (Active low) | | 6 | CPOL 0 (Leading) 0 (Leading) 1 (Trailing) | Table 61: SPI modes #### 6.14.1.1 SPI master mode pin configuration The different signals SCK, MOSI, and MISO associated with the SPI master are mapped to physical pins. This mapping is according to the configuration specified in the PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers respectively. If the CONNECT field of a PSEL.xxx register is set to Disconnected, the associated SPI master signal is not connected to any physical pin. The PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers and their configurations are only used as long as the SPI master is enabled, and retained only as long as the device is in ON mode. PSEL.SCK, PSEL.MOSI, and PSEL.MISO must only be configured when the SPI master is disabled. To secure correct behavior in the SPI, the pins used by the SPI must be configured in the GPIO peripheral as described in GPIO configuration on page 199 prior to enabling the SPI. The SCK must always be connected to a pin, and that pin's input buffer must always be connected for the SPI to work. This configuration must be retained in the GPIO for the selected IOs as long as the SPI is enabled. Only one peripheral can be assigned to drive a particular GPIO pin at a time, failing to do so may result in unpredictable behavior. | SPI master signal | SPI master pin | Direction | Output value | |-------------------|---------------------------|-----------|---------------------| | SCK | As specified in PSEL.SCK | Output | Same as CONFIG.CPOL | | MOSI | As specified in PSEL.MOSI | Output | 0 | | MISO | As specified in PSEL.MISO | Input | Not applicable | Table 62: GPIO configuration #### 6.14.1.2 Shared resources The SPI shares registers and other resources with other peripherals that have the same ID as the SPI. Therefore, the user must disable all peripherals that have the same ID as the SPI before the SPI can be configured and used. Disabling a peripheral that has the same ID as the SPI will not reset any of the registers that are shared with the SPI. It is therefore important to configure all relevant SPI registers explicitly to secure that it operates correctly. See the Instantiation table in Instantiation on page 17 for details on peripherals and their IDs. #### 6.14.1.3 SPI master transaction sequence An SPI master transaction is started by writing the first byte, which is to be transmitted by the SPI master, to the TXD register. Since the transmitter is double buffered, the second byte can be written to the TXD register immediately after the first one. The SPI master will then send these bytes in the order they are written to the TXD register. The SPI master is a synchronous interface, and for every byte that is sent, a different byte will be received at the same time; this is illustrated in SPI master transaction on page 200. Bytes that are received will be moved to the RXD register where the CPU can extract them by reading the register. The RXD register is double buffered in the same way as the TXD register, and a second byte can therefore be received at the same time as the first byte is being extracted from RXD by the CPU. The SPI master will generate a READY event every time a new byte is moved to the RXD register. The double buffered byte will be moved from RXD-1 to RXD as soon as the first byte is extracted from RXD. The SPI master will stop when there are no more bytes to send in TXD and TXD+1. Figure 77: SPI master transaction The READY event of the third byte transaction is delayed until B is extracted from RXD in occurrence number 3 on the horizontal lifeline. The reason for this is that the third event is generated first when C is moved from RXD-1 to RXD after B is read. The SPI master will move the incoming byte to the RXD register after a short delay following the SCK clock period of the last bit in the byte. This also means that the READY event will be delayed accordingly, see SPI master transaction on page 200. Therefore, it is important that you always clear the READY event, even if the RXD register and the data that is being received is not used. Figure 78: SPI master transaction # 6.14.2 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|-------------|---------------|------------| | 0x40004000 | SPI | SPI0 | SPI master | | Deprecated | Table 63: Instances | Register | Offset | Description | |--------------|--------|---------------------------------------------------------------| | EVENTS_READY | 0x108 | TXD byte sent and RXD byte received | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | ENABLE | 0x500 | Enable SPI | | PSEL.SCK | 0x508 | Pin select for SCK | | PSEL.MOSI | 0x50C | Pin select for MOSI signal | | PSEL.MISO | 0x510 | Pin select for MISO signal | | RXD | 0x518 | RXD register | | TXD | 0x51C | TXD register | | FREQUENCY | 0x524 | SPI frequency. Accuracy depends on the HFCLK source selected. | | CONFIG | 0x554 | Configuration register | Table 64: Register overview #### 6.14.2.1 EVENTS\_READY Address offset: 0x108 TXD byte sent and RXD byte received #### **6.14.2.2 INTENSET** Address offset: 0x304 Enable interrupt | Bit number | | 31 30 29 28 27 | 7 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 C | |------------------|----------|----------------|--------------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW READY | | | Write '1' to enable interrupt for event READY | | | Set | 1 | Enable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | #### 6.14.2.3 INTENCLR Address offset: 0x308 #### Disable interrupt #### 6.14.2.4 ENABLE Address offset: 0x500 **Enable SPI** #### 6.14.2.5 PSEL.SCK Address offset: 0x508 Pin select for SCK | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | C | АААА | | Rese | t OxFFFFFFF | | 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | Acce Field | Value ID | Value | Description | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.14.2.6 PSEL.MOSI Address offset: 0x50C Pin select for MOSI signal 202 #### 6.14.2.7 PSEL.MISO Address offset: 0x510 Pin select for MISO signal #### 6.14.2.8 RXD Address offset: 0x518 **RXD** register #### 6.14.2.9 TXD Address offset: 0x51C TXD register # 6.14.2.10 FREQUENCY Address offset: 0x524 SPI frequency. Accuracy depends on the HFCLK source selected. NORDIC | Bit r | number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|------|------------------------|-----------------------------------------------------------------| | ID | | | A A A A A A A | . A A A A A A A A A A A A A A A A A A A | | Rese | et 0x04000000 | | 0 0 0 0 0 1 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW FREQUENCY | | | SPI master data rate | | | | K125 | 0x02000000 | 125 kbps | | | | K250 | 0x04000000 | 250 kbps | | | | K500 | 0x08000000 | 500 kbps | | | | M1 | 0x10000000 | 1 Mbps | | | | M2 | 0x20000000 | 2 Mbps | | | | M4 | 0x40000000 | 4 Mbps | | | | M8 | 0x80000000 | 8 Mbps | #### 6.14.2.11 CONFIG Address offset: 0x554 Configuration register # 6.14.3 Electrical specification # 6.14.3.1 SPI master interface electrical specifications | Symbol | Description | Min. | Тур. | Max. | Units | |------------------------|--------------------------------------------------------|------|------|-----------------|-------| | f <sub>SPI</sub> | Bit rates for SPI <sup>22</sup> | | | 8 <sup>23</sup> | Mbps | | t <sub>SPI,START</sub> | Time from writing TXD register to transmission started | | 1 | | μs | #### 6.14.3.2 Serial Peripheral Interface (SPI) Master timing specifications | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------------|--------------------------------------------|------|------|----------------------|-------| | t <sub>SPI,CSCK</sub> | SCK period | 125 | | | ns | | $t_{SPI,RSCK,LD}$ | SCK rise time, standard drive <sup>a</sup> | | | t <sub>RF,25pF</sub> | | High bit rates may require GPIOs to be set as High Drive, see GPIO chapter for more details. The actual maximum data rate depends on the slave's CLK to MISO and MOSI setup and hold timings. <sup>&</sup>lt;sup>a</sup> At 25pF load, including GPIO capacitance, see GPIO spec. | Symbol | Description | Min. | Тур. | Max. | Units | |--------------------------|--------------------------------------------|-----------------------|------|-----------------------|-------| | t <sub>SPI,RSCK,HD</sub> | SCK rise time, high drive <sup>a</sup> | | | t <sub>HRF,25pF</sub> | | | t <sub>SPI,FSCK,LD</sub> | SCK fall time, standard drive <sup>a</sup> | | | t <sub>RF,25pF</sub> | | | t <sub>SPI,FSCK,HD</sub> | SCK fall time, high drive <sup>a</sup> | | | t <sub>HRF,25pF</sub> | | | t <sub>SPI,WHSCK</sub> | SCK high time <sup>a</sup> | (t <sub>CSCK</sub> /2 | ) | | | | | | - t <sub>RSCK</sub> | | | | | t <sub>SPI,WLSCK</sub> | SCK low time <sup>a</sup> | (t <sub>CSCK</sub> /2 | ) | | | | | | - t <sub>FSCK</sub> | | | | | t <sub>SPI,SUMI</sub> | MISO to CLK edge setup time | 19 | | | ns | | t <sub>SPI,HMI</sub> | CLK edge to MISO hold time | 18 | | | ns | | t <sub>SPI,VMO</sub> | CLK edge to MOSI valid | | | 59 | ns | | t <sub>SPI,HMO</sub> | MOSI hold time after CLK edge | 20 | | | ns | Figure 79: SPI master timing diagram # 6.15 SPIM — Serial peripheral interface master with EasyDMA The SPI master can communicate with multiple slaves using individual chip select signals for each of the slave devices attached to a bus. Listed here are the main features for the SPIM - SPI mode 0-3 - EasyDMA direct transfer to/from RAM for both SPI Slave and SPI Master - Individual selection of IO pin for each SPI signal Figure 80: SPIM — SPI master with EasyDMA The SPIM does not implement support for chip select directly. Therefore, the CPU must use available GPIOs to select the correct slave and control this independently of the SPI master. The SPIM supports SPI modes 0 through 3. The CONFIG register allows setting CPOL and CPHA appropriately. | Mode | Clock polarity | Clock phase | |-----------|-----------------|--------------| | | CPOL | СРНА | | SPI_MODE0 | 0 (Active High) | 0 (Leading) | | SPI_MODE1 | 0 (Active High) | 1 (Trailing) | | SPI_MODE2 | 1 (Active Low) | 0 (Leading) | | SPI_MODE3 | 1 (Active Low) | 1 (Trailing) | Table 65: SPI modes ### 6.15.1 SPI master transaction sequence An SPI master transaction consists of a sequence started by the START task followed by a number of events, and finally the STOP task. An SPI master transaction is started by triggering the START task. The ENDTX event will be generated when the transmitter has transmitted all bytes in the TXD buffer as specified in the TXD.MAXCNT register. The ENDRX event will be generated when the receiver has filled the RXD buffer, i.e. received the last possible byte as specified in the RXD.MAXCNT register. Following a START task, the SPI master will generate an END event when both ENDRX and ENDTX have been generated. The SPI master is stopped by triggering the STOP task. A STOPPED event is generated when the SPI master has stopped. If the ENDRX event has not already been generated when the SPI master has come to a stop, the SPI master will generate the ENDRX event explicitly even though the RX buffer is not full. NORDIC If the ENDTX event has not already been generated when the SPI master has come to a stop, the SPI master will generate the ENDTX event explicitly even though all bytes in the TXD buffer, as specified in the TXD.MAXCNT register, have not been transmitted. The SPI master is a synchronous interface, and for every byte that is sent, a different byte will be received at the same time; this is illustrated in SPI master transaction on page 207. Figure 81: SPI master transaction #### 6.15.2 Master mode pin configuration The SCK, MOSI, and MISO signals associated with the SPI master are mapped to physical pins according to the configuration specified in the PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers respectively. The PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers and their configurations are only used as long as the SPI master is enabled, and retained only as long as the device is in ON mode. PSEL.SCK, PSEL.MOSI and PSEL.MISO must only be configured when the SPI master is disabled. To secure correct behavior in the SPI, the pins used by the SPI must be configured in the GPIO peripheral as described in GPIO configuration on page 207 prior to enabling the SPI. This configuration must be retained in the GPIO for the selected IOs as long as the SPI is enabled. Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior. | SPI master signal | SPI master pin | Direction | Output value | |-------------------|---------------------------|-----------|---------------------| | SCK | As specified in PSEL.SCK | Output | Same as CONFIG.CPOL | | MOSI | As specified in PSEL.MOSI | Output | 0 | | MISO | As specified in PSEL.MISO | Input | Not applicable | Table 66: GPIO configuration #### 6.15.3 EasyDMA The SPIM implements EasyDMA for accessing RAM without CPU involvement. The SPIM peripheral implements the following EasyDMA channels: | Channel | Туре | Register Cluster | |---------|--------|------------------| | TXD | READER | TXD | | RXD | WRITER | RXD | Table 67: SPIM EasyDMA Channels For detailed information regarding the use of EasyDMA, see EasyDMA on page 34. The .PTR and .MAXCNT registers are double-buffered. They can be updated and prepared for the next transmission immediately after having received the STARTED event. The SPI master will automatically stop transmitting after TXD.MAXCNT bytes have been transmitted and RXD.MAXCNT bytes have been received. If RXD.MAXCNT is larger than TXD.MAXCNT, the remaining transmitted bytes will contain the value defined in the ORC register. If TXD.MAXCNT is larger than RXD.MAXCNT, the superfluous received bytes will be discarded. The ENDRX/ENDTX event indicate that EasyDMA has finished accessing respectively the RX/TX buffer in RAM. The END event gets generated when both RX and TX are finished accessing the buffers in RAM. In the case of bus congestion as described in , data loss may occur. #### 6.15.4 Low power When putting the system in low power and the peripheral is not needed, lowest possible power consumption is achieved by stopping, and then disabling the peripheral. The STOP task may not be always needed (the peripheral might already be stopped), but if it is sent, software shall wait until the STOPPED event was received as a response before disabling the peripheral through the ENABLE register. # 6.15.5 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|-------------|---------------|--| | 0x40004000 | SPIM | SPIM0 | SPI master | | | Table 68: Instances | Register | Offset | Description | |----------------|--------|------------------------------------------| | TASKS_START | 0x010 | Start SPI transaction | | TASKS_STOP | 0x014 | Stop SPI transaction | | TASKS_SUSPEND | 0x01C | Suspend SPI transaction | | TASKS_RESUME | 0x020 | Resume SPI transaction | | EVENTS_STOPPED | 0x104 | SPI transaction has stopped | | EVENTS_ENDRX | 0x110 | End of RXD buffer reached | | EVENTS_END | 0x118 | End of RXD buffer and TXD buffer reached | | EVENTS_ENDTX | 0x120 | End of TXD buffer reached | | EVENTS_STARTED | 0x14C | Transaction started | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTENSET | 0x304 | Enable interrupt | | Register | Offset | Description | |------------|--------|-------------------------------------------------------------------------------------| | INTENCLR | 0x308 | Disable interrupt | | ENABLE | 0x500 | Enable SPIM | | PSEL.SCK | 0x508 | Pin select for SCK | | PSEL.MOSI | 0x50C | Pin select for MOSI signal | | PSEL.MISO | 0x510 | Pin select for MISO signal | | FREQUENCY | 0x524 | SPI frequency. Accuracy depends on the HFCLK source selected. | | RXD.PTR | 0x534 | Data pointer | | RXD.MAXCNT | 0x538 | Maximum number of bytes in receive buffer | | RXD.AMOUNT | 0x53C | Number of bytes transferred in the last transaction | | RXD.LIST | 0x540 | EasyDMA list type | | TXD.PTR | 0x544 | Data pointer | | TXD.MAXCNT | 0x548 | Maximum number of bytes in transmit buffer | | TXD.AMOUNT | 0x54C | Number of bytes transferred in the last transaction | | TXD.LIST | 0x550 | EasyDMA list type | | CONFIG | 0x554 | Configuration register | | ORC | 0x5C0 | Over-read character. Character clocked out in case and over-read of the TXD buffer. | Table 69: Register overview #### 6.15.5.1 TASKS\_START Address offset: 0x010 Start SPI transaction # 6.15.5.2 TASKS\_STOP Address offset: 0x014 Stop SPI transaction # 6.15.5.3 TASKS\_SUSPEND Address offset: 0x01C Suspend SPI transaction | Bit n | umb | er | | 313 | 0 29 | 28 | 27 2 | 6 2 | 25 2 | 4 2 | 23 2 | 22 2 | 21 2 | 20 1 | 9 1 | 8 17 | 7 16 | 15 | 14 | 13 | 12 1 | .1 1 | 0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 : | 1 0 | |-------|-------|---------------|---------|-----|------|----|------|-----|------|-----|------|------|------|-------|-----|------|------|----|----|----|------|------|-----|---|---|---|---|---|---|-----|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t OxC | 0000000 | | 0 | 0 0 | 0 | 0 ( | כ | 0 ( | 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | W | TASKS_SUSPEND | | | | | | | | | Sus | per | nd S | SPI t | ran | ısac | tior | 1 | | | | | | | | | | | | | | | | | | Trigger | 1 | | | | | | | Trig | ger | tas | sk | | | | | | | | | | | | | | | | | | #### 6.15.5.4 TASKS\_RESUME Address offset: 0x020 Resume SPI transaction | Bit r | number | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------|---------|----------------|------------------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_RESUME | | | Resume SPI transaction | | | | Trigger | 1 | Trigger task | # 6.15.5.5 EVENTS\_STOPPED Address offset: 0x104 SPI transaction has stopped # 6.15.5.6 **EVENTS\_ENDRX** Address offset: 0x110 End of RXD buffer reached | Bit number | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|------------------|------------------------------------------------------------------------| | ID | | А | | Reset 0x00000000 | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A RW EVENTS_ENDRX | | End of RXD buffer reached | | NotGen | erated 0 | Event not generated | | Generat | ed 1 | Event generated | #### 6.15.5.7 EVENTS END Address offset: 0x118 End of RXD buffer and TXD buffer reached 4454\_187 v0.5 210 NORI | Bit number | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|------------------|------------------------------------------------------------------------| | ID | | А | | Reset 0x00000000 | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A RW EVENTS_END | | End of RXD buffer and TXD buffer reached | | NotGener | ated 0 | Event not generated | | Generated | 1 | Event generated | # 6.15.5.8 EVENTS\_ENDTX Address offset: 0x120 End of TXD buffer reached | Bit r | number | | 31 30 29 2 | 28 27 26 | 25 24 | 4 23 22 | 2 21 2 | 0 19 : | 18 17 | 16 19 | 5 14 1 | 13 12 | 2 11 | 10 9 | 8 | 7 | 6 | 5 4 | 3 | 2 | 1 0 | |-------|-----------------|--------------|------------|----------|-------|---------|---------|--------|--------|-------|--------|-------|------|------|---|---|---|-----|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | Α | | Res | et 0x00000000 | | 0 0 0 | 0 0 0 | 0 0 | 0_0 | 0 0 | 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | | ID | | | | | ı | Desc | ription | | | 厂 | | | | | | | | | | | | | Α | RW EVENTS_ENDTX | | | | | End | of TXD | buff | er rea | ached | | | | | | | | | | | | | | | NotGenerated | 0 | | | Even | t not g | gener | ated | | | | | | | | | | | | | | | | Generated | 1 | | | Even | t gene | rate | b | | 1 | | | | | | | | | | | # 6.15.5.9 EVENTS\_STARTED Address offset: 0x14C Transaction started | Bit number | | 31 30 | 29 28 | 27 26 | 25 | 24 2 | 3 22 | 21 20 | 19 1 | l8 17 | 16 1 | .5 14 | 13 | 12 11 | . 10 | 9 8 | 7 | 6 | 5 | 4 3 | 2 | 1 0 | |---------------------|--------------|-------|-------|-------|----|------|-------|--------|-------|-------|------|-------|----|-------|------|-----|---|---|---|-----|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | Α | | Reset 0x00000000 | | 0 0 | 0 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 0 | 0 ( | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 0 | | ID Acce Field | Value ID | Value | | | | 1 | escri | | | | | | | | | | | | | | | | | A RW EVENTS_STARTED | | | | | | T | ransa | action | star | ted | | | | | | | | | | | | | | | NotGenerated | 0 | | | | E | vent | not g | ener | ated | | | | | | | | | | | | | | | Generated | 1 | | | | E | vent | gene | rated | I | | | | | | | | | | | | | # 6.15.5.10 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit n | umber | | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------------------|-----------------------------------------------------------------------| | ID | | | | А | | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW END_START | | | Shortcut between event END and task START | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | #### 6.15.5.11 INTENSET Address offset: 0x304 Enable interrupt | Bit n | umber | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|----------|-------------------|---------------------------------------------------------------------| | ID | | | | E D C B A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | A | RW STOPPED | | | Write '1' to enable interrupt for event STOPPED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW ENDRX | | | Write '1' to enable interrupt for event ENDRX | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW END | | | Write '1' to enable interrupt for event END | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW ENDTX | | | Write '1' to enable interrupt for event ENDTX | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | E | RW STARTED | | | Write '1' to enable interrupt for event STARTED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | # 6.15.5.12 INTENCLR Address offset: 0x308 Disable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | E D C B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | Acce Field | Value ID | Value | | | Α | RW STOPPED | | | Write '1' to disable interrupt for event STOPPED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW ENDRX | | | Write '1' to disable interrupt for event ENDRX | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW END | | | Write '1' to disable interrupt for event END | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW ENDTX | | | Write '1' to disable interrupt for event ENDTX | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | E | RW STARTED | | | Write '1' to disable interrupt for event STARTED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 1 0 E Reset 0x00000000 D Acce Field Value Description D Value Description D D D D D D D D D | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ID E D C B A | | | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | #### 6.15.5.13 ENABLE Address offset: 0x500 **Enable SPIM** | Bit number | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 | |------------------|----------|----------------|----------------------------------------------------------------------|---| | ID | | | A A A | Α | | Reset 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | ID Acce Field | | | Description | | | A RW ENABLE | | | Enable or disable SPIM | | | | Disabled | 0 | Disable SPIM | | | | Enabled | 7 | Enable SPIM | | #### 6.15.5.14 PSEL.SCK Address offset: 0x508 Pin select for SCK #### 6.15.5.15 PSEL.MOSI Address offset: 0x50C Pin select for MOSI signal | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | С | АААА | | Rese | t OxFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | Description | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.15.5.16 PSEL.MISO Address offset: 0x510 Pin select for MISO signal | Bit number | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | С | ААААА | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field | | | Description | | A RW PIN | | [031] | Pin number | | C RW CONNECT | | | Connection | | | Disconnected | 1 | Disconnect | | | Connected | 0 | Connect | #### 6.15.5.17 FREQUENCY Address offset: 0x524 SPI frequency. Accuracy depends on the HFCLK source selected. | Bit number | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|------|----------------------|--------------------------------------------------------------------| | ID | | A A A A A A | | | Reset 0x04000000 | | 0 0 0 0 0 1 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW FREQUENCY | | | SPI master data rate | | | K125 | 0x02000000 | 125 kbps | | | K250 | 0x04000000 | 250 kbps | | | K500 | 0x08000000 | 500 kbps | | | M1 | 0x10000000 | 1 Mbps | | | M2 | 0x20000000 | 2 Mbps | | | M4 | 0x40000000 | 4 Mbps | | | M8 | 0x80000000 | 8 Mbps | | | | | | # 6.15.5.18 RXD.PTR Address offset: 0x534 Data pointer 6.15.5.19 RXD.MAXCNT Address offset: 0x538 Maximum number of bytes in receive buffer | A | RW MAXCNT | value ID | [10x3FFF] | Maximum number of bytes in receive buffer | |-------|--------------|----------|------------------------|------------------------------------------------------------------| | ID | Acce Field | | | Description | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID | | | | A A A A A A A A A A A A A A A A A A A | | Bit n | umber | | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | #### 6.15.5.20 RXD.AMOUNT Address offset: 0x53C Number of bytes transferred in the last transaction | Bit number | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------------------|------------------------------------------------------------------| | ID | | A A A A A A A A A A A A A A A A A A A | | Reset 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | A R AMOUNT | [10x3FFF] | Number of bytes transferred in the last transaction | #### 6.15.5.21 RXD.LIST Address offset: 0x540 EasyDMA list type #### 6.15.5.22 TXD.PTR Address offset: 0x544 Data pointer **Note:** See the memory chapter for details about which memories are available for EasyDMA. #### 6.15.5.23 TXD.MAXCNT Address offset: 0x548 Maximum number of bytes in transmit buffer | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 10 10 10 10 10 10 10 10 10 10 10 10 | A RW MAXCNT | [10x3FFF] | Maximum number of bytes in transmit buffer | |--------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------|------------------------------------------------------------------| | ID A A A A A A A A A A A A A A A A A A A | ID Acce Field | | | | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | ID | | A A A A A A A A A A A A A A A A A A A | | | Bit number | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | #### 6.15.5.24 TXD.AMOUNT Address offset: 0x54C Number of bytes transferred in the last transaction #### 6.15.5.25 TXD.LIST Address offset: 0x550 EasyDMA list type #### 6.15.5.26 CONFIG Address offset: 0x554 Configuration register #### 6.15.5.27 ORC Address offset: 0x5C0 Over-read character. Character clocked out in case and over-read of the TXD buffer. | Bit number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|---------------------------------------------------------------------------------------| | ID | A A A A A A A | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value Description | | A RW ORC | Over-read character. Character clocked out in case and over- | read of the TXD buffer. # 6.15.6 Electrical specification # 6.15.6.1 SPIM master interface electrical specifications | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|----------------------------------------------|------|------|-----------------|-------| | f <sub>SPIM</sub> | Bit rates for SPIM <sup>24</sup> | | | 8 <sup>25</sup> | Mbps | | t <sub>SPIM,START</sub> | Time from START task to transmission started | | | | μs | # 6.15.6.2 Serial Peripheral Interface Master (SPIM) timing specifications | Symbol | Description | Min. Typ. | Max. | Units | |---------------------------|--------------------------------------------|--------------------------|-----------------------|-------| | t <sub>SPIM,CSCK</sub> | SCK period | | | ns | | t <sub>SPIM,RSCK,LD</sub> | SCK rise time, standard drive <sup>a</sup> | | t <sub>RF,25pF</sub> | | | $t_{SPIM,RSCK,HD}$ | SCK rise time, high drive <sup>a</sup> | | t <sub>HRF,25pF</sub> | | | t <sub>SPIM,FSCK,LD</sub> | SCK fall time, standard drive <sup>a</sup> | | t <sub>RF,25pF</sub> | | | t <sub>SPIM,FSCK,HD</sub> | SCK fall time, high drive <sup>a</sup> | | t <sub>HRF,25pF</sub> | | | t <sub>SPIM,WHSCK</sub> | SCK high time <sup>a</sup> | (0.5*t <sub>CSCK</sub> | | | | | | - t <sub>RSCK</sub> | | | | t <sub>SPIM,WLSCK</sub> | SCK low time <sup>a</sup> | (0.5*t <sub>CSCK</sub> ) | | | | | | – t <sub>FSCK</sub> | | | | t <sub>SPIM,SUMI</sub> | MISO to CLK edge setup time | 19 | | ns | | t <sub>SPIM,HMI</sub> | CLK edge to MISO hold time | 18 | | ns | | t <sub>SPIM,VMO</sub> | CLK edge to MOSI valid | | 59 | ns | | t <sub>SPIM,HMO</sub> | MOSI hold time after CLK edge | 20 | | ns | High bit rates may require GPIOs to be set as High Drive, see GPIO chapter for more details. The actual maximum data rate depends on the slave's CLK to MISO and MOSI setup and hold timings. <sup>&</sup>lt;sup>a</sup> At 25pF load, including GPIO pin capacitance, see GPIO spec. Figure 82: SPIM timing diagram # 6.16 SPIS — Serial peripheral interface slave with EasyDMA SPI slave (SPIS) is implemented with EasyDMA support for ultra low power serial communication from an external SPI master. EasyDMA in conjunction with hardware-based semaphore mechanisms removes all real-time requirements associated with controlling the SPI slave from a low priority CPU execution context. Figure 83: SPI slave The SPIS supports SPI modes 0 through 3. The CONFIG register allows setting CPOL and CPHA appropriately. | Mode | Clock polarity | Clock phase | |-----------|-----------------|-------------------| | | CPOL | СРНА | | SPI_MODE0 | 0 (Active High) | 0 (Trailing Edge) | | SPI_MODE1 | 0 (Active High) | 1 (Leading Edge) | | SPI_MODE2 | 1 (Active Low) | 0 (Trailing Edge) | | SPI_MODE3 | 1 (Active Low) | 1 (Leading Edge) | Table 70: SPI modes #### 6.16.1 Shared resources The SPI slave shares registers and other resources with other peripherals that have the same ID as the SPI slave. Therefore, you must disable all peripherals that have the same ID as the SPI slave before the SPI slave can be configured and used. Disabling a peripheral that has the same ID as the SPI slave will not reset any of the registers that are shared with the SPI slave. It is important to configure all relevant SPI slave registers explicitly to secure that it operates correctly. The Instantiation table in Instantiation on page 17 shows which peripherals have the same ID as the SPI slave. #### 6.16.2 EasyDMA The SPIS implements EasyDMA for accessing RAM without CPU involvement. The SPIS peripheral implements the following EasyDMA channels: | Channel | Туре | Register Cluster | |---------|--------|------------------| | TXD | READER | TXD | | RXD | WRITER | RXD | Table 71: SPIS EasyDMA Channels For detailed information regarding the use of EasyDMA, see EasyDMA on page 34. If RXD.MAXCNT is larger than TXD.MAXCNT, the remaining transmitted bytes will contain the value defined in the ORC register. The END event indicates that EasyDMA has finished accessing the buffer in RAM. #### 6.16.3 SPI slave operation SPI slave uses two memory pointers, RXD.PTR and TXD.PTR, that point to the RXD buffer (receive buffer) and TXD buffer (transmit buffer) respectively. Since these buffers are located in RAM, which can be accessed by both the SPI slave and the CPU, a hardware based semaphore mechanism is implemented to enable safe sharing. See SPI transaction when shortcut between END and ACQUIRE is enabled on page 221. Before the CPU can safely update the RXD.PTR and TXD.PTR pointers it must first acquire the SPI semaphore. The CPU can acquire the semaphore by triggering the ACQUIRE task and then receiving the ACQUIRED event. When the CPU has updated the RXD.PTR and TXD.PTR pointers the CPU must release the semaphore before the SPI slave will be able to acquire it. The CPU releases the semaphore by triggering the RELEASE task. This is illustrated in SPI transaction when shortcut between END and ACQUIRE is enabled on page 221. Triggering the RELEASE task when the semaphore is not granted to the CPU will have no effect. The semaphore mechanism does not, at any time, prevent the CPU from performing read or write access to the RXD.PTR register, the TXD.PTR registers, or the RAM that these pointers are pointing to. The semaphore is only telling when these can be updated by the CPU so that safe sharing is achieved. The semaphore is by default assigned to the CPU after the SPI slave is enabled. No ACQUIRED event will be generated for this initial semaphore handover. An ACQUIRED event will be generated immediately if the ACQUIRE task is triggered while the semaphore is assigned to the CPU. The SPI slave will try to acquire the semaphore when CSN goes low. If the SPI slave does not manage to acquire the semaphore at this point, the transaction will be ignored. This means that all incoming data on MOSI will be discarded, and the DEF (default) character will be clocked out on the MISO line throughout the whole transaction. This will also be the case even if the semaphore is released by the CPU during the transaction. In case of a race condition where the CPU and the SPI slave try to acquire the semaphore at the same time, as illustrated in lifeline item 2 in SPI transaction when shortcut between END and ACQUIRE is enabled on page 221, the semaphore will be granted to the CPU. If the SPI slave acquires the semaphore, the transaction will be granted. The incoming data on MOSI will be stored in the RXD buffer and the data in the TXD buffer will be clocked out on MISO. When a granted transaction is completed and CSN goes high, the SPI slave will automatically release the semaphore and generate the END event. As long as the semaphore is available the SPI slave can be granted multiple transactions one after the other. If the CPU is not able to reconfigure the TXD.PTR and RXD.PTR between granted transactions, the same TX data will be clocked out and the RX buffers will be overwritten. To prevent this from happening, the END\_ACQUIRE shortcut can be used. With this shortcut enabled the semaphore will be handed over to the CPU automatically after the granted transaction has completed, giving the CPU the ability to update the TXPTR and RXPTR between every granted transaction. If the CPU tries to acquire the semaphore while it is assigned to the SPI slave, an immediate handover will not be granted. However, the semaphore will be handed over to the CPU as soon as the SPI slave has released the semaphore after the granted transaction is completed. If the END\_ACQUIRE shortcut is enabled and the CPU has triggered the ACQUIRE task during a granted transaction, only one ACQUIRE request will be served following the END event. The MAXRX register specifies the maximum number of bytes the SPI slave can receive in one granted transaction. If the SPI slave receives more than MAXRX number of bytes, an OVERFLOW will be indicated in the STATUS register and the incoming bytes will be discarded. The MAXTX parameter specifies the maximum number of bytes the SPI slave can transmit in one granted transaction. If the SPI slave is forced to transmit more than MAXTX number of bytes, an OVERREAD will be indicated in the STATUS register and the ORC character will be clocked out. The RXD.AMOUNT and TXD.AMOUNT registers are updated when a granted transaction is completed. The TXD.AMOUNT register indicates how many bytes were read from the TX buffer in the last transaction, that is, ORC (over-read) characters are not included in this number. Similarly, the RXD.AMOUNT register indicates how many bytes were written into the RX buffer in the last transaction. The ENDRX event is generated when the RX buffer has been filled. Figure 84: SPI transaction when shortcut between END and ACQUIRE is enabled # 6.16.4 Pin configuration The CSN, SCK, MOSI, and MISO signals associated with the SPI slave are mapped to physical pins according to the configuration specified in the PSEL.CSN, PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers respectively. If the CONNECT field of any of these registers is set to Disconnected, the associated SPI slave signal will not be connected to any physical pins. The PSEL.CSN, PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers and their configurations are only used as long as the SPI slave is enabled, and retained only as long as the device is in System ON mode, see POWER — Power supply on page 46 chapter for more information about power modes. When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field and PIN\_CNF[n] register. PSEL.CSN, PSEL.SCK, PSEL.MOSI, and PSEL.MISO must only be configured when the SPI slave is disabled. To secure correct behavior in the SPI slave, the pins used by the SPI slave must be configured in the GPIO peripheral as described in GPIO configuration before enabling peripheral on page 222 before enabling the SPI slave. This is to secure that the pins used by the SPI slave are driven correctly if the SPI slave itself is temporarily disabled, or if the device temporarily enters System OFF. This configuration must be retained in the GPIO for the selected I/Os as long as the SPI slave is to be recognized by an external SPI master. The MISO line is set in high impedance as long as the SPI slave is not selected with CSN. Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior. | SPI signal | SPI pin | Direction | Output value Comment | |------------|---------------------------|-----------|-------------------------------------------------------------| | CSN | As specified in PSEL.CSN | Input | Not applicable | | SCK | As specified in PSEL.SCK | Input | Not applicable | | MOSI | As specified in PSEL.MOSI | Input | Not applicable | | MISO | As specified in PSEL.MISO | Input | Not applicable Emulates that the SPI slave is not selected. | Table 72: GPIO configuration before enabling peripheral # 6.16.5 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|-------------|---------------| | 0x40004000 | SPIS | SPIS0 | SPI slave | | Table 73: Instances | Register | Offset | Description | | |-----------------|--------|-------------------------------------------------------------|------------| | TASKS_ACQUIRE | 0x024 | Acquire SPI semaphore | | | TASKS_RELEASE | 0x028 | Release SPI semaphore, enabling the SPI slave to acquire it | | | EVENTS_END | 0x104 | Granted transaction completed | | | EVENTS_ENDRX | 0x110 | End of RXD buffer reached | | | EVENTS_ACQUIRED | 0x128 | Semaphore acquired | | | SHORTS | 0x200 | Shortcuts between local events and tasks | | | INTENSET | 0x304 | Enable interrupt | | | INTENCLR | 0x308 | Disable interrupt | | | SEMSTAT | 0x400 | Semaphore status register | | | STATUS | 0x440 | Status from last transaction | | | ENABLE | 0x500 | Enable SPI slave | | | PSEL.SCK | 0x508 | Pin select for SCK | | | PSEL.MISO | 0x50C | Pin select for MISO signal | | | PSEL.MOSI | 0x510 | Pin select for MOSI signal | | | PSEL.CSN | 0x514 | Pin select for CSN signal | | | PSELSCK | 0x508 | Pin select for SCK | Deprecated | | PSELMISO | 0x50C | Pin select for MISO | Deprecated | | PSELMOSI | 0x510 | Pin select for MOSI | Deprecated | | PSELCSN | 0x514 | Pin select for CSN | Deprecated | | RXDPTR | 0x534 | RXD data pointer | Deprecated | | MAXRX | 0x538 | Maximum number of bytes in receive buffer | Deprecated | | AMOUNTRX | 0x53C | Number of bytes received in last granted transaction | Deprecated | | RXD.PTR | 0x534 | RXD data pointer | | | RXD.MAXCNT | 0x538 | Maximum number of bytes in receive buffer | | | RXD.AMOUNT | 0x53C | Number of bytes received in last granted transaction | | | RXD.LIST | 0x540 | EasyDMA list type | | | TXDPTR | 0x544 | TXD data pointer | Deprecated | | MAXTX | 0x548 | Maximum number of bytes in transmit buffer | Deprecated | | AMOUNTTX | 0x54C | Number of bytes transmitted in last granted transaction | Deprecated | | TXD.PTR | 0x544 | TXD data pointer | | | TXD.MAXCNT | 0x548 | Maximum number of bytes in transmit buffer | | | TXD.AMOUNT | 0x54C | Number of bytes transmitted in last granted transaction | | | TXD.LIST | 0x550 | EasyDMA list type | | | CONFIG | 0x554 | Configuration register | | | | | | | | Register | Offset | Description | |----------|--------|-----------------------------------------------------------------------------| | DEF | 0x55C | Default character. Character clocked out in case of an ignored transaction. | | ORC | 0x5C0 | Over-read character | Table 74: Register overview # 6.16.5.1 TASKS\_ACQUIRE Address offset: 0x024 Acquire SPI semaphore | Bit r | number | | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|---------|------------------|-----------------------------------------------------------------------| | ID | | | | A | | Res | et 0x00000000 | | 0 0 0 0 0 0 | | | ID | | | | Description | | Α | W TASKS_ACQUIRE | | | Acquire SPI semaphore | | | | Trigger | 1 | Trigger task | # 6.16.5.2 TASKS\_RELEASE Address offset: 0x028 Release SPI semaphore, enabling the SPI slave to acquire it | Bit number | | 31 30 29 | 9 28 27 26 25 24 | 23 22 21 20 19 18 | 17 16 15 14 13 | 12 11 10 9 | 8 7 6 | 5 4 3 | 2 1 0 | |-------------------|----------|----------|------------------|-------------------|----------------|---------------|-----------|-------|-------| | ID | | | | | | | | | А | | Reset 0x00000000 | | 0 0 0 | 00000 | 00000 | 00000 | 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 0 | | ID Acce Field | Value ID | Value | | Description | | | | | | | A W TASKS_RELEASE | | | | Release SPI semap | hore, enabling | the SPI slave | to acquir | e it | | | | Trigger | 1 | | Trigger task | | | | | | # 6.16.5.3 **EVENTS END** Address offset: 0x104 Granted transaction completed | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW EVENTS_END | | | Granted transaction completed | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | # 6.16.5.4 EVENTS\_ENDRX Address offset: 0x110 End of RXD buffer reached | Bit number | 313 | 30 29 28 27 26 25 | 24 23 22 | 21 20 1 | 9 18 17 | 16 15 | 14 13 | 12 11 | 10 9 | 8 | 7 6 | 5 | 4 | 3 2 | 1 0 | |--------------------|-------------|-------------------|----------|----------|----------|-------|-------|-------|------|-----|-----|---|---|-----|-----| | ID | | | | | | | | | | | | | | | А | | Reset 0x00000000 | 0 | 0 0 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 ( | 0 | 0 | 0 | 0 0 | 0 0 | | ID Acce Field Valu | | | | | | | | | | | | | | | | | A RW EVENTS_ENDRX | | | End of | f RXD bu | uffer re | ached | | | | | | | | | | | Note | Generated 0 | | Event | not gen | erated | | | | | | | | | | | | Gen | nerated 1 | | Event | generat | ted | | | | | | | | | | | # 6.16.5.5 EVENTS\_ACQUIRED Address offset: 0x128 Semaphore acquired | Bit r | number | | 31 30 29 28 | 27 26 25 | 24 23 22 | 21 20 3 | 19 18 1 | 7 16 1 | 15 14 | 13 1 | 2 11 | 10 9 | 8 | 7 | 6 5 | 4 | 3 | 2 | 1 0 | |-------|--------------------|--------------|-------------|----------|----------|---------|---------|--------|-------|------|------|------|---|---|-----|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | Α | | Res | et 0x00000000 | | 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 0 | 0 | 0 0 | 0 ( | 0 ( | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | Descr | iption | | | | | | | | | | | | | | | Α | RW EVENTS_ACQUIRED | | | | Sema | phore a | cquire | d | | | | | | | | | | | | | | | NotGenerated | 0 | | Event | not ge | nerate | d | | | | | | | | | | | | | | | Generated | 1 | | Event | genera | ited | | | | | | | | | | | | | # 6.16.5.6 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit no | umber | | | 313 | 0 29 2 | 28 27 20 | 6 25 | 5 24 | 23 2 | 22 2 | 1 20 | 19 1 | 8 17 | 16 1 | .5 1 | 4 13 | 12 1 | 1 10 | 9 | 8 | 7 6 | 5 5 | 4 | 3 | 2 | 1 0 | |--------|----------------|----------|---|------|--------|----------|------|------|------|-------|-------|------|------|-------|------|------|------|------|------|----|-----|-----|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | Α | | | Rese | t 0x00000000 | | · | 0 ( | 0 0 | 0 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 ( | 0 | 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 0 | | ID | Acce Field | Value ID | | Valu | | | | 7 | Des | crip | | | | | | | | | | | | | | | | | | Α | RW END_ACQUIRE | | | | | V | | | Sho | ortcu | it be | twee | n ev | ent l | ND | and | task | ACC | QUIF | RE | | | | | | | | | | Disabled | | 0 | | | | | Disa | able | shor | tcut | | | | | | | | | | | | | | | | | | Enabled | | 1 | | <b>F</b> | | | Ena | able | shor | tcut | | | | | | | | | | | | | | | # 6.16.5.7 INTENSET Address offset: 0x304 Enable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | C B A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW END | | | Write '1' to enable interrupt for event END | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW ENDRX | | | Write '1' to enable interrupt for event ENDRX | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW ACQUIRED | | | Write '1' to enable interrupt for event ACQUIRED | | Bit number | | 31 30 29 28 27 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 | |------------------|----------|----------------|-------------------------------------------------------|-----------------| | ID | | | С | В А | | Reset 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 00000000 | | ID Acce Field | | | | | | | Set | 1 | Enable | | | | | = | LIIdDIC | | | | Disabled | 0 | Read: Disabled | | #### 6.16.5.8 INTENCLR Address offset: 0x308 Disable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|----------------------|--------------------------------------------------------------------| | ID | | | | C B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW END | | | Write '1' to disable interrupt for event END | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW ENDRX | | A (74 | Write '1' to disable interrupt for event ENDRX | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW ACQUIRED | | | Write '1' to disable interrupt for event ACQUIRED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | # 6.16.5.9 SEMSTAT Address offset: 0x400 Semaphore status register | Bit number | | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|------------|------------------|------------------------------------------------------------------------| | ID | | | A A | | Reset 0x00000001 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | | | | A R SEMSTAT | | | Semaphore status | | | Free | 0 | Semaphore is free | | | CPU | 1 | Semaphore is assigned to CPU | | | SPIS | 2 | Semaphore is assigned to SPI slave | | | CPUPending | 3 | Semaphore is assigned to SPI but a handover to the CPU is | | | | | pending | #### 6.16.5.10 STATUS Address offset: 0x440 Status from last transaction Individual bits are cleared by writing a '1' to the bits that shall be cleared | Bit number | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|------------|-------------------------|-----------------------------------------------------------------| | ID | | | В А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW OVERREAD | | | TX buffer over-read detected, and prevented | | | NotPresent | 0 | Read: error not present | | | Present | 1 | Read: error present | | | Clear | 1 | Write: clear error on writing '1' | | B RW OVERFLOW | | | RX buffer overflow detected, and prevented | | | NotPresent | 0 | Read: error not present | | | Present | 1 | Read: error present | | | Clear | 1 | Write: clear error on writing '1' | #### 6.16.5.11 ENABLE Address offset: 0x500 **Enable SPI slave** #### 6.16.5.12 PSEL.SCK Address offset: 0x508 Pin select for SCK #### 6.16.5.13 PSEL.MISO Address offset: 0x50C Pin select for MISO signal | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | С | ААААА | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field | | | Description | | A RW PIN | | [031] | Pin number | | C RW CONNECT | | | Connection | | | Disconnected | 1 | Disconnect | | | Connected | 0 | Connect | #### 6.16.5.14 PSEL.MOSI Address offset: 0x510 Pin select for MOSI signal | Bit n | umber | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 | 18 17 16 15 1 | 4 13 12 11 10 | 9876 | 5 5 4 | 4 3 | 2 1 0 | |-------|--------------|--------------|----------------|-------------------------|---------------|---------------|---------|-------|-------|-------| | ID | | | С | <b>A</b> | | | | A | A A . | A A A | | Rese | et OxFFFFFFF | | 1 1 1 1 1 | 1 1 1 1 1 1 1 1 | 11111 | 1111 | 1 1 1 1 | . 1 1 | 1 1 | 1 1 1 | | ID | | | | Description | | | | | | | | Α | RW PIN | | [031] | Pin number | | | | | | | | С | RW CONNECT | | | Connection | | | | | | | | | | Disconnected | 1 | Disconnect | | | | | | | | | | Connected | 0 | Connect | | | | | | | #### 6.16.5.15 PSEL.CSN Address offset: 0x514 Pin select for CSN signal | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | С | АААА | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID Acce Field | Value ID | Value | Description | | A RW PIN | | [031] | Pin number | | C RW CONNECT | | | Connection | | | Disconnected | 1 | Disconnect | | | Connected | 0 | Connect | # 6.16.5.16 PSELSCK ( Deprecated ) Address offset: 0x508 Pin select for SCK # 6.16.5.17 PSELMISO ( Deprecated ) Address offset: 0x50C #### Pin select for MISO #### 6.16.5.18 PSELMOSI (Deprecated) Address offset: 0x510 Pin select for MOSI | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 D | | |-----------------------------------------------------------------------------------------------|-------| | ID A A A A A A A A A A A A A A A A A A A | | | ID A A A A A A A A A A A A A A A A A A A | | | | 1 1 1 | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | AAA | | | 2 1 0 | # 6.16.5.19 PSELCSN ( Deprecated Address offset: 0x514 Pin select for CSN # 6.16.5.20 RXDPTR (Deprecated) Address offset: 0x534 RXD data pointer | Bit n | umber | 31 | 30 2 | 29 : | 28 | 27 : | 26 | 25 | 24 | 23 | 22 : | 21 2 | 20 1 | 9 1 | 8 17 | ' 16 | 15 | 14 | 13 : | 12 1 | .1 1 | 0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 : | 1 0 | |-------|--------------|----|------|------|----|------|----|----|----|-----|------|------|------|------|------|------|----|----|------|------|------|-----|---|---|---|---|---|-----|-----|-----| | ID | | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α. | A A | λ Α | A | Α | Α | Α | Α | A . | 4 Α | \ A | Α | Α | Α | Α | Α | Α . | Α, | А А | | Rese | t 0x00000000 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW RXDPTR | | | | | | | | | RXI | ) da | ata | poiı | nter | | | | | | | | | | | | | | | | | **Note:** See the memory chapter for details about which memories are available for EasyDMA. #### 6.16.5.21 MAXRX (Deprecated) Address offset: 0x538 Maximum number of bytes in receive buffer | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 1 0 A A A A A A A A A A A A A A A A A A | |-------------------------------------------------------------------------------------------------------------------------------------------| | | | | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | # 6.16.5.22 AMOUNTRX (Deprecated) Address offset: 0x53C Number of bytes received in last granted transaction | A R AMOUNTRX | [10x3FFF] | Number of bytes received in the last granted tr | | |------------------|----------------------|-------------------------------------------------|-------------------| | ID Acce Field | | Description | | | Reset 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 | | ID | | A A A A A | A A A A A A A A | | Bit number | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8 7 6 5 4 3 2 1 0 | #### 6.16.5.23 RXD.PTR Address offset: 0x534 RXD data pointer # 6.16.5.24 RXD.MAXCNT Address offset: 0x538 Maximum number of bytes in receive buffer | Reset 0x00000000 | <b>0</b><br>Value ID | | 0 0 0 0 0 | Descri | | 0 0 | 0 0 | 0 0 | 0 0 | 0 ( | 0 0 | 0 | 0 | 0 0 | 0 | 0 0 | 0 | |------------------|----------------------|---------|----------------|----------|----------|---------|---------|-------|-------|------|-----|---|----|-----|---|-----|-----| | Reset 0x0000000 | 0 | 0 0 | 0 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 ( | 0 | 0 | 0 | 0 0 | 0 | 0 0 | 0 | | | | | | | | | | | | | | | _ | | _ | | | | ID | | | | | | | | А | А А | A A | A A | Α | Α. | A A | Α | A A | A | | Bit number | | 31 30 2 | 29 28 27 26 25 | 24 23 22 | 21 20 19 | 9 18 17 | ' 16 19 | 14 13 | 12 11 | 10 9 | 8 | 7 | 6 | 5 4 | 3 | 2 1 | . 0 | #### 6.16.5.25 RXD.AMOUNT Address offset: 0x53C Number of bytes received in last granted transaction | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 10 ID | A R AMOUNT | [10x3FFF] | Number of bytes received in the last granted transaction | |---------------------------------------------------------------------------------------------------------|------------------|---------------------|--------------------------------------------------------------------| | ID A A A A A A A A A A A A A A A A A A A | ID Acce Field | | Description | | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | ID | | A A A A A A A A A A A A A A A A A A A | | | Bit number | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | #### 6.16.5.26 RXD.LIST Address offset: 0x540 EasyDMA list type | Bit r | number | | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|-----------|------------------|-----------------------------------------------------------------------| | ID | | | | Α Α | | Rese | et 0x0000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW LIST | | | List type | | | | Disabled | 0 | Disable EasyDMA list | | | | ArrayList | 1 | Use array list | # 6.16.5.27 TXDPTR ( Deprecated ) Address offset: 0x544 TXD data pointer # 6.16.5.28 MAXTX (Deprecated) Address offset: 0x548 Maximum number of bytes in transmit buffer | Bit | umber | 31 | 30 2 | 9 2 | 8 27 | 7 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 1 | .8 1 | 7 16 | 15 | 14 | 13 | 12 | 11 1 | .0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-----|---------------|----|------|------|------|------|----|----|----|------|-----|------|------|------|------|------|----|------|-----|------|------|----|---|---|---|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | Α | Α | Α. | 4 Α | A | Α | Α | Α | Α | Α | Α | А А | | Res | et 0x00000000 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW MAXTX | [1 | 0x3I | FFF] | l | | | | M | axir | nur | n nı | umb | er c | of b | /tes | in | trar | nsm | it b | uffe | er | | | | | | | | # 6.16.5.29 AMOUNTTX (Deprecated) Address offset: 0x54C Number of bytes transmitted in last granted transaction NORDIC\* | A R AMOUNTT | X | [10x3FFF] | Number of bytes transmitted in last granted transaction | |------------------|---|-------------------------|------------------------------------------------------------------| | ID Acce Field | | | Description | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | A A A A A A A A A A A A A A A A A A A | | Bit number | | 31 30 29 28 27 26 25 24 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | | #### 6.16.5.30 TXD.PTR Address offset: 0x544 TXD data pointer | Bit r | number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|---------------------------------------------------------------------------------------| | ID | | A A A A A A A A A A A A A A A A A A A | | Res | et 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | Value Description | | Α | RW PTR | TXD data pointer | **Note:** See the memory chapter for details about which memories are available for EasyDMA. #### 6.16.5.31 TXD.MAXCNT Address offset: 0x548 Maximum number of bytes in transmit buffer | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|---------------------------------------------------------------------------------------| | ID | | A A A A A A A A A A A A A A A A A A A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | Value Description | | A RW MAXCNT | | [10x3FFF] Maximum number of bytes in transmit buffer | #### 6.16.5.32 TXD.AMOUNT Address offset: 0x54C Number of bytes transmitted in last granted transaction | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 ID Acce Field Value ID Value Description | A R AMOUNT | [10x3FFF] | Number of bytes transmitted in last granted transaction | |----------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------|---------------------------------------------------------------| | ID A A A A A A A A A A A A A A A A A A A | | | | | | Reset 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | ID | | A A A A A A A A A A A A A A A A A A A | | | Bit number | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | #### 6.16.5.33 TXD.LIST Address offset: 0x550 EasyDMA list type | Bit number | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|------------------------|------------------------------------------------------------------| | ID | | A A | | Reset 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A RW LIST | | List type | | Disabled | 0 | Disable EasyDMA list | | ArrayList | 1 | Use array list | #### 6.16.5.34 CONFIG Address offset: 0x554 Configuration register | Bit n | umber | | 31 30 29 2 | 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|------------|------------|------------------------------------------------------------------------------| | ID | | | | СВА | | Rese | t 0x00000000 | | 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW ORDER | | | Bit order | | | | MsbFirst | 0 | Most significant bit shifted out first | | | | LsbFirst | 1 | Least significant bit shifted out first | | В | RW CPHA | | | Serial clock (SCK) phase | | | | Leading | 0 | Sample on leading edge of clock, shift serial data on trailing | | | | | | edge | | | | Trailing | 1 | Sample on trailing edge of clock, shift serial data on leading | | | | | | edge | | С | RW CPOL | | | Serial clock (SCK) polarity | | | | ActiveHigh | 0 | Active high | | | | ActiveLow | 1 | Active low | # 6.16.5.35 DEF Address offset: 0x55C Default character. Character clocked out in case of an ignored transaction. | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|---------------------------------------------------------------------------------------| | ID | | A A A A A A A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | | | A RW DEF | | Default character. Character clocked out in case of an | | | | ignored transaction. | #### 6.16.5.36 ORC Address offset: 0x5C0 Over-read character | A RW ORC | | Over-read character. Character clocked out after an over- | |------------------|----------------------|------------------------------------------------------------------| | ID Acce Field | | Description | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | A A A A A A A | | Bit number | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | Over-read character. Character clocked out after an overread of the transmit buffer. # 6.16.6 Electrical specification # 6.16.6.1 SPIS slave interface electrical specifications | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|---------------------------------------------------------|------|------|-----------------|-------| | f <sub>SPIS</sub> | Bit rates for SPIS <sup>26</sup> | | | 8 <sup>27</sup> | Mbps | | t <sub>SPIS,START</sub> | Time from RELEASE task to receive/transmit (CSN active) | | | | μs | # 6.16.6.2 Serial Peripheral Interface Slave (SPIS) timing specifications | Symbol | Description | Min. | Тур. | Max. | Units | |---------------------------|-----------------------------------|------------------|------|------|-------| | t <sub>SPIS,CSCKIN</sub> | SCK input period | | | | ns | | t <sub>SPIS,RFSCKIN</sub> | SCK input rise/fall time | | | 30 | ns | | t <sub>SPIS,WHSCKIN</sub> | SCK input high time | 30 | | | ns | | t <sub>SPIS,WLSCKIN</sub> | SCK input low time | 30 | | | ns | | t <sub>SPIS,SUCSN</sub> | CSN to CLK setup time | | | | ns | | t <sub>SPIS,HCSN</sub> | CLK to CSN hold time | 2000 | | | ns | | t <sub>SPIS,ASA</sub> | CSN to MISO driven | | | | ns | | t <sub>SPIS,ASO</sub> | CSN to MISO valid <sup>a</sup> | | | 1000 | ns | | t <sub>SPIS,DISSO</sub> | CSN to MISO disabled <sup>a</sup> | | | 68 | ns | | t <sub>SPIS,CWH</sub> | CSN inactive time | 300 | | | ns | | t <sub>SPIS,VSO</sub> | CLK edge to MISO valid | | | 19 | ns | | t <sub>SPIS,HSO</sub> | MISO hold time after CLK edge | 18 <sup>28</sup> | | | ns | | t <sub>SPIS,SUSI</sub> | MOSI to CLK edge setup time | 59 | | | ns | | t <sub>SPIS,HSI</sub> | CLK edge to MOSI hold time | 20 | | | ns | High bit rates may require GPIOs to be set as High Drive, see GPIO chapter for more details. The actual maximum data rate depends on the master's CLK to MISO and MOSI setup and hold timings <sup>&</sup>lt;sup>a</sup> At 25pF load, including GPIO capacitance, see GPIO spec. <sup>&</sup>lt;sup>28</sup> This is to ensure compatibility to SPI masters sampling MISO on the same edge as MOSI is output Figure 85: SPIS timing diagram Figure 86: Common SPIM and SPIS timing diagram # 6.17 SWI — Software interrupts A set of interrupts have been reserved for use as software interrupts. ### 6.17.1 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|----------------------|---------------|--| | 0x40014000 | SWI | SWI0 | Software interrupt 0 | | | | 0x40015000 | SWI | SWI1 | Software interrupt 1 | | | | 0x40016000 | SWI | SWI2 | Software interrupt 2 | | | | 0x40017000 | SWI | SWI3 | Software interrupt 3 | | | | 0x40018000 | SWI | SWI4 | Software interrupt 4 | | | | 0x40019000 | SWI | SWI5 | Software interrupt 5 | | | Table 75: Instances # 6.18 TEMP — Temperature sensor The temperature sensor measures die temperature over the temperature range of the device. Linearity compensation can be implemented if required by the application. Listed here are the main features for TEMP: - Temperature range is greater than or equal to operating temperature of the device - Resolution is 0.25 degrees TEMP is started by triggering the START task. When the temperature measurement is completed, a DATARDY event will be generated and the result of the measurement can be read from the TEMP register. To achieve the measurement accuracy stated in the electrical specification, the crystal oscillator must be selected as the HFCLK source, see CLOCK — Clock control on page 60 for more information. When the temperature measurement is completed, TEMP analog electronics power down to save power. TEMP only supports one-shot operation, meaning that every TEMP measurement has to be explicitly started using the START task. # 6.18.1 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|--------------------|---------------| | 0x4000C000 | TEMP | TEMP | Temperature sensor | | Table 76: Instances | Register | Offset | Description | |----------------|--------|----------------------------------------------| | TASKS_START | 0x000 | Start temperature measurement | | TASKS_STOP | 0x004 | Stop temperature measurement | | EVENTS_DATARDY | 0x100 | Temperature measurement complete, data ready | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | TEMP | 0x508 | Temperature in °C (0.25° steps) | | A0 | 0x520 | Slope of 1st piece wise linear function | | Register | Offset | Description | |----------|--------|-----------------------------------------------| | A1 | 0x524 | Slope of 2nd piece wise linear function | | A2 | 0x528 | Slope of 3rd piece wise linear function | | A3 | 0x52C | Slope of 4th piece wise linear function | | A4 | 0x530 | Slope of 5th piece wise linear function | | A5 | 0x534 | Slope of 6th piece wise linear function | | во | 0x540 | y-intercept of 1st piece wise linear function | | B1 | 0x544 | y-intercept of 2nd piece wise linear function | | B2 | 0x548 | y-intercept of 3rd piece wise linear function | | В3 | 0x54C | y-intercept of 4th piece wise linear function | | B4 | 0x550 | y-intercept of 5th piece wise linear function | | B5 | 0x554 | y-intercept of 6th piece wise linear function | | то | 0x560 | End point of 1st piece wise linear function | | T1 | 0x564 | End point of 2nd piece wise linear function | | T2 | 0x568 | End point of 3rd piece wise linear function | | Т3 | 0x56C | End point of 4th piece wise linear function | | T4 | 0x570 | End point of 5th piece wise linear function | Table 77: Register overviev # 6.18.1.1 TASKS\_START Address offset: 0x000 Start temperature measurement # 6.18.1.2 TASKS STOP Address offset: 0x004 Stop temperature measurement | Bit number | | | Trigger | 1 | | Trigger ta | sk | | | | | | | | | | | | | | |--------------------------------------------------------------------------------------------------------|--------|--------------|---------|---------------|------------|-------------|---------|-------|-------|------|-------|--------|------|---|---|-----|-----|---|-----|-----| | Reset 0x000000000 0 0 0 0 0 0 0 0 0 0 0 0 0 | Α | W TASKS_STOP | | | | Stop tem | peratu | re me | easur | emei | nt | | | | | | | | | | | ID A | ID | | | | | Description | | | | | | | | | | | | | | | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 ID A | Reset | 0x00000000 | | 0 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 | 0 | 0 ( | 0 ( | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | ID | | | | | | | | | | | | | | | | | | | Α | | | Bit nu | ımber | | 31 30 29 28 2 | 7 26 25 24 | 23 22 21 | 20 19 1 | 18 17 | 16 1 | 5 14 | 13 12 | 2 11 : | 10 9 | 8 | 7 | 6 5 | 5 4 | 3 | 2 1 | L 0 | # 6.18.1.3 EVENTS\_DATARDY Address offset: 0x100 Temperature measurement complete, data ready | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | | A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW EVENTS_DATARDY | | | Temperature measurement complete, data ready | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | #### 6.18.1.4 INTENSET Address offset: 0x304 Enable interrupt | Bit number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|---------------------------------------------------------------------------------------| | ID | A | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | Value Description | | A RW DATARDY | Write '1' to enable interrupt for event DATARDY | | Set | 1 Enable | | Disabled | 0 Read: Disabled | | Enabled | 1 Read: Enabled | #### 6.18.1.5 INTENCLR Address offset: 0x308 Disable interrupt #### 6.18.1.6 TEMP Address offset: 0x508 Temperature in °C (0.25° steps) | Bit n | umbe | er | 31 | 30 | 29 2 | 8 2 | 7 26 | 25 | 24 | 23 | 22 | 21 | 20 1 | 19 1 | 3 17 | <sup>7</sup> 16 | 15 | 14 | 13 | 12 | 11 : | 10 9 | 9 8 | 7 | 6 | 5 | 4 | 3 2 | 2 1 | 0 | |-------|-------|---------|----|----|------|-----|------|----|----|-----|------|-------|------|-------|------|-----------------|-------|-----|------|-----|------|------|-----|------|-----|------|-----|-----|-----|---| | ID | | | А | Α | A A | , Δ | A | Α | Α | Α | Α | Α | Α. | A A | . A | Α | Α | Α | Α | Α | Α | A | 4 Δ | A | Α | Α | Α | A A | 4 A | Α | | Rese | t 0x0 | 0000000 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | R | TEMP | | | | | | | | Ter | np | erat | ure | in ° | C (0 | .25 | ° st | eps | ) | | | | | | | | | | | | | | | | | | | | | | | Re | sult | t of | tem | per | atuı | re n | nea | sur | em | ent | . Di | e te | mp | erat | ure | in ' | °C, | | | | | | | | | | | | | | | 2's | со | mpl | em | ent | forn | nat, | , 0.2 | 25° | C st | tep | s | | | | | | | | | | | | | | | | | | | | | De | rici | ion i | noir | nt: D | ΔΤΔ | BD. | v | | | | | | | | | | | | | | #### 6.18.1.7 A0 Address offset: 0x520 Slope of 1st piece wise linear function #### 6.18.1.8 A1 Address offset: 0x524 Slope of 2nd piece wise linear function #### 6.18.1.9 A2 Address offset: 0x528 Slope of 3rd piece wise linear function #### 6.18.1.10 A3 Address offset: 0x52C Slope of 4th piece wise linear function | Bit n | umber | 31 30 2 | 29 28 | 8 27 | 26 2 | 5 24 | 23 2 | 22 2 | 1 20 | 19 | 18 | 17 10 | 5 15 | 14 : | 3 12 | 2 11 | 10 | 9 | 8 | 7 | 6 5 | 5 4 | 3 | 2 | 1 | 0 | |-------|--------------|---------|-------|------|------|------|------|------|-------|------|-----|-------|------|------|------|------|----|---|---|---|-----|-----|---|---|---|---| | ID | | | | | | | | | | | | | | | | Α | Α | Α | A | Д | A A | λ Α | A | Α | Α | Α | | Rese | t 0x0000040E | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 1 | 0 | 0 | 0 | 0 ( | ) ( | 1 | 1 | 1 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW A3 | | | | | | Slop | pe c | of 4t | h pi | ece | wise | line | ar f | ınct | ion | | | | | | | | | | _ | 6.18.1.11 A4 Address offset: 0x530 Slope of 5th piece wise linear function NORDIC Slope of 5th piece wise linear function #### 6.18.1.12 A5 Address offset: 0x534 Slope of 6th piece wise linear function | ID | | A A A A A A A A A A A A A A A A A A A | |------------------|-------------|---------------------------------------------------| | Reset 0x000005A3 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1 0 1 0 0 0 1 1 | | ID Acce Field | | Description | | A RW A5 | | Slope of 6th piece wise linear function | #### 6.18.1.13 BO Address offset: 0x540 y-intercept of 1st piece wise linear function #### 6.18.1.14 B1 Address offset: 0x544 y-intercept of 2nd piece wise linear function | Α | RW B1 | | | y-intercept of 2n | nd piece wis | e line | ear fu | ınctic | n | | | | | | | |--------|------------|----------|------------------------|--------------------|--------------|--------|--------|--------|-----|------------|---|---|-----|---|-----| | ID | | Value ID | | | | | | | | | | | | | | | Reset | 0x00003FBE | | 0 0 0 0 0 0 0 | 0 0 0 0 0 | 0 0 0 | 0 1 | 1 | 1 1 | 1 1 | l <b>1</b> | 0 | 1 | 1 1 | 1 | 1 0 | | ID | | | _ | | | А | Α . | А А | A A | A A | Α | Α | A A | A | A A | | Bit nu | mber | | 31 30 29 28 27 26 25 2 | 1 23 22 21 20 19 1 | .8 17 16 15 | 14 13 | 12 1 | 11 10 | 9 8 | 3 7 | 6 | 5 | 4 3 | 2 | 1 0 | #### 6.18.1.15 B2 Address offset: 0x548 y-intercept of 3rd piece wise linear function | | RW B2 | | | | | | | | | 3rd | | | | | - | | | | | | | | | | | |-------|---------------|-------|---------|-------|------|-------|------|----|------|------|------|------|------|----|------|-------|---|---|---|-----|-----|---|---|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | Rese | et 0x00003FBE | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 | 0 | 0 ( | 0 | 1 | 1 | 1 1 | 1 | 1 | 1 | 0 : | L 1 | 1 | 1 | 1 | 0 | | ID | | | | | | | | | | | | | | Α | A | 4 A | Α | Α | Α | A A | A A | Α | Α | Α | Α | | Bit n | umber | 31 30 | 29 28 : | 27 26 | 25 2 | 24 23 | 3 22 | 21 | 20 1 | 9 18 | 17 : | 16 1 | 5 14 | 13 | 12 1 | .1 10 | 9 | 8 | 7 | 6 5 | 5 4 | 3 | 2 | 1 | 0 | #### 6.18.1.16 B3 Address offset: 0x54C y-intercept of 4th piece wise linear function #### 6.18.1.17 B4 Address offset: 0x550 y-intercept of 5th piece wise linear function | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 ID Acce Field Value ID Value Description | | | | | | | | > | | У | -int | erc | ept ( | of 5 | 5th p | oiec | e w | ise | line | ar f | unc | tio | n | | | | | | | | | |----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|------|------|------|------|----|----|------|------|------|-------|------|-------|------|-----|------|------|------|-----|-----|---|---|---|-----|-----|---|---|---|---| | ID A A A A A A A A A A A A A A A A A A A | | | | | | | | | | 1 | esc | ript | | | | | | | | | 7 | | | | , | | | | | | | | | | | | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 1 | L 0 | 0 | 1 | 0 | 0 | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | | | | | | | | | | | | | | | | | | | A | Α | Α | Α | Α | A | A | A A | A A | Α | Α | Α | Α | | | | | | 31 3 | 30 2 | 9 28 | 3 27 | 26 | 25 | 24 2 | 3 2 | 2 2: | 1 20 | 19 | 18 | 17 1 | 6 1 | 5 14 | 113 | 12 | 11 | 10 | 9 | 8 | 7 | 6 5 | 5 4 | 3 | 2 | 1 | 0 | #### 6.18.1.18 B5 Address offset: 0x554 y-intercept of 6th piece wise linear function #### 6.18.1.19 TO Address offset: 0x560 End point of 1st piece wise linear function | Bit no | ımber | 31 30 | 29 28 | 27 | 26 25 | 5 24 | 23 2 | 2 2 | 1 20 | 19 1 | .8 17 | 16 | 15 1 | 14 1 | 3 12 | 11 1 | 0 9 | 8 | 7 | 6 | 5 - | 4 3 | 2 | 1 0 | |--------|--------------|-------|-------|----|-------|------|------|-----|-------|-------|-------|-----|-------|------|-------|------|-----|---|---|---|-----|-----|---|-----| | ID | | | | | | | | | | | | | | | | | | | Α | Α | A | A A | A | A A | | Rese | t 0x000000E2 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 ( | 0 | 0 | 1 | 1 | 1 | 0 0 | 0 | 1 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW TO | | | | | | End | poi | nt of | f 1st | piec | e w | ise I | inea | r fur | ctio | n | | | | | | | | #### 6.18.1.20 T1 Address offset: 0x564 End point of 2nd piece wise linear function | Bit number | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 | 17 16 15 | 14 13 | 12 11 | 10 9 | 8 7 | 7 6 | 5 | 4 | 3 2 | 1 | 0 | |------------------|----------------------|----------------------|----------|-------|-------|------|-----|-----|---|---|-----|-----|---| | ID | | | | | | | A | A | A | Α | A A | A A | Α | | Reset 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | | ID Acce Field | | | | | | | | | | | | | | A RW T1 End point of 2nd piece wise linear function #### 6.18.1.21 T2 Address offset: 0x568 End point of 3rd piece wise linear function | A F | RW T2 | End point of 3rd piece wise linear function | | | |---------|------------|-------------------------------------------------------------------------|-------|---------| | ID A | | Value Description | | | | Reset 0 | 0x00000019 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 1 | 1 0 0 1 | | ID | | A | A A A | AAAA | | Bit num | nber | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 | 6 5 4 | 3 2 1 0 | #### 6.18.1.22 T3 Address offset: 0x56C End point of 4th piece wise linear function #### 6.18.1.23 T4 Address offset: 0x570 End point of 5th piece wise linear function | Bit number 31.30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ID Reset 0x00000050 Value Description | A D\A/ T4 | | End point of Eth piece wise linear function | | |-------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------|-------------------------------------------------------------------------------------|-----| | ID A A A A A A A | ID Acce Field | Value ID | | | | | Reset 0x00000050 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 | | Bit number 31.30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | ID | | A A A A A | 4 А | | | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 1 0 | # 6.18.2 Electrical specification # 6.18.2.1 Temperature Sensor Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|-----------------------------------------------------------|------|---------|------|-------| | t <sub>TEMP</sub> | Time required for temperature measurement | | 36 | | μs | | T <sub>TEMP,RANGE</sub> | Temperature sensor range | -40 | | 85 | °C | | T <sub>TEMP,ACC</sub> | Temperature sensor accuracy | -5 | | 5 | °C | | T <sub>TEMP,RES</sub> | Temperature sensor resolution | | 0.25 | | °C | | T <sub>TEMP,STB</sub> | Sample to sample stability at constant device temperature | | +/-0.25 | | °C | | T <sub>TEMP,OFFST</sub> | Sample offset at 25°C | -2.5 | | 2.5 | °C | # $6.19 \text{ TWI} - I^2 \text{C compatible two-wire interface}$ The TWI master is compatible with I<sup>2</sup>C operating at 100 kHz and 400 kHz. Figure 87: TWI master's main features # 6.19.1 Functional description This TWI master is not compatible with CBUS. The TWI transmitter and receiver are single buffered. See, TWI master's main features on page 242. A TWI setup comprising one master and three slaves is illustrated in A typical TWI setup comprising one master and three slaves on page 242. This TWI master is only able to operate as the only master on the TWI bus. Figure 88: A typical TWI setup comprising one master and three slaves This TWI master supports clock stretching performed by the slaves. The TWI master is started by triggering the STARTTX or STARTRX tasks, and stopped by triggering the STOP task. If a NACK is clocked in from the slave, the TWI master will generate an ERROR event. # 6.19.2 Master mode pin configuration The different signals SCL and SDA associated with the TWI master are mapped to physical pins according to the configuration specified in the PSEL.SCL and PSEL.SDA registers respectively. If the CONNECT field of a PSEL.xxx register is set to Disconnected, the associated TWI signal is not connected to any physical pin. The PSEL.SCL and PSEL.SDA registers and their configurations are only used as long as the TWI master is enabled, and retained only as long as the device is in ON mode. PSEL.SCL and PSEL.SDA must only be configured when the TWI is disabled. To secure correct signal levels on the pins used by the TWI master when the system is in OFF mode, and when the TWI master is disabled, these pins must be configured in the GPIO peripheral as described in GPIO configuration on page 243. Only one peripheral can be assigned to drive a particular GPIO pin at a time, failing to do so may result in unpredictable behavior. | TWI master signal | TWI master pin | Direction | Drive strength | Output value | |-------------------|--------------------------|-----------|----------------|----------------| | SCL | As specified in PSEL.SCL | Input | SOD1 | Not applicable | | SDA | As specified in PSEL.SDA | Input | SOD1 | Not applicable | Table 78: GPIO configuration #### 6.19.3 Shared resources The TWI shares registers and other resources with other peripherals that have the same ID as the TWI. Therefore, you must disable all peripherals that have the same ID as the TWI before the TWI can be configured and used. Disabling a peripheral that has the same ID as the TWI will not reset any of the registers that are shared with the TWI. It is therefore important to configure all relevant TWI registers explicitly to secure that it operates correctly. The Instantiation table in Instantiation on page 17 shows which peripherals have the same ID as the TWI. # 6.19.4 Master write sequence A TWI master write sequence is started by triggering the STARTTX task. After the STARTTX task has been triggered, the TWI master will generate a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 0 (WRITE=0, READ=1). The address must match the address of the slave device that the master wants to write to. The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK=1) generated by the slave. After receiving the ACK bit, the TWI master will clock out the data bytes that are written to the TXD register. Each byte clocked out from the master will be followed by an ACK/NACK bit clocked in from the slave. A TXDSENT event will be generated each time the TWI master has clocked out a TXD byte, and the associated ACK/NACK bit has been clocked in from the slave. The TWI master transmitter is single buffered, and a second byte can only be written to the TXD register after the previous byte has been clocked out and the ACK/NACK bit clocked in, that is, after the TXDSENT event has been generated. If the CPU is prevented from writing to TXD when the TWI master is ready to clock out a byte, the TWI master will stretch the clock until the CPU has written a byte to the TXD register. A typical TWI master write sequence is illustrated in The TWI master writing data to a slave on page 244. Occurrence 3 in the figure illustrates delayed processing of the TXDSENT event associated with TXD byte 1. In this scenario the TWI master will stretch the clock to prevent writing erroneous data to the slave. Figure 89: The TWI master writing data to a slave The TWI master write sequence is stopped when the STOP task is triggered whereupon the TWI master will generate a stop condition on the TWI bus. #### 6.19.5 Master read sequence A TWI master read sequence is started by triggering the STARTRX task. After the STARTRX task has been triggered the TWI master will generate a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 1 (WRITE = 0, READ = 1). The address must match the address of the slave device that the master wants to read from. The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK = 1) generated by the slave. After having sent the ACK bit the TWI slave will send data to the master using the clock generated by the master. The TWI master will generate a RXDRDY event every time a new byte is received in the RXD register. After receiving a byte, the TWI master will delay sending the ACK/NACK bit by stretching the clock until the CPU has extracted the received byte, that is, by reading the RXD register. The TWI master read sequence is stopped by triggering the STOP task. This task must be triggered before the last byte is extracted from RXD to ensure that the TWI master sends a NACK back to the slave before generating the stop condition. A typical TWI master read sequence is illustrated in The TWI master reading data from a slave on page 245. Occurrence 3 in this figure illustrates delayed processing of the RXDRDY event associated with RXD byte B. In this scenario the TWI master will stretch the clock to prevent the slave from overwriting the contents of the RXD register. Figure 90: The TWI master reading data from a slave # 6.19.6 Master repeated start sequence A typical repeated start sequence is one in which the TWI master writes one byte to the slave followed by reading M bytes from the slave. Any combination and number of transmit and receive sequences can be combined in this fashion. Only one shortcut to STOP can be enabled at any given time. The figure below illustrates a repeated start sequence where the TWI master writes one byte, followed by reading M bytes from the slave without performing a stop in-between. Figure 91: A repeated start sequence, where the TWI master writes one byte, followed by reading M bytes from the slave without performing a stop in-between To generate a repeated start after a read sequence, a second start task must be triggered instead of the STOP task, that is, STARTRX or STARTTX. This start task must be triggered before the last byte is extracted from RXD to ensure that the TWI master sends a NACK back to the slave before generating the repeated start condition. #### 6.19.7 Low power When putting the system in low power and the peripheral is not needed, lowest possible power consumption is achieved by stopping, and then disabling the peripheral. The STOP task may not be always needed (the peripheral might already be stopped), but if it is sent, software shall wait until the STOPPED event was received as a response before disabling the peripheral through the ENABLE register. # 6.19.8 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|---------------------------|---------------|------------| | 0x40003000 | TWI | TWI0 | Two-wire interface master | O' | Deprecated | Table 79: Instances | Register | Offset | Description | |------------------|--------|------------------------------------------------------------------------| | TASKS_STARTRX | 0x000 | Start TWI receive sequence | | TASKS_STARTTX | 0x008 | Start TWI transmit sequence | | TASKS_STOP | 0x014 | Stop TWI transaction | | TASKS_SUSPEND | 0x01C | Suspend TWI transaction | | TASKS_RESUME | 0x020 | Resume TWI transaction | | EVENTS_STOPPED | 0x104 | TWI stopped | | EVENTS_RXDREADY | 0x108 | TWI RXD byte received | | EVENTS_TXDSENT | 0x11C | TWI TXD byte sent | | EVENTS_ERROR | 0x124 | TWI error | | EVENTS_BB | 0x138 | TWI byte boundary, generated before each byte that is sent or received | | EVENTS_SUSPENDED | 0x148 | TWI entered the suspended state | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | ERRORSRC | 0x4C4 | Error source | | ENABLE | 0x500 | Enable TWI | | PSEL.SCL | 0x508 | Pin select for SCL | | PSEL.SDA | 0x50C | Pin select for SDA | | RXD | 0x518 | RXD register | | TXD | 0x51C | TXD register | | FREQUENCY | 0x524 | TWI frequency. Accuracy depends on the HFCLK source selected. | | ADDRESS | 0x588 | Address used in the TWI transfer | | | | | Table 80: Register overview #### 6.19.8.1 TASKS\_STARTRX Address offset: 0x000 Start TWI receive sequence | Bit n | um | nber | r | | 313 | 30 2 | 9 28 | 3 27 | 7 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|------|------|---------------|---------|-----|------|------|------|------|----|----|------|------|------|-------|-----|------|----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | А | | Rese | et O | )x00 | 000000 | | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | ٧ | Ν | TASKS_STARTRX | | | | | | | | | Sta | rt 1 | ΓW | 'I re | cei | ve s | eq | uen | ice | | | | | | | | | | | | | | | | | | | | Trigger | 1 | | | | | | | Trig | gge | r ta | ask | | | | | | | | | | | | | | | | | | | | #### 6.19.8.2 TASKS\_STARTTX Address offset: 0x008 Start TWI transmit sequence | Bit r | number | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|---------|----------------|------------------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_STARTTX | | | Start TWI transmit sequence | | | | Trigger | 1 | Trigger task | # 6.19.8.3 TASKS\_STOP Address offset: 0x014 Stop TWI transaction # 6.19.8.4 TASKS\_SUSPEND Address offset: 0x01C Suspend TWI transaction | | | Trigger | 1 | | Trigger | task | | | | | | | | | | | | | | |-------|-----------------|---------|---------------|------------|---------|----------|--------|-------|--------|--------|-------|---|-----|---|---|---|-----|-----|---| | Α | W TASKS_SUSPEND | | | | Suspen | d TWI tı | ransac | tion | | | | | | | | | | | | | ID | | | | | | | | | | | | | | | | | | | | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 ( | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | Α | | Bit n | umber | | 31 30 29 28 2 | 7 26 25 24 | 23 22 2 | 1 20 19 | 18 17 | 16 19 | 5 14 1 | 3 12 1 | 11 10 | 9 | 8 7 | 6 | 5 | 4 | 3 2 | 2 1 | 0 | | | | | | | | | | | | | | | | | | | | | | # 6.19.8.5 TASKS\_RESUME Address offset: 0x020 Resume TWI transaction | Bit number | | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|---------|------------------|------------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID Acce Field | | | Description | | A W TASKS_RESU | JME | | Resume TWI transaction | | | Trigger | 1 | Trigger task | #### 6.19.8.6 EVENTS\_STOPPED Address offset: 0x104 TWI stopped | Bit r | number | | 31 3 | 0 29 | 28 | 27 2 | 6 2! | 5 24 | 1 23 | 3 22 | 2 2 1 | 1 20 | 0 1 | 9 1 | 3 17 | 16 | 5 15 | 5 14 | 13 | 12 | 11 | 10 | 9 8 | 3 7 | 7 6 | 5 5 | 4 | 3 | 2 | 1 0 | |-------|-------------------|--------------|------|------|----|------|------|------|------|------|-------|------|-----|------|------|----|------|------|----|----|----|----|-----|-----|-----|-----|---|---|---|-----| | ID | | | | | | | | | | | | | | | 7 | | | | | | | | | | | | | | | Α | | Rese | et 0x00000000 | | 0 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | | | | | | esci | ript | ior | | | | | | | | | | | | | | | | | | | | Α | RW EVENTS_STOPPED | | | | | | | | T۱ | NI s | sto | рре | ed | | | 7 | | | | | | | | | | | | | | | | | | NotGenerated | 0 | | | | | | E۷ | ent | t no | ot g | ger | iera | ted | | | | | | | | | | | | | | | | | | | Generated | 1 | | | | | | Ev | /ent | t ge | ene | rat | ted | | | | | | | | | | | | | | | | | # 6.19.8.7 EVENTS\_RXDREADY Address offset: 0x108 TWI RXD byte received #### 6.19.8.8 EVENTS TXDSENT Address offset: 0x11C TWI TXD byte sent | Bit n | umber | | 31 | 30 | 29 | 28 | 27 | 26 2 | 25 | 24 | 23 | 22 | 21 2 | 20 | 19 | 18 1 | 17 1 | 6 1 | .5 1 | 4 1 | 3 1: | 2 11 | . 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|-------------------|--------------|----|----|----|----|----|------|----|----|-----|------|------|-----|------|------|------|-----|------|-----|------|------|------|---|---|---|---|---|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | et 0x00000000 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | | ID | | | | | | | | | | | De: | | | | | | | | | | | | | | | | | | | | | | | Α | RW EVENTS_TXDSENT | | | | | | | | | | TW | /I T | XD I | oyt | e se | ent | | | | | | | | | | | | | | | | | | | | NotGenerated | 0 | | | | | | | | Eve | ent | not | ge | ner | ate | d | | | | | | | | | | | | | | | | | | | Generated | 1 | | | | | | | | Eve | ent | gen | era | ate | t | | | | | | | | | | | | | | | | | # 6.19.8.9 EVENTS\_ERROR Address offset: 0x124 TWI error # 6.19.8.10 EVENTS\_BB Address offset: 0x138 TWI byte boundary, generated before each byte that is sent or received #### 6.19.8.11 EVENTS SUSPENDED Address offset: 0x148 TWI entered the suspended state Generated just after ACK bit has been transferred in a read transaction, and only if SUSPEND has been requested earlier. #### 6.19.8.12 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | В А | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW BB_SUSPEND | | | Shortcut between event BB and task SUSPEND | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | В | RW BB_STOP | | | Shortcut between event BB and task STOP | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | # 6.19.8.13 INTENSET Address offset: 0x304 Enable interrupt | | | | | * · · · · · · · · · · · · · · · · · · · | |-------|---------------|----------|------------------------|------------------------------------------------------------------| | Bit n | umber | | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | ID | | | | F E D C B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | Value | Description | | Α | RW STOPPED | | | Write '1' to enable interrupt for event STOPPED | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW RXDREADY | | | Write '1' to enable interrupt for event RXDREADY | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW TXDSENT | | | Write '1' to enable interrupt for event TXDSENT | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW ERROR | | | Write '1' to enable interrupt for event ERROR | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | E | RW BB | | | Write '1' to enable interrupt for event BB | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | F | RW SUSPENDED | | | Write '1' to enable interrupt for event SUSPENDED | | | | | | Generated just after ACK bit has been transferred in a | | | | | | read transaction, and only if SUSPEND has been requested | | | | | | earlier. | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | # 6.19.8.14 INTENCLR Address offset: 0x308 Disable interrupt | Bit r | umber | | 31 30 29 28 2 | 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|---------------|------------|------------------------------------------------------------------| | ID | | | | | F E D C B A | | Rese | et 0x00000000 | | 0 0 0 0 | 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | A | RW STOPPED | | | | Write '1' to disable interrupt for event STOPPED | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | В | RW RXDREADY | | | | Write '1' to disable interrupt for event RXDREADY | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | С | RW TXDSENT | | | | Write '1' to disable interrupt for event TXDSENT | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | D | RW ERROR | | | | Write '1' to disable interrupt for event ERROR | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | E | RW BB | | | | Write '1' to disable interrupt for event BB | | | | Clear | 1 | | Disable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | F | RW SUSPENDED | | | | Write '1' to disable interrupt for event SUSPENDED | | | | | | | Generated just after ACK bit has been transferred in a | | | | X | | | read transaction, and only if SUSPEND has been requested | | | | | | | earlier. | | | | Clear | 1 | | Disable | | | | Disabled | 0 | 1 | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | | | | | | · · | # 6.19.8.15 ERRORSRC Address offset: 0x4C4 Error source | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|------------|-------------------------|-----------------------------------------------------------------| | ID | | | | СВА | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW OVERRUN | | | Overrun error | | | | | | A new byte was received before previous byte got read by | | | | | | software from the RXD register. (Previous data is lost) | | | | NotPresent | 0 | Read: no overrun occured | | | | Present | 1 | Read: overrun occured | | В | RW ANACK | | | NACK received after sending the address (write '1' to clear) | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | С | RW DNACK | | | NACK received after sending a data byte (write '1' to clear) | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | #### 6.19.8.16 ENABLE Address offset: 0x500 **Enable TWI** | Bit number | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|-------------------|---------------------------------------------------------------------| | ID | | | ААА | | Reset 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW ENABLE | | | Enable or disable TWI | | | Disabled | 0 | Disable TWI | | | Enabled | 5 | Enable TWI | #### 6.19.8.17 PSEL.SCL Address offset: 0x508 Pin select for SCL #### 6.19.8.18 PSEL.SDA Address offset: 0x50C Pin select for SDA #### 6.19.8.19 RXD Address offset: 0x518 **RXD** register #### 6.19.8.20 TXD Address offset: 0x51C TXD register #### 6.19.8.21 FREQUENCY Address offset: 0x524 TWI frequency. Accuracy depends on the HFCLK source selected. #### 6.19.8.22 ADDRESS Address offset: 0x588 Address used in the TWI transfer # 6.19.9 Electrical specification ## 6.19.9.1 TWI interface electrical specifications | Symbol | Description | Min. | Тур. | Max. | Units | |------------------------|--------------------------------------------------------|------|------|------|-------| | $f_{TWI,SCL}$ | Bit rates for TWI <sup>29</sup> | 100 | | 400 | kbps | | t <sub>TWI,START</sub> | Time from STARTRX/STARTTX task to transmission started | | 1.5 | | μs | <sup>&</sup>lt;sup>29</sup> High bit rates or stronger pull-ups may require GPIOs to be set as High Drive, see GPIO chapter for more details. # 6.19.9.2 Two Wire Interface (TWI) timing specifications | Symbol | Description | Min. | Тур. | Max. | Units | |------------------------------------------------|------------------------------------------------------------|--------------------|------|------|-------| | t <sub>TWI,SU_DAT</sub> | Data setup time before positive edge on SCL – all modes | 300 | | | ns | | t <sub>TWI,HD_DAT</sub> | Data hold time after negative edge on SCL – all modes | 500 | | | ns | | $t_{\text{TWI},\text{HD\_STA},100\text{kbps}}$ | TWI master hold time for START and repeated START | 10000 | | | ns | | | condition, 100 kbps | | | | | | t <sub>TWI,HD_STA,250kbps</sub> | TWI master hold time for START and repeated START | 4000 | | | ns | | | condition, 250kbps | | | | | | $t_{TWI,HD\_STA,400kbps}$ | TWI master hold time for START and repeated START | 2500 | | | ns | | | condition, 400 kbps | | | | | | t <sub>TWI,SU_STO,100kbps</sub> | TWI master setup time from SCL high to STOP condition, 100 | 5000 | | | ns | | | kbps | | | | | | t <sub>TWI,SU_STO,250kbps</sub> | TWI master setup time from SCL high to STOP condition, 250 | 2000 | | | ns | | | kbps | | | | | | t <sub>TWI,SU_STO,400kbps</sub> | TWI master setup time from SCL high to STOP condition, 400 | 1250 | | | ns | | | kbps | | | | | | t <sub>TWI,BUF,100kbps</sub> | TWI master bus free time between STOP and START | 5800 | | | ns | | | conditions, 100 kbps | | | | | | t <sub>TWI,BUF,250kbps</sub> | TWI master bus free time between STOP and START | 2700 | | | ns | | | conditions, 250 kbps | _ | | | | | t <sub>TWI,BUF,400kbps</sub> | TWI master bus free time between STOP and START | 2100 | | | ns | | | conditions, 400 kbps | | | | | | | | | | | | | | Aug. | | | | | | | 1/fscL | | | | | | SCL | | | _/ | | | | | t <sub>su_dat</sub> | t <sub>su_s1</sub> | 0 | l. | | Figure 92: TWI timing diagram, 1 byte transaction t<sub>HD\_DAT</sub> # 6.20 TIMER — Timer/counter SDA The TIMER can operate in two modes: timer and counter. ← t<sub>BUF</sub> → Figure 93: Block schematic for timer/counter The timer/counter runs on the high-frequency clock source (HFCLK) and includes a four-bit (1/2X) prescaler that can divide the timer input clock from the HFCLK controller. Clock source selection between PCLK16M and PCLK1M is automatic according to TIMER base frequency set by the prescaler. The TIMER base frequency is always given as 16 MHz divided by the prescaler value. The PPI system allows a TIMER event to trigger a task of any other system peripheral of the device. The PPI system also enables the TIMER task/event features to generate periodic output and PWM signals to any GPIO. The number of input/outputs used at the same time is limited by the number of GPIOTE channels. The TIMER can operate in two modes, Timer mode and Counter mode. In both modes, the TIMER is started by triggering the START task, and stopped by triggering the STOP task. After the timer is stopped the timer can resume timing/counting by triggering the START task again. When timing/counting is resumed, the timer will continue from the value it had prior to being stopped. In Timer mode, the TIMER's internal Counter register is incremented by one for every tick of the timer frequency $f_{\text{TIMER}}$ as illustrated in Block schematic for timer/counter on page 255. The timer frequency is derived from PCLK16M as shown below, using the values specified in the PRESCALER register: ``` f<sub>TIMER</sub> = 16 MHz / (2<sup>PRESCALER</sup>) ``` When $f_{TIMER} \ll 1$ MHz the TIMER will use PCLK1M instead of PCLK16M for reduced power consumption. In counter mode, the TIMER's internal Counter register is incremented by one each time the COUNT task is triggered, that is, the timer frequency and the prescaler are not utilized in counter mode. Similarly, the COUNT task has no effect in Timer mode. The TIMER's maximum value is configured by changing the bit-width of the timer in the BITMODE on page 260 register. PRESCALER on page 260 and the BITMODE on page 260 must only be updated when the timer is stopped. If these registers are updated while the TIMER is started then this may result in unpredictable behavior. When the timer is incremented beyond its maximum value the Counter register will overflow and the TIMER will automatically start over from zero. NORDIC\* The Counter register can be cleared, that is, its internal value set to zero explicitly, by triggering the CLEAR task. The TIMER implements multiple capture/compare registers. Independent of prescaler setting the accuracy of the TIMER is equivalent to one tick of the timer frequency f<sub>TIMER</sub> as illustrated in Block schematic for timer/counter on page 255. #### 6.20.1 Capture The TIMER implements one capture task for every available capture/compare register. Every time the CAPTURE[n] task is triggered, the Counter value is copied to the CC[n] register. #### 6.20.2 Compare The TIMER implements one COMPARE event for every available capture/compare register. A COMPARE event is generated when the Counter is incremented and then becomes equal to the value specified in one of the capture compare registers. When the Counter value becomes equal to the value specified in a capture compare register CC[n], the corresponding compare event COMPARE[n] is generated. BITMODE on page 260 specifies how many bits of the Counter register and the capture/compare register that are used when the comparison is performed. Other bits will be ignored. ## 6.20.3 Task delays After the TIMER is started, the CLEAR task, COUNT task and the STOP task will guarantee to take effect within one clock cycle of the PCLK16M. ## 6.20.4 Task priority If the START task and the STOP task are triggered at the same time, that is, within the same period of PCLK16M, the STOP task will be prioritized. # 6.20.5 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|-------------|----------------------------------------| | 0x40008000 | TIMER | TIMERO | Timer 0 | This timer instance has 4 CC registers | | | | | | (CC[03]) | | 0x40009000 | TIMER | TIMER1 | Timer 1 | This timer instance has 4 CC registers | | | | | | (CC[03]) | | 0x4000A000 | TIMER | TIMER2 | Timer 2 | This timer instance has 4 CC registers | | | | | | (CC[03]) | Table 81: Instances | Register | Offset | Description | | |------------------|--------|---------------------------------------|------------| | TASKS_START | 0x000 | Start Timer | | | TASKS_STOP | 0x004 | Stop Timer | | | TASKS_COUNT | 0x008 | Increment Timer (Counter mode only) | | | TASKS_CLEAR | 0x00C | Clear time | | | TASKS_SHUTDOWN | 0x010 | Shut down timer | Deprecated | | TASKS_CAPTURE[0] | 0x040 | Capture Timer value to CC[0] register | | | TASKS_CAPTURE[1] | 0x044 | Capture Timer value to CC[1] register | | | TASKS_CAPTURE[2] | 0x048 | Capture Timer value to CC[2] register | | | Register | Offset | Description | |-------------------|--------|------------------------------------------------| | TASKS_CAPTURE[3] | 0x04C | Capture Timer value to CC[3] register | | TASKS_CAPTURE[4] | 0x050 | Capture Timer value to CC[4] register | | TASKS_CAPTURE[5] | 0x054 | Capture Timer value to CC[5] register | | EVENTS_COMPARE[0] | 0x140 | Compare event on CC[0] match | | EVENTS_COMPARE[1] | 0x144 | Compare event on CC[1] match | | EVENTS_COMPARE[2] | 0x148 | Compare event on CC[2] match | | EVENTS_COMPARE[3] | 0x14C | Compare event on CC[3] match | | EVENTS_COMPARE[4] | 0x150 | Compare event on CC[4] match | | EVENTS_COMPARE[5] | 0x154 | Compare event on CC[5] match | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | MODE | 0x504 | Timer mode selection | | BITMODE | 0x508 | Configure the number of bits used by the TIMER | | PRESCALER | 0x510 | Timer prescaler register | | CC[0] | 0x540 | Capture/Compare register 0 | | CC[1] | 0x544 | Capture/Compare register 1 | | CC[2] | 0x548 | Capture/Compare register 2 | | CC[3] | 0x54C | Capture/Compare register 3 | | CC[4] | 0x550 | Capture/Compare register 4 | | CC[5] | 0x554 | Capture/Compare register 5 | Table 82: Register overview ## 6.20.5.1 TASKS\_START Address offset: 0x000 **Start Timer** # 6.20.5.2 TASKS\_STOP Address offset: 0x004 **Stop Timer** | Bit n | umber | | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 | |-------|---------------|---------|------------------|---------------------------------------------------------------------|---| | ID | | | | | Α | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | ID | | | | | | | Α | W TASKS_STOP | | | Stop Timer | | | | | Trigger | 1 | Trigger task | | # 6.20.5.3 TASKS\_COUNT Address offset: 0x008 Increment Timer (Counter mode only) #### 6.20.5.4 TASKS\_CLEAR Address offset: 0x00C Clear time | Bit number | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|---------|----------------|------------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A W TASKS_CLEAR | | | Clear time | | | Trigger | 1 | Trigger task | # 6.20.5.5 TASKS\_SHUTDOWN ( Deprecated ) Address offset: 0x010 Shut down timer # 6.20.5.6 TASKS\_CAPTURE[n] (n=0..5 Address offset: $0x040 + (n \times 0x4)$ Capture Timer value to CC[n] register | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|---------|-------------------------|-----------------------------------------------------------------| | ID | | | | А | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_CAPTURE | | | Capture Timer value to CC[n] register | | | | Trigger | 1 | Trigger task | ## 6.20.5.7 EVENTS\_COMPARE[n] (n=0..5) Address offset: $0x140 + (n \times 0x4)$ Compare event on CC[n] match #### 6.20.5.8 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit nu | ımbe | r | | 31 | 30 2: | 9 28 | 8 27 | 7 26 | 25 | 24 | 23 2 | 2 21 | . 20 | 19 1 | 8 1 | 7 1 | 5 15 | 14 | 13 | 12 1 | .1 10 | 9 | 8 | 7 | 6 | 5 4 | 1 3 | 2 | 1 0 | |--------|-------|------------------|----------|----|-------|------|------|------|----|----|------|--------|-------|------|------|-----|------|----|-----|------|-------|-----|------|-----|---|-----|-----|---|-----| | ID | | | | | | | | | | | | | | | | | | | L | Κ . | J I | Н | G | | | F E | D | С | ВА | | Rese | t 0x0 | 0000000 | | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0_0 | 0 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 0 | | ID | | | | | | | | | | 1 | Desc | cripti | ion | 1 | | | | | | | | | | | | | | | | | A-F | RW | COMPARE[i]_CLEAR | | | | | | | | | Shoi | rtcut | bet | twe | en e | ver | nt C | ОМ | PAR | E[i] | and | tas | k CL | EAR | 1 | | | | | | | | (i=05) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Disabled | 0 | | | | | | | Disa | ble s | shor | tcut | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | ٦ | | Enal | ble sl | hort | tcut | | | | | | L | | | | | | | | | | | G-L | RW | COMPARE[i]_STOP | | | | | | 7 | | | Shoi | rtcut | t bet | twe | en e | ver | it C | MC | PAR | E[i] | and | tas | k ST | ОР | | | | | | | | | (i=05) | | | | V | | | | | | | | | K | | | | ٦ | 1 | | | | | | | | | | | | | | Disabled | 0 | | | | | | | Disa | ble s | shor | tcut | | | | | J | | | | | | | | | | | | | | | Enabled | 1 | | P | | | | | Enal | ble sl | hort | tcut | | | | | | | | | | | | | | | | #### 6.20.5.9 INTENSET Address offset: 0x304 **Enable interrupt** #### 6.20.5.10 INTENCLR Address offset: 0x308 Disable interrupt | Bit number | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------------------------|------------------------|------------------------------------------------------------------| | ID | | F E D C B A | | Reset 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A-F RW COMPARE[i] (i=05) | | Write '1' to disable interrupt for event COMPARE[i] | | Clear | 1 | Disable | | Disabled | 0 | Read: Disabled | | Enabled | 1 | Read: Enabled | #### 6.20.5.11 MODE Address offset: 0x504 Timer mode selection | Bit n | umber | | 31 30 2 | 29 28 | 3 27 2 | 6 25 | 24 | 23 2 | 2 2: | 1 20 | 19 | 18 | 17 | 16 1 | 15 1 | 4 13 | 3 12 | 11 3 | 10 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 2 1 | . 0 | |-------|---------------|-----------------|---------|-------|--------|------|----|------|-------|------|------|-----|-----|------|------|------|------|------|------|---|---|---|---|---|-----|------|------| | ID | | | | | | | | 4 | | | 7 | 7 | | | | | | | | | | | | | | Δ | A | | Rese | et 0x00000000 | | 0 0 | 0 0 | 0 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | ID | | | | | | | | Desi | sript | tion | | | | | | | | | | | | | | | | | | | Α | RW MODE | | | | | | | Tim | er m | node | e . | | | | | 4 | | | | | | | | | | | | | | | Timer | 0 | | 4 | 1 | | Sele | ct T | ime | r m | ode | è | | | | | | | | | | | | | | | | | | Counter | 1 | | | | | Sele | ct C | oun | iter | mo | de | | | | N | | | | | | | [ | Оер | reca | ated | | | | LowPowerCounter | 2 | | | | | Sele | ct L | ow l | Pov | ver | Cou | ınte | r m | ode | | | | | | | | | | | | #### 6.20.5.12 BITMODE Address offset: 0x508 Configure the number of bits used by the TIMER | Bit numb | er | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 3 | 1 0 | |-----------|-----------|----------|-------------------------|---------------------------------------------------------------|-----| | ID | | | | | 4 A | | Reset 0x0 | 00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 | | ID Ac | ce Field | Value ID | Value | | | | A RW | V BITMODE | | | Timer bit width | | | | | 16Bit | 0 | 16 bit timer bit width | | | | | 08Bit | 1 | 8 bit timer bit width | | | | | 24Bit | 2 | 24 bit timer bit width | | | | | 32Bit | 3 | 32 bit timer bit width | | #### 6.20.5.13 PRESCALER Address offset: 0x510 Timer prescaler register | _ | RW PRESCALER | [09] | Prescaler value | |-------|---------------|----------------------|------------------------------------------------------------------| | ID | | | Description | | Rese | et 0x00000004 | 0 0 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID | | | АААА | | Bit r | umber | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | # 6.20.5.14 CC[n] (n=0..5) Address offset: $0x540 + (n \times 0x4)$ #### Capture/Compare register n # $6.21 \text{ TWIM} - I^2 \text{C}$ compatible two-wire interface master with EasyDMA TWI master with EasyDMA (TWIM) is a two-wire half-duplex master which can communicate with multiple slave devices connected to the same bus Listed here are the main features for TWIM: - I<sup>2</sup>C compatible - Supported baud rates: 100, 250, 400 kbps - Support for clock stretching (non I<sup>2</sup>C compliant) - EasyDMA The two-wire interface can communicate with a bi-directional wired-AND bus with two lines (SCL, SDA). The protocol makes it possible to interconnect up to 127 individually addressable devices. TWIM is not compatible with CBUS. The GPIOs used for each two-wire interface line can be chosen from any GPIO on the device and are independently configurable. This enables great flexibility in device pinout and efficient use of board space and signal routing. Figure 94: TWI master with EasyDMA A typical TWI setup consists of one master and one or more slaves. For an example, see A typical TWI setup comprising one master and three slaves on page 262. This TWIM is only able to operate as a single master on the TWI bus. Multi-master bus configuration is not supported. Figure 95: A typical TWI setup comprising one master and three slaves This TWI master supports clock stretching performed by the slaves. Note that the SCK pulse following a stretched clock cycle may be shorter than specified by the I2C specification. The TWI master is started by triggering the STARTTX or STARTRX tasks, and stopped by triggering the STOP task. The TWI master will generate a STOPPED event when it has stopped following a STOP task. The TWI master cannot get stopped while it is suspended, so the STOP task has to be issued after the TWI master has been resumed. After the TWI master is started, the STARTTX task or the STARTRX task should not be triggered again before the TWI master has stopped, i.e. following a LASTRX, LASTTX or STOPPED event. If a NACK is clocked in from the slave, the TWI master will generate an ERROR event. # 6.21.1 EasyDMA The TWIM implements EasyDMA for accessing RAM without CPU involvement. The TWIM peripheral implements the following EasyDMA channels: | Channel | Туре | Register Cluster | |---------|--------|------------------| | TXD | READER | TXD | | RXD | WRITER | RXD | Table 83: TWIM EasyDMA Channels For detailed information regarding the use of EasyDMA, see EasyDMA on page 34. The .PTR and .MAXCNT registers are double-buffered. They can be updated and prepared for the next RX/TX transmission immediately after having received the RXSTARTED/TXSTARTED event. The STOPPED event indicates that EasyDMA has finished accessing the buffer in RAM. #### 6.21.2 Master write sequence A TWI master write sequence is started by triggering the STARTTX task. After the STARTTX task has been triggered, the TWI master will generate a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 0 (WRITE=0, READ=1). The address must match the address of the slave device that the master wants to write to. The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK=1) generated by the slave. After receiving the ACK bit, the TWI master will clock out the data bytes found in the transmit buffer located in RAM at the address specified in the TXD.PTR register. Each byte clocked out from the master will be followed by an ACK/NACK bit clocked in from the slave. A typical TWI master write sequence is illustrated in TWI master writing data to a slave on page 263. Occurrence 2 in the figure illustrates clock stretching performed by the TWI master following a SUSPEND task. A SUSPENDED event indicates that the SUSPEND task has taken effect; this event can be used to synchronize the software. Figure 96: TWI master writing data to a slave The TWI master will generate a LASTTX event when it starts to transmit the last byte, this is illustrated in TWI master writing data to a slave on page 263 The TWI master is stopped by triggering the STOP task, this task should be triggered during the transmission of the last byte to secure that the TWI will stop as fast as possible after sending the last byte. It is safe to use the shortcut between LASTTX and STOP to accomplish this. Note that the TWI master does not stop by itself when the whole RAM buffer has been sent, or when an error occurs. The STOP task must be issued, through the use of a local or PPI shortcut, or in software as part of the error handler. The TWI master cannot get stopped while it is suspended, so the STOP task has to be issued after the TWI master has been resumed. #### 6.21.3 Master read sequence A TWI master read sequence is started by triggering the STARTRX task. After the STARTRX task has been triggered the TWI master will generate a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 1 (WRITE = 0, READ = 1). The address must match the address of the slave device that the master wants to read from. The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK = 1) generated by the slave. After having sent the ACK bit the TWI slave will send data to the master using the clock generated by the master. Data received will be stored in RAM at the address specified in the RXD.PTR register. The TWI master will generate an ACK after all but the last byte received from the slave. The TWI master will generate a NACK after the last byte received to indicate that the read sequence shall stop. A typical TWI master read sequence is illustrated in The TWI master reading data from a slave on page 265. Occurrence 2 in the figure illustrates clock stretching performed by the TWI master following a SUSPEND task. A SUSPENDED event indicates that the SUSPEND task has taken effect; this event can be used to synchronize the software. The TWI master will generate a LASTRX event when it is ready to receive the last byte, this is illustrated in The TWI master reading data from a slave on page 265. If RXD.MAXCNT > 1 the LASTRX event is generated after sending the ACK of the previously received byte. If RXD.MAXCNT = 1 the LASTRX event is generated after receiving the ACK following the address and READ bit. The TWI master is stopped by triggering the STOP task, this task must be triggered before the NACK bit is supposed to be transmitted. The STOP task can be triggered at any time during the reception of the last byte. It is safe to use the shortcut between LASTRX and STOP to accomplish this. Note that the TWI master does not stop by itself when the RAM buffer is full, or when an error occurs. The STOP task must be issued, through the use of a local or PPI shortcut, or in software as part of the error handler. The TWI master cannot get stopped while it is suspended, so the STOP task has to be issued after the TWI master has been resumed. Figure 97: The TWI master reading data from a slave # 6.21.4 Master repeated start sequence A typical repeated start sequence is one in which the TWI master writes two bytes to the slave followed by reading four bytes from the slave. This example uses shortcuts to perform the simplest type of repeated start sequence, i.e. one write followed by one read. The same approach can be used to perform a repeated start sequence where the sequence is read followed by write. The figure A repeated start sequence, where the TWI master writes two bytes followed by reading 4 bytes from the slave on page 265 illustrates this: Figure 98: A repeated start sequence, where the TWI master writes two bytes followed by reading 4 bytes from the slave If a more complex repeated start sequence is needed and the TWI firmware drive is serviced in a low priority interrupt it may be necessary to use the SUSPEND task and SUSPENDED event to guarantee that the correct tasks are generated at the correct time. This is illustrated in A double repeated start sequence using the SUSPEND task to secure safe operation in low priority interrupts on page 266. Figure 99: A double repeated start sequence using the SUSPEND task to secure safe operation in low priority interrupts #### 6.21.5 Low power When putting the system in low power and the peripheral is not needed, lowest possible power consumption is achieved by stopping, and then disabling the peripheral. The STOP task may not be always needed (the peripheral might already be stopped), but if it is sent, software shall wait until the STOPPED event was received as a response before disabling the peripheral through the ENABLE register. # 6.21.6 Master mode pin configuration The SCL and SDA signals associated with the TWI master are mapped to physical pins according to the configuration specified in the PSEL.SCL and PSEL.SDA registers respectively. The PSEL.SCL and PSEL.SDA registers and their configurations are only used as long as the TWI master is enabled, and retained only as long as the device is in ON mode. When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field and PIN\_CNF[n] register. PSEL.SCL, PSEL.SDA must only be configured when the TWI master is disabled. To secure correct signal levels on the pins used by the TWI master when the system is in OFF mode, and when the TWI master is disabled, these pins must be configured in the GPIO peripheral as described in GPIO configuration before enabling peripheral on page 266. Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior. | TWI master signal | TWI master pin | Direction | Output value | Drive strength | |-------------------|--------------------------|-----------|----------------|----------------| | SCL | As specified in PSEL.SCL | Input | Not applicable | SOD1 | | SDA | As specified in PSEL.SDA | Input | Not applicable | S0D1 | Table 84: GPIO configuration before enabling peripheral # 6.21.7 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|---------------------------|---------------| | 0x40003000 | TWIM | TWIM0 | Two-wire interface master | | Table 85: Instances | Register | Offset | Description | |------------------|--------|----------------------------------------------------------------------------------------| | TASKS_STARTRX | 0x000 | Start TWI receive sequence | | TASKS_STARTTX | 0x008 | Start TWI transmit sequence | | TASKS_STOP | 0x014 | Stop TWI transaction. Must be issued while the TWI master is not suspended. | | TASKS_SUSPEND | 0x01C | Suspend TWI transaction | | TASKS_RESUME | 0x020 | Resume TWI transaction | | EVENTS_STOPPED | 0x104 | TWI stopped | | EVENTS_ERROR | 0x124 | TWI error | | EVENTS_SUSPENDED | 0x148 | Last byte has been sent out after the SUSPEND task has been issued, TWI traffic is now | | | | suspended. | | EVENTS_RXSTARTED | 0x14C | Receive sequence started | | EVENTS_TXSTARTED | 0x150 | Transmit sequence started | | EVENTS_LASTRX | 0x15C | Byte boundary, starting to receive the last byte | | EVENTS_LASTTX | 0x160 | Byte boundary, starting to transmit the last byte | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTEN | 0x300 | Enable or disable interrupt | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | ERRORSRC | 0x4C4 | Error source | | ENABLE | 0x500 | Enable TWIM | | PSEL.SCL | 0x508 | Pin select for SCL signal | | PSEL.SDA | 0x50C | Pin select for SDA signal | | FREQUENCY | 0x524 | TWI frequency. Accuracy depends on the HFCLK source selected. | | RXD.PTR | 0x534 | Data pointer | | RXD.MAXCNT | 0x538 | Maximum number of bytes in receive buffer | | RXD.AMOUNT | 0x53C | Number of bytes transferred in the last transaction | | RXD.LIST | 0x540 | EasyDMA list type | | TXD.PTR | 0x544 | Data pointer | | TXD.MAXCNT | 0x548 | Maximum number of bytes in transmit buffer | | TXD.AMOUNT | 0x54C | Number of bytes transferred in the last transaction | | TXD.LIST | 0x550 | EasyDMA list type | | ADDRESS | 0x588 | Address used in the TWI transfer | Table 86: Register overview # 6.21.7.1 TASKS STARTRX Address offset: 0x000 Start TWI receive sequence # 6.21.7.2 TASKS\_STARTTX Address offset: 0x008 Start TWI transmit sequence #### 6.21.7.3 TASKS\_STOP Address offset: 0x014 Stop TWI transaction. Must be issued while the TWI master is not suspended. | Bit number | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|---------|-------------------------------------------------------------|---------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | Value Description | | | A W TASKS_STOP | | Stop TWI transaction. Must be issued is not suspended. | d while the TWI master | | | Trigger | 1 Trigger task | | # 6.21.7.4 TASKS\_SUSPEND Address offset: 0x01C Suspend TWI transaction #### 6.21.7.5 TASKS RESUME Address offset: 0x020 Resume TWI transaction | / TASKS RESUME | value 15 | Resume TWI transaction | | |----------------|----------|-----------------------------------------------------------------------------------|------------------------------------------| | | | | | | | | | | | <00000000 | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 | | | | | Α | | ber | | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 | | | | x0000000 | 00000000 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | #### 6.21.7.6 EVENTS STOPPED Address offset: 0x104 TWI stopped | Bit number | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW EVENTS_STOPPED | | | TWI stopped | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | ## 6.21.7.7 EVENTS\_ERROR Address offset: 0x124 TWI error | Bit number | | 31 30 29 28 | 3 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------------------|--------------|-------------|------------|--------------------------------------------------------------------| | ID | | | | A | | Reset 0x00000000 | | 0 0 0 0 | 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | Description | | A RW EVENTS_ERROR | | | | TWI error | | | NotGenerated | 0 | | Event not generated | | | Generated | 1 | 4 | Event generated | ## 6.21.7.8 EVENTS\_SUSPENDED Address offset: 0x148 Last byte has been sent out after the SUSPEND task has been issued, TWI traffic is now suspended. ## 6.21.7.9 EVENTS RXSTARTED Address offset: 0x14C Receive sequence started #### 6.21.7.10 EVENTS\_TXSTARTED Address offset: 0x150 Transmit sequence started | Bit num | ıber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------|--------------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | | А | | Reset 0 | x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID A | | | | Description | | A R | W EVENTS_TXSTARTED | | | Transmit sequence started | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | # 6.21.7.11 EVENTS\_LASTRX Address offset: 0x15C Byte boundary, starting to receive the last byte | Bit r | number | | 31 30 29 28 | 27 26 25 2 | 24 23 22 2 | 1 20 19 | 18 17 | 16 15 | 14 13 | 3 12 1 | 1 10 9 | 8 | 7 6 | 5 5 | 4 | 3 | 2 1 | 0 | |-------|------------------|--------------|-------------|------------|------------|---------|--------|-------|--------|--------|---------|-----|-----|-----|---|---|-----|---| | ID | | | | | | | | | | | | | | | | | | Α | | Res | et 0x00000000 | | 0 0 0 0 | 0 0 0 | 0 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 ( | 0 0 | 0 | 0 ( | 0 | 0 | 0 | 0 0 | 0 | | ID | | | | | Descrip | tion | | | | | | | | | | | | | | Α | RW EVENTS_LASTRX | | | | Byte bo | undary, | starti | ng to | receiv | e the | last by | yte | | | | | | | | | | NotGenerated | 0 | | Event n | ot gene | rated | | | | | | | | | | | | | | | Generated | 1 | | Event ge | enerate | d | | | | | | | | | | | | # 6.21.7.12 EVENTS\_LASTTX Address offset: 0x160 Byte boundary, starting to transmit the last byte #### 6.21.7.13 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit nu | ımber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|-------------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | F E D C B A | | Reset | 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW LASTTX_STARTRX | | | Shortcut between event LASTTX and task STARTRX | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | В | RW LASTTX_SUSPEND | | | Shortcut between event LASTTX and task SUSPEND | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | С | RW LASTTX_STOP | | | Shortcut between event LASTTX and task STOP | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | Bit n | umber | | 31 | 30 | 29 28 | 8 27 | 26 2 | 25 2 | 4 2 | 3 22 | 2 2 1 | 1 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 1 | LO | 9 | 8 | 7 ( | 5 5 | 5 4 | 3 | 2 | 1 | 0 | |-------|-------------------|----------|----|----|-------|------|------|------|-----|------|-------|------|------|-----|----|-----|----|-----|------|----|------|------|-----|-----|-----|-----|-----|---|---|---|---| | ID | | | | | | | | | | | | | | | | | | | | F | Ε | D | C I | В | 4 | | | | | | | | Rese | t 0x00000000 | | 0 | 0 | 0 0 | 0 | 0 | 0 0 | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | ) ( | 0 | 0 | 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | D | RW LASTRX_STARTTX | | | | | | | | S | hort | tcut | t be | etw | eer | ev | ent | LA | STF | XX a | nd | tas | k S1 | AR | ΤTX | | | | | | | | | | | Disabled | 0 | | | | | | D | isab | ole s | sho | rtc | ut | | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | | Ε | nabl | le s | shoi | rtcı | ıt | | | | | | | | | | | | | | | | | | | E | RW LASTRX_SUSPEND | | | | | | | | S | hort | tcut | t be | etw | eer | ev | ent | LA | STF | XX a | nd | tas | k Sl | JSP | EN | D | | | | | | | | | | Disabled | 0 | | | | | | D | isab | ole s | sho | rtc | ut | | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | | Ε | nabl | le s | shoi | rtcı | ıt | | | | | | | | | | | | | | | | | | | F | RW LASTRX_STOP | | | | | | | | S | hort | tcut | t be | etw | eer | ev | ent | LA | STF | RX a | nd | tas | k S1 | OP | • | | | | | | | | | | | Disabled | 0 | | | | | | D | isab | ole s | sho | rtc | ut | | | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | | | Ε | nabl | le s | shoi | rtcı | ıt | | | | | | | | | | | | | | | | | | #### 6.21.7.14 INTEN Address offset: 0x300 Enable or disable interrupt | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | I I H G F D A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | Value ID | Value | Description | | Α | RW STOPPED | | | Enable or disable interrupt for event STOPPED | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | D | RW ERROR | | | Enable or disable interrupt for event ERROR | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | F | RW SUSPENDED | | | Enable or disable interrupt for event SUSPENDED | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | G | RW RXSTARTED | | | Enable or disable interrupt for event RXSTARTED | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | Н | RW TXSTARTED | | | Enable or disable interrupt for event TXSTARTED | | | | Disabled | , 0 | Disable | | | | Enabled | 1 | Enable | | 1 | RW LASTRX | | | Enable or disable interrupt for event LASTRX | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | J | RW LASTTX | | | Enable or disable interrupt for event LASTTX | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | ## 6.21.7.15 INTENSET Address offset: 0x304 Enable interrupt | Bit r | umber | | 31 30 29 28 | 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|-------------|-------------|-----------------------------------------------------------------| | ID | | | | J | I H G F D A | | Rese | et 0x00000000 | | 0 0 0 0 | 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | Α | RW STOPPED | | | | Write '1' to enable interrupt for event STOPPED | | | | Set | 1 | | Enable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | D | RW ERROR | | | | Write '1' to enable interrupt for event ERROR | | | | Set | 1 | | Enable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | F | RW SUSPENDED | | | | Write '1' to enable interrupt for event SUSPENDED | | | | Set | 1 | | Enable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | G | RW RXSTARTED | | | | Write '1' to enable interrupt for event RXSTARTED | | | | Set | 1 | | Enable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | Н | RW TXSTARTED | | | | Write '1' to enable interrupt for event TXSTARTED | | | | Set | 1 | | Enable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | I | RW LASTRX | | | | Write '1' to enable interrupt for event LASTRX | | | | Set | 1 | | Enable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 1 | | Read: Enabled | | J | RW LASTTX | | | | Write '1' to enable interrupt for event LASTTX | | | | Set | 1 | 4 | Enable | | | | Disabled | 0 | | Read: Disabled | | | | Enabled | 4 | | Read: Enabled | | | | | | | | # 6.21.7.16 INTENCLR Address offset: 0x308 Disable interrupt | Bit r | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | J | I H G F D A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | Description | | Α | RW STOPPED | | | Write '1' to disable interrupt for event STOPPED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW ERROR | | | Write '1' to disable interrupt for event ERROR | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | F | RW SUSPENDED | | | Write '1' to disable interrupt for event SUSPENDED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | | | | | Bit n | umber | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|--------------|----------|----------------------|------------------------------------------------------------------| | ID | | | | J I H G F D A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | Description | | | | Enabled | 1 | Read: Enabled | | G | RW RXSTARTED | | | Write '1' to disable interrupt for event RXSTARTED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Н | RW TXSTARTED | | | Write '1' to disable interrupt for event TXSTARTED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | 1 | RW LASTRX | | | Write '1' to disable interrupt for event LASTRX | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | J | RW LASTTX | | | Write '1' to disable interrupt for event LASTTX | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | # 6.21.7.17 ERRORSRC Address offset: 0x4C4 Error source | Bit nu | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|--------------|-------------|------------------------|-----------------------------------------------------------------| | ID | | | | СВА | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | Acce Field | Value ID | Value | Description | | Α | RW OVERRUN | | XV | Overrun error | | | | | | A new byte was received before previous byte got | | | | | | transferred into RXD buffer. (Previous data is lost) | | | | NotReceived | 0 | Error did not occur | | | | Received | 1 | Error occurred | | В | RW ANACK | | | NACK received after sending the address (write '1' to clear) | | | | NotReceived | 0 | Error did not occur | | | | Received | 1 | Error occurred | | С | RW DNACK | | | NACK received after sending a data byte (write '1' to clear) | | | | NotReceived | 0 | Error did not occur | | | | Received | 1 | Error occurred | #### 6.21.7.18 ENABLE Address offset: 0x500 **Enable TWIM** | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | АААА | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW ENABLE | | | Enable or disable TWIM | | | Disabled | 0 | Disable TWIM | | | Enabled | 6 | Enable TWIM | #### 6.21.7.19 PSEL.SCL Address offset: 0x508 Pin select for SCL signal | Bit r | number | | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | |-------|--------------|--------------|------------------|----------------------------------------------------------------------| | ID | | | С | ААА | | Rese | et OxFFFFFFF | | 1 1 1 1 1 : | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | Description | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.21.7.20 PSEL.SDA Address offset: 0x50C Pin select for SDA signal # 6.21.7.21 FREQUENCY Address offset: 0x524 TWI frequency. Accuracy depends on the HFCLK source selected. | Bit r | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|------|------------------------|-----------------------------------------------------------------| | ID | | | A A A A A A A | . A A A A A A A A A A A A A A A A A A A | | Rese | et 0x04000000 | | 0 0 0 0 0 1 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW FREQUENCY | | | TWI master clock frequency | | | | K100 | 0x01980000 | 100 kbps | | | | K250 | 0x04000000 | 250 kbps | | | | K400 | 0x06400000 | 400 kbps | #### 6.21.7.22 RXD.PTR Address offset: 0x534 Data pointer **Note:** See the memory chapter for details about which memories are available for EasyDMA. #### 6.21.7.23 RXD.MAXCNT Address offset: 0x538 Maximum number of bytes in receive buffer #### 6.21.7.24 RXD.AMOUNT Address offset: 0x53C Number of bytes transferred in the last transaction #### 6.21.7.25 RXD.LIST Address offset: 0x540 EasyDMA list type | Bit number | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|-------------------------|-----------------------------------------------------------------| | ID | | ААА | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A RW LIST | | List type | | Disabled | 0 | Disable EasyDMA list | | ArrayList | 1 | Use array list | #### 6.21.7.26 TXD.PTR Address offset: 0x544 Data pointer **Note:** See the memory chapter for details about which memories are available for EasyDMA. #### 6.21.7.27 TXD.MAXCNT Address offset: 0x548 Maximum number of bytes in transmit buffer #### 6.21.7.28 TXD.AMOUNT Address offset: 0x54C Number of bytes transferred in the last transaction #### 6.21.7.29 TXD.LIST Address offset: 0x550 EasyDMA list type | Bit number | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|-------------------------|-----------------------------------------------------------------| | ID | | ААА | | Reset 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | Description | | A RW LIST | | List type | | Disabled | 0 | Disable EasyDMA list | | ArrayList | 1 | Use array list | #### 6.21.7.30 ADDRESS Address offset: 0x588 Address used in the TWI transfer | Bit number | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|---------------------------------------------------------------------------------------| | ID | A A A A A A | | Reset 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | Value Description | A RW ADDRESS Address used in the TWI transfer # 6.21.8 Electrical specification # 6.21.8.1 TWIM interface electrical specifications | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|--------------------------------------------------------|------|------|------|-------| | f <sub>TWIM,SCL</sub> | Bit rates for TWIM <sup>30</sup> | 100 | | 400 | kbps | | t <sub>TWIM,START</sub> | Time from STARTRX/STARTTX task to transmission started | | ii. | | μs | # 6.21.8.2 Two Wire Interface Master (TWIM) timing specifications | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------------------------|------------------------------------------------------------------------|-------|------|------|-------| | t <sub>TWIM,SU_DAT</sub> | Data setup time before positive edge on SCL – all modes | 300 | | | ns | | t <sub>TWIM,HD_DAT</sub> | Data hold time after negative edge on SCL – all modes | 500 | | | ns | | t <sub>TWIM,HD_STA,100kbps</sub> | TWIM master hold time for START and repeated START condition, 100 kbps | 10000 | | | ns | | t <sub>TWIM,HD_STA,250kbps</sub> | TWIM master hold time for START and repeated START condition, 250kbps | 4000 | | | ns | | t <sub>TWIM,HD_STA,400kbps</sub> | TWIM master hold time for START and repeated START condition, 400 kbps | 2500 | | | ns | | t <sub>TWIM</sub> ,su_sto,100kbps | TWIM master setup time from SCL high to STOP condition, 100 kbps | 5000 | | | ns | | t <sub>TWIM,SU_STO,250kbps</sub> | TWIM master setup time from SCL high to STOP condition,<br>250 kbps | 2000 | | | ns | | t <sub>TWIM,SU_STO,400kbps</sub> | TWIM master setup time from SCL high to STOP condition, 400 kbps | 1250 | | | ns | | t <sub>TWIM,BUF,100kbps</sub> | TWIM master bus free time between STOP and START conditions, 100 kbps | 5800 | | | ns | | t <sub>TWIM,BUF,250kbps</sub> | TWIM master bus free time between STOP and START conditions, 250 kbps | 2700 | | | ns | | t <sub>TWIM,BUF,400kbps</sub> | TWIM master bus free time between STOP and START conditions, 400 kbps | 2100 | | | ns | High bit rates or stronger pull-ups may require GPIOs to be set as High Drive, see GPIO chapter for more details. Figure 100: TWIM timing diagram, 1 byte transaction # 6.21.9 Pullup resistor Figure 101: Recommended TWIM pullup value vs. line capacitance - The I2C specification allows a line capacitance of 400 pF at most. - The value of internal pullup resistor (R<sub>PU</sub>) for nRF52805 can be found in GPIO General purpose input/output on page 102. # $6.22 \text{ TWIS} - I^2 \text{C}$ compatible two-wire interface slave with EasyDMA TWI slave with EasyDMA (TWIS) is compatible with $I^2C$ operating at 100 kHz and 400 kHz. The TWI transmitter and receiver implement EasyDMA. Figure 102: TWI slave with EasyDMA A typical TWI setup consists of one master and one or more slaves. For an example, see A typical TWI setup comprising one master and three slaves on page 279. TWIS is only able to operate with a single master on the TWI bus. Figure 103: A typical TWI setup comprising one master and three slaves The TWI slave state machine is illustrated in TWI slave state machine on page 280 and TWI slave state machine symbols on page 280 is explaining the different symbols used in the state machine. Figure 104: TWI slave state machine | Symbol | Туре | Description | |------------------|--------------|----------------------------------------------------------------------------------------------------------| | ENABLE | Register | The TWI slave has been enabled via the ENABLE register | | PREPARETX | Task | The TASKS_PREPARETX task has been triggered | | STOP | Task | The TASKS_STOP task has been triggered | | PREPARERX | Task | The TASKS_PREPARERX task has been triggered | | STOPPED | Event | The EVENTS_STOPPED event was generated | | RXSTARTED | Event | The EVENTS_RXSTARTED event was generated | | TXSTARTED | Event | The EVENTS_TXSTARTED event was generated | | TX prepared | Internal | Internal flag indicating that a TASKS_PREPARETX task has been triggered. This flag is not visible to the | | | | user. | | RX prepared | Internal | Internal flag indicating that a TASKS_PREPARERX task has been triggered. This flag is not visible to the | | | | user. | | Unprepare TX | Internal | Clears the internal 'TX prepared' flag until next TASKS_PREPARETX task. | | Unprepare RX | Internal | Clears the internal 'RX prepared' flag until next TASKS_PREPARERX task. | | Stop sequence | TWI protocol | A TWI stop sequence was detected | | Restart sequence | TWI protocol | A TWI restart sequence was detected | Table 87: TWI slave state machine symbols The TWI slave supports clock stretching performed by the master. The TWI slave operates in a low power mode while waiting for a TWI master to initiate a transfer. As long as the TWI slave is not addressed, it will remain in this low power mode. To secure correct behaviour of the TWI slave, PSEL.SCL, PSEL.SDA, CONFIG and the ADDRESS[n] registers, must be configured prior to enabling the TWI slave through the ENABLE register. Similarly, changing these settings must be performed while the TWI slave is disabled. Failing to do so may result in unpredictable behaviour. #### 6.22.1 EasyDMA The TWIS implements EasyDMA for accessing RAM without CPU involvement. The TWIS peripheral implements the following EasyDMA channels: | Channel | Туре | Register Cluster | |---------|--------|------------------| | TXD | READER | TXD | | RXD | WRITER | RXD | Table 88: TWIS EasyDMA Channels For detailed information regarding the use of EasyDMA, see EasyDMA on page 34. The STOPPED event indicates that EasyDMA has finished accessing the buffer in RAM. ## 6.22.2 TWI slave responding to a read command Before the TWI slave can respond to a read command the TWI slave must be configured correctly and enabled via the ENABLE register. When enabled the TWI slave will be in its IDLE state where it will consume $I_{\rm IDLE}$ . A read command is started when the TWI master generates a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 1 (WRITE=0, READ=1). The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK=1) response from the TWI slave. The TWI slave is able to listen for up to two addresses at the same time. Which addresses to listen for is configured in the ADDRESS registers and the CONFIG register. The TWI slave will only acknowledge (ACK) the read command if the address presented by the master matches one of the addresses the slave is configured to listen for. The TWI slave will generate a READ event when it acknowledges the read command. The TWI slave is only able to detect a read command from the IDLE state. The TWI slave will set an internal 'TX prepared' flag when the PREPARETX task is triggered. When the read command is received the TWI slave will enter the TX state if the internal 'TX prepared' flag is set. If the internal 'TX prepared' flag is not set when the read command is received, the TWI slave will stretch the master's clock until the PREPARETX task is triggered and the internal 'TX prepared' flag is set. The TWI slave will generate the TXSTARTED event and clear the 'TX prepared' flag ('unprepare TX') when it enters the TX state. In this state the TWI slave will send the data bytes found in the transmit buffer to the master using the master's clock. The TWI slave will consume $I_{TX}$ in this mode. The TWI slave will go back to the IDLE state if the TWI slave receives a restart command when it is in the TX state. The TWI slave is stopped when it receives the stop condition from the TWI master. A STOPPED event will be generated when the transaction has stopped. The TWI slave will clear the 'TX prepared' flag ('unprepare TX') and go back to the IDLE state when it has stopped. The transmit buffer is located in RAM at the address specified in the TXD.PTR register. The TWI slave will only be able to send TXD.MAXCNT bytes from the transmit buffer for each transaction. If the TWI master forces the slave to send more than TXD.MAXCNT bytes, the slave will send the byte specified in the ORC register to the master instead. If this happens, an ERROR event will be generated. The EasyDMA configuration registers, see TXD.PTR etc., are latched when the TXSTARTED event is generated. The TWI slave can be forced to stop by triggering the STOP task. A STOPPED event will be generated when the TWI slave has stopped. The TWI slave will clear the 'TX prepared' flag and go back to the IDLE state when it has stopped, see also Terminating an ongoing TWI transaction on page 284. Each byte sent from the slave will be followed by an ACK/NACK bit sent from the master. The TWI master will generate a NACK following the last byte that it wants to receive to tell the slave to release the bus so that the TWI master can generate the stop condition. The TXD.AMOUNT register can be queried after a transaction to see how many bytes were sent. A typical TWI slave read command response is illustrated in The TWI slave responding to a read command on page 282. Occurrence 2 in the figure illustrates clock stretching performed by the TWI slave following a SUSPEND task. # 6.22.3 TWI slave responding to a write command Before the TWI slave can respond to a write command the TWI slave must be configured correctly and enabled via the ENABLE register. When enabled the TWI slave will be in its IDLE state where it will consume $I_{\rm IDLE}$ . A write command is started when the TWI master generates a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 0 (WRITE=0, READ=1). The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK=1) response from the slave. The TWI slave is able to listen for up to two addresses at the same time. Which addresses to listen for is configured in the ADDRESS registers and the CONFIG register. The TWI slave will only acknowledge (ACK) the write command if the address presented by the master matches one of the addresses the slave is configured to listen for. The TWI slave will generate a WRITE event if it acknowledges the write command. The TWI slave is only able to detect a write command from the IDLE state. The TWI slave will set an internal 'RX prepared' flag when the PREPARERX task is triggered. When the write command is received the TWI slave will enter the RX state if the internal 'RX prepared' flag is set. If the internal 'RX prepared' flag is not set when the write command is received, the TWI slave will stretch the master's clock until the PREPARERX task is triggered and the internal 'RX prepared' flag is set. The TWI slave will generate the RXSTARTED event and clear the internal 'RX prepared' flag ('unprepare RX') when it enters the RX state. In this state the TWI slave will be able to receive the bytes sent by the TWI master. The TWI slave will consume $I_{RX}$ in this mode. The TWI slave will go back to the IDLE state if the TWI slave receives a restart command when it is in the RX state. The TWI slave is stopped when it receives the stop condition from the TWI master. A STOPPED event will be generated when the transaction has stopped. The TWI slave will clear the internal 'RX prepared' flag ('unprepare RX') and go back to the IDLE state when it has stopped. The receive buffer is located in RAM at the address specified in the TXD.PTR register. The TWI slave will only be able to receive as many bytes as specified in the RXD.MAXCNT register. If the TWI master tries to send more bytes to the slave than the slave is able to receive, these bytes will be discarded and the bytes will be NACKed by the slave. If this happens, an ERROR event will be generated. The EasyDMA configuration registers, see RXD.PTR etc., are latched when the RXSTARTED event is generated. The TWI slave can be forced to stop by triggering the STOP task. A STOPPED event will be generated when the TWI slave has stopped. The TWI slave will clear the internal 'RX prepared' flag and go back to the IDLE state when it has stopped, see also Terminating an ongoing TWI transaction on page 284. The TWI slave will generate an ACK after every byte received from the master. The RXD.AMOUNT register can be queried after a transaction to see how many bytes were received. A typical TWI slave write command response is illustrated in The TWI slave responding to a write command on page 283. Occurrence 2 in the figure illustrates clock stretching performed by the TWI slave following a SUSPEND task. Figure 106: The TWI slave responding to a write command # 6.22.4 Master repeated start sequence An example of a repeated start sequence is one in which the TWI master writes two bytes to the slave followed by reading four bytes from the slave. This is illustrated in A repeated start sequence, where the TWI master writes two bytes followed by reading four bytes from the slave on page 284. NORDIC\* It is here assumed that the receiver does not know in advance what the master wants to read, and that this information is provided in the first two bytes received in the write part of the repeated start sequence. To guarantee that the CPU is able to process the received data before the TWI slave starts to reply to the read command, the SUSPEND task is triggered via a shortcut from the READ event generated when the read command is received. When the CPU has processed the incoming data and prepared the correct data response, the CPU will resume the transaction by triggering the RESUME task. Figure 107: A repeated start sequence, where the TWI master writes two bytes followed by reading four bytes from the slave # 6.22.5 Terminating an ongoing TWI transaction In some situations, e.g. if the external TWI master is not responding correctly, it may be required to terminate an ongoing transaction. This can be achieved by triggering the STOP task. In this situation a STOPPED event will be generated when the TWI has stopped independent of whether or not a STOP condition has been generated on the TWI bus. The TWI slave will release the bus when it has stopped and go back to its IDLE state. # 6.22.6 Low power When putting the system in low power and the peripheral is not needed, lowest possible power consumption is achieved by stopping, and then disabling the peripheral. The STOP task may not be always needed (the peripheral might already be stopped), but if it is sent, software shall wait until the STOPPED event was received as a response before disabling the peripheral through the ENABLE register. # 6.22.7 Slave mode pin configuration The SCL and SDA signals associated with the TWI slave are mapped to physical pins according to the configuration specified in the PSEL.SCL and PSEL.SDA registers respectively. The PSEL.SCL and PSEL.SDA registers and their configurations are only used as long as the TWI slave is enabled, and retained only as long as the device is in ON mode. When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field and PIN\_CNF[n] register. PSEL.SCL and PSEL.SDA must only be configured when the TWI slave is disabled. To secure correct signal levels on the pins used by the TWI slave when the system is in OFF mode, and when the TWI slave is disabled, these pins must be configured in the GPIO peripheral as described in GPIO configuration before enabling peripheral on page 285. Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior. | TWI slave signal | TWI slave pin | Direction | Output value | Drive strength | |------------------|--------------------------|-----------|----------------|----------------| | SCL | As specified in PSEL.SCL | Input | Not applicable | SOD1 | | SDA | As specified in PSEL.SDA | Input | Not applicable | SOD1 | Table 89: GPIO configuration before enabling peripheral # 6.22.8 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|--------------------------|---------------|--| | 0x40003000 | TWIS | TWIS0 | Two-wire interface slave | | | Table 90: Instances | Register | Offset | Description | |------------------|--------|-----------------------------------------------------------------------------------------| | TASKS_STOP | 0x014 | Stop TWI transaction | | TASKS_SUSPEND | 0x01C | Suspend TWI transaction | | TASKS_RESUME | 0x020 | Resume TWI transaction | | TASKS_PREPARERX | 0x030 | Prepare the TWI slave to respond to a write command | | TASKS_PREPARETX | 0x034 | Prepare the TWI slave to respond to a read command | | EVENTS_STOPPED | 0x104 | TWI stopped | | EVENTS_ERROR | 0x124 | TWI error | | EVENTS_RXSTARTED | 0x14C | Receive sequence started | | EVENTS_TXSTARTED | 0x150 | Transmit sequence started | | EVENTS_WRITE | 0x164 | Write command received | | EVENTS_READ | 0x168 | Read command received | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTEN | 0x300 | Enable or disable interrupt | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | ERRORSRC | 0x4D0 | Error source | | MATCH | 0x4D4 | Status register indicating which address had a match | | ENABLE | 0x500 | Enable TWIS | | PSEL.SCL | 0x508 | Pin select for SCL signal | | PSEL.SDA | 0x50C | Pin select for SDA signal | | RXD.PTR | 0x534 | RXD Data pointer | | RXD.MAXCNT | 0x538 | Maximum number of bytes in RXD buffer | | RXD.AMOUNT | 0x53C | Number of bytes transferred in the last RXD transaction | | RXD.LIST | 0x540 | EasyDMA list type | | TXD.PTR | 0x544 | TXD Data pointer | | TXD.MAXCNT | 0x548 | Maximum number of bytes in TXD buffer | | TXD.AMOUNT | 0x54C | Number of bytes transferred in the last TXD transaction | | TXD.LIST | 0x550 | EasyDMA list type | | ADDRESS[0] | 0x588 | TWI slave address 0 | | ADDRESS[1] | 0x58C | TWI slave address 1 | | CONFIG | 0x594 | Configuration register for the address match mechanism | | ORC | 0x5C0 | Over-read character. Character sent out in case of an over-read of the transmit buffer. | | | | | Table 91: Register overview # 6.22.8.1 TASKS\_STOP Address offset: 0x014 Stop TWI transaction | Bit n | umb | er | | 31 30 29 28 27 26 25 2 | 24 : | 23 2 | 2 2 | 21 2 | 0 1 | 9 1 | 8 1 | 7 16 | 5 15 | 5 14 | 13 | 12 | 11 : | 10 ! | 9 | 8 | 7 | 6 | 5 4 | 1 3 | 3 2 | 1 | 0 | |-------|------|------------|---------|------------------------|------|------|-----|------|------|------|------|------|------|------|----|----|------|------|---|---|---|---|-----|-----|-----|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t Ox | 00000000 | | 0 0 0 0 0 0 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 | 0 | 0 | | ID | | | | | | Des | | | | | | | | | | | | | | | | | | | | | | | Α | W | TASKS_STOP | | | | Stop | T۱ | WI 1 | trar | ısad | ctio | n | | | | | | | | | | | | | | | | | | | | Trigger | 1 | | Trig | ger | tas | sk | | | | | | | | | | | | | | | | | | | #### 6.22.8.2 TASKS\_SUSPEND Address offset: 0x01C Suspend TWI transaction | Bit n | umber | | 31 30 29 28 27 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|---------|----------------|-----------------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_SUSPEND | | | Suspend TWI transaction | | | | Trigger | 1 | Trigger task | # 6.22.8.3 TASKS\_RESUME Address offset: 0x020 Resume TWI transaction #### 6.22.8.4 TASKS PREPARERX Address offset: 0x030 Prepare the TWI slave to respond to a write command | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------------|---------|-------------------------|-----------------------------------------------------------------| | ID | | | | А | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | W TASKS_PREPARERX | | | Prepare the TWI slave to respond to a write command | | | | Trigger | 1 | Trigger task | #### 6.22.8.5 TASKS\_PREPARETX Address offset: 0x034 4454\_187 v0.5 Prepare the TWI slave to respond to a read command 286 NORDIC\* | Bit n | um | be | r | | 31 30 | 29 | 28 2 | 7 26 | 25 | 24 : | 23 2 | 2 2 | 21 2 | 0 19 | 18 | 17 : | 16 1 | .5 1 | .4 1 | 3 12 | 2 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | . 0 | |-------|------|-----|-----------------|---------|-------|----|------|------|----|------|-------|-----|------|------|-------|------|------|------|------|------|------|-----|------|----|-----|----|---|---|-----|-----|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | et O | x0( | 000000 | | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 ( | 0 | 0 0 | 0 | 0 | 0 | 0 ( | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | ID | | | | | | | | | | | Desc | | | | | | | | | | | | | | | | | | | | | | Α | ٧ | ٧ | TASKS_PREPARETX | | | | | | | ı | Prep | oar | e th | e TV | VI sl | ave | to | res | pon | d to | a r | eac | l co | mn | nan | ıd | | | | | | | | | | | Trigger | 1 | | | | | | Trigg | ger | tas | k | | | | | | | | | | | | | | | | | | #### 6.22.8.6 EVENTS\_STOPPED Address offset: 0x104 TWI stopped | Bit ni | ımber | | 31 30 29 28 | 27 26 | 25 24 | 23 2 | 2 21 | 20 1 | 19 18 | 17 | 16 1 | 5 14 | 113 | 12 1 | .1 10 | 9 | 8 | 7 | 6 5 | 5 4 | 3 | 2 | 1 0 | |--------|-------------------|--------------|-------------|-------|-------|------|--------|-------|-------|-----|------|------|-----|------|-------|---|---|---|-----|-----|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t 0x00000000 | | 0 0 0 0 | 0 0 | 0 0 | 0 ( | 0 0 | 0 | 0 0 | 0 | 0 ( | ) 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 0 | | ID | | | | | | Desi | sripti | or | • | | | | | | | | | | | | | | | | Α | RW EVENTS_STOPPED | | | | | TWI | stop | ped | | | | | | | | | | | | | | | | | | | NotGenerated | 0 | | | Ever | nt no | t gei | nerat | ted | | | | | | | | | | | | | | | | | Generated | 1 | | | Ever | nt gei | nera | ted | | | | • | | | | | | | | | | | # 6.22.8.7 EVENTS\_ERROR Address offset: 0x124 TWI error #### 6.22.8.8 EVENTS RXSTARTED Address offset: 0x14C Receive sequence started | Bit number | | 31 30 2 | 29 28 3 | 27 2 | 6 25 | 24 | 23 22 | 2 21 | 20 : | 19 1 | 8 17 | <sup>7</sup> 16 | 15 | 14 1 | L3 12 | 2 11 | 10 | 9 8 | 3 7 | 6 | 5 | 4 | 3 2 | 1 0 | |-----------------------|-------------|---------|---------|------|------|----|-------|-------|------|------|------|-----------------|----|------|-------|------|----|-----|-----|---|---|---|-----|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | | А | | Reset 0x00000000 | | 0 0 | 0 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 0 | 0 0 | | ID Acce Field Va | | | | | | | Desc | | | | | | | | | | | | | | | | | | | A RW EVENTS_RXSTARTED | | | | | | | Rece | ive s | equ | ienc | e st | arte | d | | | | | | | | | | | | | No | otGenerated | 0 | | | | | Even | t no | t ge | nera | ted | | | | | | | | | | | | | | | Ge | enerated | 1 | | | | | Even | t ger | nera | ited | | | | | | | | | | | | | | | ## 6.22.8.9 EVENTS\_TXSTARTED Address offset: 0x150 Transmit sequence started | Bit num | ber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------|--------------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | | А | | Reset 0 | x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID A | | | | Description | | A R | W EVENTS_TXSTARTED | | | Transmit sequence started | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | # 6.22.8.10 EVENTS\_WRITE Address offset: 0x164 Write command received | Bit nu | mber | | 31 30 29 2 | 3 27 26 2 | 5 24 2 | 23 22 : | 21 20 | 19 1 | 8 17 | 16 19 | 5 14 1 | 3 12 | 11 1 | 0 9 | 8 | 7 6 | 5 | 4 | 3 2 | 2 1 | 0 | |--------|-----------------|--------------|------------|-----------|--------|---------|--------|-------|------|-------|--------|------|------|-----|-----|-----|---|---|-----|-----|---| | ID | | | | | | | | | | | | | | | | | | | | | Α | | Reset | 0x00000000 | | 0 0 0 0 | 00 | 0 0 | 0_0 | 0 0 | 0 ( | 0 0 | 0 0 | 0 ( | 0 0 | 0 ( | 0 | 0 ( | 0 | 0 | 0 | 0 ( | 0 0 | 0 | | ID | | | | | 1 | Descri | ption | | | / | | | | | | | | | | | | | Α | RW EVENTS_WRITE | | | | 1 | Write | comm | nand | rece | ived | | | | | | | | | | | | | | | NotGenerated | 0 | | | Event | not ge | enera | ated | | | | | | | | | | | | | | | | Generated | 1 | | i | Event | gener | ated | | | | | | | | | | | | | | # 6.22.8.11 EVENTS\_READ Address offset: 0x168 Read command received #### 6.22.8.12 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit r | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|------------------|----------|-------------------------|-----------------------------------------------------------------| | ID | | | | B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW WRITE_SUSPEND | | | Shortcut between event WRITE and task SUSPEND | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | | В | RW READ_SUSPEND | | | Shortcut between event READ and task SUSPEND | | | | Disabled | 0 | Disable shortcut | | | | Enabled | 1 | Enable shortcut | ## 6.22.8.13 INTEN Address offset: 0x300 Enable or disable interrupt | Bit n | umber | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | . 0 | |-------|---------------|----------|----------------|----------------------------------------------------------------------|-----| | ID | | | | HG FE B A | | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | ID | | | | | | | Α | RW STOPPED | | | Enable or disable interrupt for event STOPPED | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | | В | RW ERROR | | | Enable or disable interrupt for event ERROR | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | | Е | RW RXSTARTED | | | Enable or disable interrupt for event RXSTARTED | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | | F | RW TXSTARTED | | | Enable or disable interrupt for event TXSTARTED | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | | G | RW WRITE | | | Enable or disable interrupt for event WRITE | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | | Н | RW READ | | | Enable or disable interrupt for event READ | | | | | Disabled | 0 | Disable | | | | | Enabled | 1 | Enable | | ## 6.22.8.14 INTENSET Address offset: 0x304 Enable interrupt | | | _ | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |-------|---------------|----------|---|-----|------|------|------|----|----|----|-----|-------|------|------|------|------|------|-----|----|------|------|-------|------|------|---|---|---|-----|-----|---|---| | Bit r | number | | | 313 | 0 29 | 9 28 | 3 27 | 26 | 25 | 24 | 23 | 22 2 | 21 2 | 0 1 | 9 18 | 17 | 16 | 15 | 14 | 13 1 | L2 1 | 11 10 | 9 | 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 | | ID | | | | | | | | Н | G | | | | | F E | | | | | | | | | В | | | | | | | Α | | | Res | et 0x00000000 | | | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | ID | | Value ID | , | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW STOPPED | | | | | | | | | | Wr | ite ' | 1' t | o er | abl | e in | teri | upt | fo | r ev | ent | STO | OPP | ED | | | | | | | | | | | Set | : | 1 | | | | | | | Ena | able | | | | | | | | | | | | | | | | | | | | | | | Disabled | ( | 0 | | | | | | | Rea | ad: [ | Disa | ble | d | | | | | | | | | | | | | | | | | | | | Enabled | : | 1 | | | | | | | Rea | ad: I | Ena | bled | i | | | | | | | | | | | | | | | | | | В | RW ERROR | | | | | | | | | | Wr | ite ' | 1' t | o er | abl | e in | teri | upt | fo | r ev | ent | ERI | ROR | | | | | | | | | | | | Set | : | 1 | | | | | | | Ena | able | | | | | | | | | | | | | | | | | | | | | | | Disabled | ( | 0 | | | | | | | Rea | ad: [ | Disa | ble | d | | | | | | | | | | | | | | | | | | | | Enabled | : | 1 | | | | | | | Rea | ad: I | Ena | bled | i | | | | | | | | | | | | | | | | | | E | RW RXSTARTED | | | | | | | | | | Wr | ite ' | 1' t | o er | abl | e in | teri | upt | fo | r ev | ent | RX | STAI | RTE | D | | | | | | | | | | Set | : | 1 | | | | | | | Ena | able | | | | | | | | | | | | | | | | | | | | | | | Disabled | ( | 0 | | | | | | | Rea | ad: [ | Disa | ble | d | | | | | | | | | | | | | | | | | | | | Enabled | : | 1 | | | | | | | Rea | ad: I | Ena | bled | i | | | | | | | | | | | | | | | | | | F | RW TXSTARTED | | | | | | | | | | Wr | ite ' | 1' t | o er | abl | e in | teri | upt | fo | r ev | ent | TXS | STAF | RTEI | 0 | | | | | | | | | | Set | : | 1 | | | | | | | Ena | able | | | | | | | | | | | | | | | | | | | | | | | Disabled | ( | 0 | | | | | | | Rea | ad: [ | Disa | ble | d | | | | | | | | | | | | | | | | | | | | Enabled | | 1 | | | | | | | Rea | ad: I | Ena | bled | ł | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bit number | | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|------------------------|------------------------------------------------------------------| | ID | | H G | F E B A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | G RW WRITE | | | Write '1' to enable interrupt for event WRITE | | | Set | 1 | Enable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | | H RW READ | | | Write '1' to enable interrupt for event READ | | | Set | 1 | Enable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | #### 6.22.8.15 INTENCLR Address offset: 0x308 #### 6.22.8.16 ERRORSRC Address offset: 0x4D0 Error source | Bit r | umber | | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|-------------|------------------------|------------------------------------------------------------------| | ID | | | | СВА | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW OVERFLOW | | | RX buffer overflow detected, and prevented | | | | NotDetected | 0 | Error did not occur | | | | Detected | 1 | Error occurred | | В | RW DNACK | | | NACK sent after receiving a data byte | | | | NotReceived | 0 | Error did not occur | | | | Received | 1 | Error occurred | | С | RW OVERREAD | | | TX buffer over-read detected, and prevented | | | | NotDetected | 0 | Error did not occur | | | | Detected | 1 | Error occurred | #### 6.22.8.17 MATCH Address offset: 0x4D4 Status register indicating which address had a match #### 6.22.8.18 ENABLE Address offset: 0x500 **Enable TWIS** #### 6.22.8.19 PSEL.SCL Address offset: 0x508 Pin select for SCL signal | Bit no | umber | | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|--------------|--------------|---------------------|---------------------------------------------------------------------| | ID | | | С | АААА | | Rese | t OxFFFFFFFF | | 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.22.8.20 PSEL.SDA Address offset: 0x50C Pin select for SDA signal | Bit no | umber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|--------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | С | АААА | | Rese | t OxFFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | Description | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.22.8.21 RXD.PTR Address offset: 0x534 **RXD** Data pointer **Note:** See the memory chapter for details about which memories are available for EasyDMA. #### 6.22.8.22 RXD.MAXCNT Address offset: 0x538 Maximum number of bytes in RXD buffer #### 6.22.8.23 RXD.AMOUNT Address offset: 0x53C Number of bytes transferred in the last RXD transaction #### 6.22.8.24 RXD.LIST Address offset: 0x540 EasyDMA list type | Bit num | ber | | 31 30 29 | 28 27 | 26 25 | 24 2 | 3 22 | 21 2 | 0 19 | 18 1 | 7 16 | 15 3 | 14 13 | 3 12 1 | 11 10 | 9 | 8 | 7 6 | 5 5 | 4 | 3 | 2 | 1 0 | |---------|-----------|-----------|----------|-------|-------|------|--------|--------|------|---------|------|------|-------|--------|-------|---|---|-----|-----|---|---|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | | | A A | | Reset 0 | x00000000 | | 0 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 0 | | ID A | | | | | | | | | | | | | | | | | | | | | | | | | A R | W LIST | | | | | L | ist ty | pe | | | | | | | | | | | | | | | | | | | Disabled | 0 | | | | Disabl | le Ea | syDN | //A lis | st | | | | | | | | | | | | | | | | ArrayList | 1 | | | ι | Jse a | rray l | ist | | | | | | | | | | | | | | | #### 6.22.8.25 TXD.PTR Address offset: 0x544 TXD Data pointer ## 6.22.8.26 TXD.MAXCNT Address offset: 0x548 Maximum number of bytes in TXD buffer #### 6.22.8.27 TXD.AMOUNT Address offset: 0x54C Number of bytes transferred in the last TXD transaction | Α | R AMOUNT | [10x3FFF] | Number of bytes to | ransferred | in the | last TX | (D tr | ans | acti | on | | | | _ | |--------|------------|-------------------------|---------------------|-------------|--------|---------|-------|-----|------|-----|---|-----|-----|---| | ID | | | | | | | | | | | | | | | | Reset | 0x00000000 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 | 0 0 0 0 | 0 0 | 0 0 | 0 | 0 | 0 ( | 0 | 0 | 0 0 | 0 | 0 | | ID | | | | | A A | A A A | A | Α . | A A | A | Α | ΑА | A A | Α | | Bit nu | mber | 31 30 29 28 27 26 25 24 | 1 23 22 21 20 19 18 | 17 16 15 14 | 1 13 1 | 2 11 10 | 9 | 8 | 7 6 | 5 5 | 4 | 3 2 | 1 | 0 | | | | | | | | | | | | | | | | | #### 6.22.8.28 TXD.LIST Address offset: 0x550 EasyDMA list type ## 6.22.8.29 ADDRESS[n] (n=0..1) Address offset: $0x588 + (n \times 0x4)$ TWI slave address n #### 6.22.8.30 CONFIG Address offset: 0x594 Configuration register for the address match mechanism #### 6.22.8.31 ORC Address offset: 0x5C0 Over-read character. Character sent out in case of an over-read of the transmit buffer. ## 6.22.9 Electrical specification ## 6.22.9.1 TWIS slave timing specifications | Symbol | Description | Min. | Typ. N | lax. Units | |-------------------------------------------------|-----------------------------------------------------------|------|--------|------------| | f <sub>TWIS,SCL</sub> | Bit rates for TWIS <sup>31</sup> | 100 | 4 | 00 kbps | | t <sub>TWIS,START</sub> | Time from PREPARERX/PREPARETX task to ready to receive/ | | 1.5 | μs | | | transmit | | | | | $t_{TWIS,SU\_DAT}$ | Data setup time before positive edge on SCL – all modes | 300 | | ns | | t <sub>TWIS,HD_DAT</sub> | Data hold time after negative edge on SCL – all modes | 500 | | ns | | $t_{\text{TWIS},\text{HD\_STA},100\text{kbps}}$ | TWI slave hold time from for START condition (SDA low to | 5200 | | ns | | | SCL low), 100 kbps | | | | | $t_{\text{TWIS},\text{HD\_STA},400\text{kbps}}$ | TWI slave hold time from for START condition (SDA low to | 1300 | | ns | | | SCL low), 400 kbps | | | | | $t_{TWIS,SU\_STO,100kbps}$ | TWI slave setup time from SCL high to STOP condition, 100 | 5200 | | ns | | | kbps | | | | | t <sub>TWIS,SU_STO,400kbps</sub> | TWI slave setup time from SCL high to STOP condition, 400 | 1300 | | ns | | | kbps | | | | | t <sub>TWIS,BUF,100kbps</sub> | TWI slave bus free time between STOP and START | | 4700 | ns | | | conditions, 100 kbps | | | | | t <sub>TWIS,BUF,400kbps</sub> | TWI slave bus free time between STOP and START | | 1300 | ns | | | conditions, 400 kbps | | | | Figure 108: TWIS timing diagram, 1 byte transaction ## 6.23 UART — Universal asynchronous receiver/transmitter Figure 109: UART configuration NORDIC High bit rates or stronger pull-ups may require GPIOs to be set as High Drive, see GPIO chapter for more details. ## 6.23.1 Functional description Listed here are the main features of UART. The UART implements support for the following features: - Full-duplex operation - Automatic flow control - Parity checking and generation for the 9<sup>th</sup> data bit As illustrated in UART configuration on page 295, the UART uses the TXD and RXD registers directly to transmit and receive data. The UART uses one stop bit. **Note:** External crystal oscillator must be enabled to obtain sufficient clock accuracy for stable communication. See CLOCK — Clock control on page 60 for more information. #### 6.23.2 Pin configuration The different signals RXD, CTS (Clear To Send, active low), RTS (Request To Send, active low), and TXD associated with the UART are mapped to physical pins according to the configuration specified in the PSEL.RXD, PSEL.CTS, PSEL.RTS, and PSEL.TXD registers respectively. If the CONNECT field of a PSEL.xxx register is set to Disconnected, the associated UART signal will not be connected to any physical pin. The PSEL.RXD, PSEL.CTS, PSEL.RTS, and PSEL.TXD registers and their configurations are only used as long as the UART is enabled, and retained only for the duration the device is in ON mode. PSEL.RXD, PSEL.CTS, PSEL.RTS and PSEL.TXD must only be configured when the UART is disabled. To secure correct signal levels on the pins by the UART when the system is in OFF mode, the pins must be configured in the GPIO peripheral as described in Pin configuration on page 296. Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior. | UART pin | Direction | Output value | |----------|-----------|----------------| | RXD | Input | Not applicable | | CTS | Input | Not applicable | | RTS | Output | 1 | | TXD | Output | 1 | Table 92: GPIO configuration #### 6.23.3 Shared resources The UART shares registers and other resources with other peripherals that have the same ID as the UART. Therefore, you must disable all peripherals that have the same ID as the UART before the UART can be configured and used. Disabling a peripheral that has the same ID as the UART will not reset any of the registers that are shared with the UART. It is therefore important to configure all relevant UART registers explicitly to ensure that it operates correctly. See the Instantiation table in Instantiation on page 17 for details on peripherals and their IDs. #### 6.23.4 Transmission A UART transmission sequence is started by triggering the STARTTX task. Bytes are transmitted by writing to the TXD register. When a byte has been successfully transmitted the UART will generate a TXDRDY event after which a new byte can be written to the TXD register. A UART transmission sequence is stopped immediately by triggering the STOPTX task. If flow control is enabled a transmission will be automatically suspended when CTS is deactivated and resumed when CTS is activated again, as illustrated in UART transmission on page 297. A byte that is in transmission when CTS is deactivated will be fully transmitted before the transmission is suspended. For more information, see Suspending the UART on page 298. Figure 110: UART transmission #### 6.23.5 Reception A UART reception sequence is started by triggering the STARTRX task. The UART receiver chain implements a FIFO capable of storing six incoming RXD bytes before data is overwritten. Bytes are extracted from this FIFO by reading the RXD register. When a byte is extracted from the FIFO a new byte pending in the FIFO will be moved to the RXD register. The UART will generate an RXDRDY event every time a new byte is moved to the RXD register. When flow control is enabled, the UART will deactivate the RTS signal when there is only space for four more bytes in the receiver FIFO. The counterpart transmitter is therefore able to send up to four bytes after the RTS signal is deactivated before data is being overwritten. To prevent overwriting data in the FIFO, the counterpart UART transmitter must therefore make sure to stop transmitting data within four bytes after the RTS line is deactivated. The RTS signal will first be activated again when the FIFO has been emptied, that is, when all bytes in the FIFO have been read by the CPU, see UART reception on page 298. The RTS signal will also be deactivated when the receiver is stopped through the STOPRX task as illustrated in UART reception on page 298. The UART is able to receive four to five additional bytes if they are sent in succession immediately after the RTS signal has been deactivated. This is possible because the UART is, even after the STOPRX task is triggered, able to receive bytes for an extended period of time dependent on the configured baud rate. The UART will generate a receiver timeout event (RXTO) when this period has elapsed. To prevent loss of incoming data the RXD register must only be read one time following every RXDRDY event. To secure that the CPU can detect all incoming RXDRDY events through the RXDRDY event register, the RXDRDY event register must be cleared before the RXD register is read. The reason for this is that the UART is allowed to write a new byte to the RXD register, and therefore can also generate a new event, immediately after the RXD register is read (emptied) by the CPU. Figure 111: UART reception As indicated in occurrence 2 in the figure, the RXDRDY event associated with byte B is generated first after byte A has been extracted from RXD. ## 6.23.6 Suspending the UART The UART can be suspended by triggering the SUSPEND task. SUSPEND will affect both the UART receiver and the UART transmitter, i.e. the transmitter will stop transmitting and the receiver will stop receiving. UART transmission and reception can be resumed, after being suspended, by triggering STARTTX and STARTRX respectively. Following a SUSPEND task, an ongoing TXD byte transmission will be completed before the UART is suspended. When the SUSPEND task is triggered, the UART receiver will behave in the same way as it does when the STOPRX task is triggered. ## 6.23.7 Error conditions An ERROR event, in the form of a framing error, will be generated if a valid stop bit is not detected in a frame. Another ERROR event, in the form of a break condition, will be generated if the RXD line is held active low for longer than the length of a data frame. Effectively, a framing error is always generated before a break condition occurs. ## 6.23.8 Using the UART without flow control If flow control is not enabled, the interface will behave as if the CTS and RTS lines are kept active all the time. ## 6.23.9 Parity and stop bit configuration Automatic even parity generation for both transmission and reception can be configured using the register CONFIG on page 307. See the register description for details. The amount of stop bits can also be configurated through the register CONFIG on page 307. ## 6.23.10 Registers | Base address | Peripheral | Instance | Description | Configuration | | |--------------|------------|----------|----------------------------------|---------------|------------| | 0x40002000 | UART | UART0 | Universal asynchronous receiver/ | | Deprecated | | | | | transmitter | | | Table 93: Instances | Register | Offset | Description | |---------------|--------|-----------------------------------------------------------| | TASKS_STARTRX | 0x000 | Start UART receiver | | TASKS_STOPRX | 0x004 | Stop UART receiver | | TASKS_STARTTX | 0x008 | Start UART transmitter | | TASKS_STOPTX | 0x00C | Stop UART transmitter | | TASKS_SUSPEND | 0x01C | Suspend UART | | EVENTS_CTS | 0x100 | CTS is activated (set low). Clear To Send. | | EVENTS_NCTS | 0x104 | CTS is deactivated (set high). Not Clear To Send. | | EVENTS_RXDRDY | 0x108 | Data received in RXD | | EVENTS_TXDRDY | 0x11C | Data sent from TXD | | EVENTS_ERROR | 0x124 | Error detected | | EVENTS_RXTO | 0x144 | Receiver timeout | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | ERRORSRC | 0x480 | Error source | | ENABLE | 0x500 | Enable UART | | PSEL.RTS | 0x508 | Pin select for RTS | | PSEL.TXD | 0x50C | Pin select for TXD | | PSEL.CTS | 0x510 | Pin select for CTS | | PSEL.RXD | 0x514 | Pin select for RXD | | RXD | 0x518 | RXD register | | TXD | 0x51C | TXD register | | BAUDRATE | 0x524 | Baud rate. Accuracy depends on the HFCLK source selected. | | CONFIG | 0x56C | Configuration of parity and hardware flow control | | | | | Table 94: Register overview ## 6.23.10.1 TASKS\_STARTRX Address offset: 0x000 Start UART receiver ## 6.23.10.2 TASKS\_STOPRX Address offset: 0x004 Stop UART receiver | Bit nu | umber | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|----------------|---------|-------------------|---------------------------------------------------------------------| | ID | | | | A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | W TASKS_STOPRX | | | Stop UART receiver | | | | Trigger | 1 | Trigger task | ## 6.23.10.3 TASKS\_STARTTX Address offset: 0x008 Start UART transmitter | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|---------|-------------------------|-----------------------------------------------------------------| | ID | | | | A | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | W TASKS_STARTTX | | | Start UART transmitter | | | | Trigger | 1 | Trigger task | #### 6.23.10.4 TASKS STOPTX Address offset: 0x00C Stop UART transmitter #### 6.23.10.5 TASKS SUSPEND Address offset: 0x01C Suspend UART ## 6.23.10.6 EVENTS\_CTS Address offset: 0x100 CTS is activated (set low). Clear To Send. ## 6.23.10.7 EVENTS\_NCTS Address offset: 0x104 CTS is deactivated (set high). Not Clear To Send. | Bit n | umber | | 31 | 30 | 29 2 | 28 2 | 7 26 | 5 25 | 24 | 23 | 22 | 21 | 20 | 19 1 | .8 1 | 7 1 | 5 15 | 14 | 13 | 12 1 | 11 1 | .0 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 2 1 | 0 | |-------|----------------|--------------|----|----|------|------|------|------|----|-----|------|-----|------|-------|------|-----|------|-------|-----|------|------|------|-----|---|---|---|---|-----|-----|---| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | t 0x00000000 | | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW EVENTS_NCTS | | | | | | | | | CT | S is | dea | acti | ivate | ed ( | set | higł | n). N | Vot | Clea | ır T | Se | nd. | | | | | | | | | | | NotGenerated | 0 | | | | | | | Eve | ent | not | ge | ner | ate | d | | | | | | | | | | | | | | | | | | Generated | 1 | | | | | | | Eve | ent | gen | nera | ated | l | | | | | | | | | | | | | | | | #### 6.23.10.8 EVENTS\_RXDRDY Address offset: 0x108 Data received in RXD #### **6.23.10.9 EVENTS TXDRDY** Address offset: 0x11C Data sent from TXD #### 6.23.10.10 EVENTS\_ERROR Address offset: 0x124 Error detected | Bit number | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------------|-------------------|---------------------------------------------------------------------| | ID | | А | | Reset 0x00000000 | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field Value ID | | | | A RW EVENTS_ERROR | | Error detected | | NotGenerated | 0 | Event not generated | | Generated | 1 | Event generated | ## 6.23.10.11 EVENTS\_RXTO Address offset: 0x144 Receiver timeout #### 6.23.10.12 SHORTS Address offset: 0x200 Shortcuts between local events and tasks ## 6.23.10.13 INTENSET Address offset: 0x304 **Enable interrupt** | Bit number | 31 | 30 29 28 27 26 | 25 24 | 23 22 21 : | 20 19 18 | 17 16 | 5 15 1 | 4 13 1 | 2 11 10 | 9 | 8 7 | 6 | 5 4 | 3 | 2 : | L 0 | |--------------------|----------|----------------|-------|------------|-----------|--------|--------|---------|---------|------|-----|---|-----|---|-----|-----| | ID | | | | | | F | | | | Е | D | | | | C E | 3 A | | Reset 0x00000000 | 0 | 0 0 0 0 0 | 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 ( | 0 | | ID Acce Field Valu | ue ID Va | | | | | | | | | | | | | | | | | A RW CTS | | | | Write '1' | to enable | e inte | rupt | for eve | ent CTS | | | | | | | | | Set | 1 | | | Enable | | | | | | | | | | | | | | Disa | abled 0 | | | Read: Dis | abled | | | | | | | | | | | | | Ena | abled 1 | | | Read: Ena | abled | | | | | | | | | | | | | B RW NCTS | | | | Write '1' | to enable | e inte | rupt | for eve | ent NC | ΓS | | | | | | | | Set | 1 | | | Enable | | | | | | | | | | | | | | Disa | abled 0 | | | Read: Dis | abled | | | | | | | | | | | | | Ena | abled 1 | | | Read: Ena | abled | | | | | | | | | | | | | C RW RXDRDY | | | | Write '1' | to enable | e inte | rupt | for eve | ent RXD | ORDY | | | | | | | | Set | 1 | | | Enable | | | | | | | | | | | | | | Disa | abled 0 | | | Read: Dis | abled | | | | | | | | | | | | | Ena | abled 1 | | | Read: Ena | abled | | | | | | | | | | | | | D RW TXDRDY | | | | Write '1' | to enable | e inte | rupt | for eve | ent TXD | RDY | | | | | | | | Set | 1 | | | Enable | | | | | | | | | | | | | | Bit number | | 21 20 20 20 2 | 7 26 25 24 | 22 22 21 20 | 10 10 | 2 1 7 | 101 | 1 - 1 | 112 | 12.11 | 10 | 0 | 0 | 7 ( | ~ F | 4 | 3 | 2 | 1 0 | |-----------------|----------|----------------|------------|--------------|---------|-------|-------|-------|-------|-------|------|----|---|-----|-----|---|---|---|-----| | Bit number | | 31 30 29 28 27 | 7 26 25 24 | 23 22 21 20 | ) 19 18 | | 16 1 | 15 1 | 4 13 | 12 1. | 1 10 | | | | 5 | 4 | | 2 | 1 0 | | ID | | | | | | F | | | | | | Ε | | D | | | | С | ВА | | Reset 0x0000000 | 0 | 0 0 0 0 0 | 0 0 0 | 0 0 0 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | 0 | 0 0 | | ID Acce Field | | | | | | | | | | | | | | | | | | | | | | Disabled | 0 | | Read: Disab | oled | | | | | | | | | | | | | | | | | Enabled | 1 | | Read: Enab | led | | | | | | | | | | | | | | | | E RW ERROF | R | | | Write '1' to | enab | le in | terrı | upt 1 | for e | vent | ERR | OR | | | | | | | | | | Set | 1 | | Enable | | | | | | | | | | | | | | | | | | Disabled | 0 | | Read: Disab | oled | | | | | | | | | | | | | | | | | Enabled | 1 | | Read: Enab | led | | | | | | | | | | | | | | | | F RW RXTO | | | | Write '1' to | enab | le in | terrı | upt 1 | for e | vent | RXT | 0 | | | | | | | | | | Set | 1 | | Enable | | | | | | | | | | | | | | | | | | Disabled | 0 | | Read: Disab | oled | | | | | | | | | | | | | | | | | Enabled | 1 | | Read: Enab | led < | | | | | | | | | | | | | | | #### 6.23.10.14 INTENCLR Address offset: 0x308 Disable interrupt #### 6.23.10.15 ERRORSRC Address offset: 0x480 Error source | Bit r | number | | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|------------|------------------------|------------------------------------------------------------------| | ID | | | | D C B A | | Res | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW OVERRUN | | | Overrun error | | | | | | A start bit is received while the previous data still lies in | | | | | | RXD. (Previous data is lost.) | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | В | RW PARITY | | | Parity error | | | | | | A character with bad parity is received, if HW parity check is | | | | | | enabled. | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | С | RW FRAMING | | | Framing error occurred | | | | | | A valid stop bit is not detected on the serial data input after | | | | | | all bits in a character have been received. | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | D | RW BREAK | | | Break condition | | | | | | The serial data input is '0' for longer than the length of a | | | | | | data frame. (The data frame length is 10 bits without parity | | | | | | bit, and 11 bits with parity bit.). | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | | | | | | ## 6.23.10.16 ENABLE Address offset: 0x500 **Enable UART** | Bit n | umber | | 31 30 29 2 | 8 27 26 2 | 5 24 | 23 22 | 21 20 | 0 19 1 | 18 17 | 7 16 | 15 1 | 14 13 | 3 12 | 11 1 | .0 9 | 8 | 7 | 6 | 5 4 | . 3 | 2 | 1 0 | |-------|---------------|----------|------------|-----------|------|-------|---------|--------|-------|------|------|-------|------|------|------|---|---|---|-----|-----|---|-----| | ID | | | | | | | | | | | | | | | | | | | | Α | Α | A A | | Rese | et 0x00000000 | | 0 0 0 0 | 000 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 | | ID | | Value ID | Value | | | | | | | | | | | | | | | | | | | | | Α | RW ENABLE | | | | | Enabl | le or o | lisabl | le UA | ART | | | | | | | | | | | | | | | | Disabled | 0 | | | Disab | le UA | RT | | | | | | | | | | | | | | | | | | Enabled | 4 | | | Enabl | le UAI | RT | | | | | | | | | | | | | | | ## 6.23.10.17 PSEL.RTS Address offset: 0x508 Pin select for RTS | Bit nı | umber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|-------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | C | A A A A A | | Rese | t OxFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.23.10.18 PSEL.TXD Address offset: 0x50C Pin select for TXD | Bit n | umber | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 | 18 17 16 15 1 | 4 13 12 11 10 | 9876 | 5 5 4 | 4 3 | 2 1 0 | |-------|--------------|--------------|----------------|-------------------------|---------------|---------------|---------|-------|-------|-------| | ID | | | С | <b>A</b> | | | | A | A A . | A A A | | Rese | et OxFFFFFFF | | 1 1 1 1 1 | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 | 1111 | 1 1 1 1 | . 1 1 | 1 1 | 1 1 1 | | ID | | | | Description | | | | | | | | Α | RW PIN | | [031] | Pin number | | | | | | | | С | RW CONNECT | | | Connection | | | | | | | | | | Disconnected | 1 | Disconnect | | | | | | | | | | Connected | 0 | Connect | | | | | | | #### 6.23.10.19 PSEL.CTS Address offset: 0x510 Pin select for CTS #### 6.23.10.20 PSEL.RXD Address offset: 0x514 Pin select for RXD | Bit n | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | С | АААА | | Rese | t OxFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | | | | #### 6.23.10.21 RXD Address offset: 0x518 **RXD** register #### 6.23.10.22 TXD Address offset: 0x51C TXD register . #### 6.23.10.23 BAUDRATE Address offset: 0x524 Baud rate. Accuracy depends on the HFCLK source selected. | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|------------|------------------------|-----------------------------------------------------------------| | ID | | AAAAAAA | | | Reset 0x04000000 | | 0 0 0 0 0 1 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | Value ID | Value | Description | | A RW BAUDRATE | | | Baud rate | | | Baud1200 | 0x0004F000 | 1200 baud (actual rate: 1205) | | | Baud2400 | 0x0009D000 | 2400 baud (actual rate: 2396) | | | Baud4800 | 0x0013B000 | 4800 baud (actual rate: 4808) | | | Baud9600 | 0x00275000 | 9600 baud (actual rate: 9598) | | | Baud14400 | 0x003B0000 | 14400 baud (actual rate: 14414) | | | Baud19200 | 0x004EA000 | 19200 baud (actual rate: 19208) | | | Baud28800 | 0x0075F000 | 28800 baud (actual rate: 28829) | | | Baud31250 | 0x00800000 | 31250 baud | | | Baud38400 | 0x009D5000 | 38400 baud (actual rate: 38462) | | | Baud56000 | 0x00E50000 | 56000 baud (actual rate: 55944) | | | Baud57600 | 0x00EBF000 | 57600 baud (actual rate: 57762) | | | Baud76800 | 0x013A9000 | 76800 baud (actual rate: 76923) | | | Baud115200 | 0x01D7E000 | 115200 baud (actual rate: 115942) | | | Baud230400 | 0x03AFB000 | 230400 baud (actual rate: 231884) | | | Baud250000 | 0x04000000 | 250000 baud | | | Baud460800 | 0x075F7000 | 460800 baud (actual rate: 470588) | | | Baud921600 | 0x0EBED000 | 921600 baud (actual rate: 941176) | | | Baud1M | 0x10000000 | 1Mega baud | | | | | | #### 6.23.10.24 CONFIG Address offset: 0x56C Configuration of parity and hardware flow control ## 6.23.11 Electrical specification ## 6.23.11.1 UART electrical specification | Symbol | Description | Min. | Тур. | Max. | Units | |-------------------------|--------------------------------------------------------|------|------|------|-------| | f <sub>UART</sub> | Baud rate for UART <sup>32</sup> . | | | 1000 | kbps | | t <sub>UART,CTSH</sub> | CTS high time | 1 | | | μs | | t <sub>UART,START</sub> | Time from STARTRX/STARTTX task to transmission started | | 1 | | μs | # 6.24 UARTE — Universal asynchronous receiver/transmitter with EasyDMA The Universal asynchronous receiver/transmitter with EasyDMA (UARTE) offers fast, full-duplex, asynchronous serial communication with built-in flow control (CTS, RTS) support in hardware at a rate up to 1 Mbps, and EasyDMA data transfer from/to RAM. Listed here are the main features for UARTE: - Full-duplex operation - Automatic hardware flow control - Optional even parity bit checking and generation - EasyDMA - Up to 1 Mbps baudrate - · Return to IDLE between transactions supported (when using HW flow control) - One or two stop bit - · Least significant bit (LSB) first High baud rates may require GPIOs to be set as High Drive, see GPIO chapter for more details. Figure 112: UARTE configuration, The GPIOs used for each UART interface can be chosen from any GPIO on the device and are independently configurable. This enables great flexibility in device pinout and efficient use of board space and signal routing. **Note:** External crystal oscillator must be enabled to obtain sufficient clock accuracy for stable communication. See CLOCK — Clock control on page 60 for more information. #### 6.24.1 EasyDMA The UARTE implements EasyDMA for reading and writing to and from the RAM. If the TXD.PTR and the RXD.PTR are not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 15 for more information about the different memory regions. The .PTR and .MAXCNT registers are double-buffered. They can be updated and prepared for the next RX/TX transmission immediately after having received the RXSTARTED/TXSTARTED event. The ENDRX/ENDTX event indicates that EasyDMA has finished accessing respectively the RX/TX buffer in RAM. #### 6.24.2 Transmission The first step of a DMA transmission is storing bytes in the transmit buffer and configuring EasyDMA. This is achieved by writing the initial address pointer to TXD.PTR, and the number of bytes in the RAM buffer to TXD.MAXCNT. The UARTE transmission is started by triggering the STARTTX task. After each byte has been sent over the TXD line, a TXDRDY event will be generated. When all bytes in the TXD buffer, as specified in the TXD.MAXCNT register, have been transmitted, the UARTE transmission will end automatically and an ENDTX event will be generated. A UARTE transmission sequence is stopped by triggering the STOPTX task, a TXSTOPPED event will be generated when the UARTE transmitter has stopped. If the ENDTX event has not already been generated when the UARTE transmitter has come to a stop, the UARTE will generate the ENDTX event explicitly even though all bytes in the TXD buffer, as specified in the TXD.MAXCNT register, have not been transmitted. If flow control is enabled through the HWFC field in the CONFIG register, a transmission will be automatically suspended when CTS is deactivated and resumed when CTS is activated again, as illustrated in UARTE transmission on page 309. A byte that is in transmission when CTS is deactivated will be fully transmitted before the transmission is suspended. Figure 113: UARTE transmission The UARTE transmitter will be in its lowest activity level, and consume the least amount of energy, when it is stopped, i.e. before it is started via STARTTX or after it has been stopped via STOPTX and the TXSTOPPED event has been generated. See POWER — Power supply on page 46 for more information about power modes. #### 6.24.3 Reception The UARTE receiver is started by triggering the STARTRX task. The UARTE receiver is using EasyDMA to store incoming data in an RX buffer in RAM. The RX buffer is located at the address specified in the RXD.PTR register. The RXD.PTR register is double-buffered and it can be updated and prepared for the next STARTRX task immediately after the RXSTARTED event is generated. The size of the RX buffer is specified in the RXD.MAXCNT register and the UARTE will generate an ENDRX event when it has filled up the RX buffer, see UARTE reception on page 310. For each byte received over the RXD line, an RXDRDY event will be generated. This event is likely to occur before the corresponding data has been transferred to Data RAM. The RXD.AMOUNT register can be queried following an ENDRX event to see how many new bytes have been transferred to the RX buffer in RAM since the previous ENDRX event. The UARTE receiver is stopped by triggering the STOPRX task. An RXTO event is generated when the UARTE has stopped. The UARTE will make sure that an impending ENDRX event will be generated before the RXTO event is generated. This means that the UARTE will guarantee that no ENDRX event will be generated after RXTO, unless the UARTE is restarted or a FLUSHRX command is issued after the RXTO event is generated. **Important:** If the ENDRX event has not already been generated when the UARTE receiver has come to a stop, which implies that all pending content in the RX FIFO has been moved to the RX buffer, the UARTE will generate the ENDRX event explicitly even though the RX buffer is not full. In this scenario the ENDRX event will be generated before the RXTO event is generated. To be able to know how many bytes have actually been received into the RX buffer, the CPU can read the RXD.AMOUNT register following the ENDRX event or the RXTO event. The UARTE is able to receive up to four bytes after the STOPRX task has been triggered as long as these are sent in succession immediately after the RTS signal is deactivated. This is possible because after the RTS is deactivated the UARTE is able to receive bytes for an extended period equal to the time it takes to send 4 bytes on the configured baud rate. After the RXTO event is generated the internal RX FIFO may still contain data, and to move this data to RAM the FLUSHRX task must be triggered. To make sure that this data does not overwrite data in the RX buffer, the RX buffer should be emptied or the RXD.PTR should be updated before the FLUSHRX task is triggered. To make sure that all data in the RX FIFO is moved to the RX buffer, the RXD.MAXCNT register must be set to RXD.MAXCNT > 4, see UARTE reception with forced stop via STOPRX on page 311. The UARTE will generate the ENDRX event after completing the FLUSHRX task even if the RX FIFO was empty or if the RX buffer does not get filled up. To be able to know how many bytes have actually been received into the RX buffer in this case, the CPU can read the RXD.AMOUNT register following the ENDRX event. Figure 115: UARTE reception with forced stop via STOPRX If HW flow control is enabled through the HWFC field in the CONFIG register, the RTS signal will be deactivated when the receiver is stopped via the STOPRX task or when the UARTE is only able to receive four more bytes in its internal RX FIFO. With flow control disabled, the UARTE will function in the same way as when the flow control is enabled except that the RTS line will not be used. This means that no signal will be generated when the UARTE has reached the point where it is only able to receive four more bytes in its internal RX FIFO. Data received when the internal RX FIFO is filled up, will be lost. The UARTE receiver will be in its lowest activity level, and consume the least amount of energy, when it is stopped, i.e. before it is started via STARTRX or after it has been stopped via STOPRX and the RXTO event has been generated. See POWER — Power supply on page 46 for more information about power modes. #### 6.24.4 Error conditions An ERROR event, in the form of a framing error, will be generated if a valid stop bit is not detected in a frame. Another ERROR event, in the form of a break condition, will be generated if the RXD line is held active low for longer than the length of a data frame. Effectively, a framing error is always generated before a break condition occurs. An ERROR event will not stop reception. If the error was a parity error, the received byte will still be transferred into Data RAM, and so will following incoming bytes. If there was a framing error (wrong stop bit), that specific byte will NOT be stored into Data RAM, but following incoming bytes will. ## 6.24.5 Using the UARTE without flow control If flow control is not enabled, the interface will behave as if the CTS and RTS lines are kept active all the time. ## 6.24.6 Parity and stop bit configuration Automatic even parity generation for both transmission and reception can be configured using the register CONFIG on page 325. See the register description for details. The amount of stop bits can also be configured through the register CONFIG on page 325. ## 6.24.7 Low power When putting the system in low power and the peripheral is not needed, lowest possible power consumption is achieved by stopping, and then disabling the peripheral. The STOPTX and STOPRX tasks may not be always needed (the peripheral might already be stopped), but if STOPTX and/or STOPRX is sent, software shall wait until the TXSTOPPED and/or RXTO event is received in response, before disabling the peripheral through the ENABLE register. ## 6.24.8 Pin configuration The different signals RXD, CTS (Clear To Send, active low), RTS (Request To Send, active low), and TXD associated with the UARTE are mapped to physical pins according to the configuration specified in the PSEL.RXD, PSEL.RTS, and PSEL.TXD registers respectively. The PSEL.RXD, PSEL.CTS, PSEL.RTS, and PSEL.TXD registers and their configurations are only used as long as the UARTE is enabled, and retained only for the duration the device is in ON mode. PSEL.RXD, PSEL.RTS, PSEL.RTS and PSEL.TXD must only be configured when the UARTE is disabled. To secure correct signal levels on the pins by the UARTE when the system is in OFF mode, the pins must be configured in the GPIO peripheral as described in GPIO configuration before enabling peripheral on page 312. Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior. | UARTE signal | UARTE pin | Direction | Output value | |--------------|--------------------------|-----------|----------------| | RXD | As specified in PSEL.RXD | Input | Not applicable | | CTS | As specified in PSEL.CTS | Input | Not applicable | | RTS | As specified in PSEL.RTS | Output | 1 | | TXD | As specified in PSEL.TXD | Output | 1 | Table 95: GPIO configuration before enabling peripheral ## 6.24.9 Registers | Base address | Peripheral | Instance | <b>Description Configuration</b> | |--------------|------------|----------|----------------------------------| | 0x40002000 | UARTE | UARTE0 | Universal asynchronous receiver/ | | | | | transmitter with EasyDMA | Table 96: Instances | Register | Offset | Description | |------------------|--------|------------------------------------------------------------------------| | TASKS_STARTRX | 0x000 | Start UART receiver | | TASKS_STOPRX | 0x004 | Stop UART receiver | | TASKS_STARTTX | 0x008 | Start UART transmitter | | TASKS_STOPTX | 0x00C | Stop UART transmitter | | TASKS_FLUSHRX | 0x02C | Flush RX FIFO into RX buffer | | EVENTS_CTS | 0x100 | CTS is activated (set low). Clear To Send. | | EVENTS_NCTS | 0x104 | CTS is deactivated (set high). Not Clear To Send. | | EVENTS_RXDRDY | 0x108 | Data received in RXD (but potentially not yet transferred to Data RAM) | | EVENTS_ENDRX | 0x110 | Receive buffer is filled up | | EVENTS_TXDRDY | 0x11C | Data sent from TXD | | EVENTS_ENDTX | 0x120 | Last TX byte transmitted | | EVENTS_ERROR | 0x124 | Error detected | | EVENTS_RXTO | 0x144 | Receiver timeout | | EVENTS_RXSTARTED | 0x14C | UART receiver has started | | EVENTS_TXSTARTED | 0x150 | UART transmitter has started | | EVENTS_TXSTOPPED | 0x158 | Transmitter stopped | | SHORTS | 0x200 | Shortcuts between local events and tasks | | INTEN | 0x300 | Enable or disable interrupt | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | Register | Offset | Description | |------------|--------|-----------------------------------------------------------| | ERRORSRC | 0x480 | Error source | | | | Note : this register is read / write one to clear. | | ENABLE | 0x500 | Enable UART | | PSEL.RTS | 0x508 | Pin select for RTS signal | | PSEL.TXD | 0x50C | Pin select for TXD signal | | PSEL.CTS | 0x510 | Pin select for CTS signal | | PSEL.RXD | 0x514 | Pin select for RXD signal | | BAUDRATE | 0x524 | Baud rate. Accuracy depends on the HFCLK source selected. | | RXD.PTR | 0x534 | Data pointer | | RXD.MAXCNT | 0x538 | Maximum number of bytes in receive buffer | | RXD.AMOUNT | 0x53C | Number of bytes transferred in the last transaction | | TXD.PTR | 0x544 | Data pointer | | TXD.MAXCNT | 0x548 | Maximum number of bytes in transmit buffer | | TXD.AMOUNT | 0x54C | Number of bytes transferred in the last transaction | | CONFIG | 0x56C | Configuration of parity and hardware flow control | Table 97: Register overview ## 6.24.9.1 TASKS\_STARTRX Address offset: 0x000 Start UART receiver ## 6.24.9.2 TASKS\_STOPRX Address offset: 0x004 Stop UART receiver | Bit n | umber | | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------|---------|---------------------|---------------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | W TASKS_STOPRX | | | Stop UART receiver | | | | Trigger | 1 | Trigger task | ## 6.24.9.3 TASKS\_STARTTX Address offset: 0x008 Start UART transmitter ## 6.24.9.4 TASKS\_STOPTX Address offset: 0x00C Stop UART transmitter | Bit n | number | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 1 | .5 14 13 12 11 10 9 8 | 3 7 6 5 4 3 2 1 0 | |-------|----------------|---------|----------------|------------------------------------|-----------------------|-------------------| | ID | | | | | | А | | Rese | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 | 0000000 | 00000000 | | ID | | | | Description | | | | Α | W TASKS_STOPTX | | | Stop UART transmitter | | | | | | Trigger | 1 | Trigger task | | | ## 6.24.9.5 TASKS\_FLUSHRX Address offset: 0x02C Flush RX FIFO into RX buffer #### 6.24.9.6 EVENTS CTS Address offset: 0x100 CTS is activated (set low). Clear To Send. | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | | А | | Rese | t 0x00000000 | | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW EVENTS_CTS | | | CTS is activated (set low). Clear To Send. | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | #### 6.24.9.7 EVENTS NCTS Address offset: 0x104 CTS is deactivated (set high). Not Clear To Send. 4454\_187 v0.5 314 NO | Bit n | umber | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|----------------|--------------|----------------------|------------------------------------------------------------------| | ID | | | | А | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW EVENTS_NCTS | | | CTS is deactivated (set high). Not Clear To Send. | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | ## 6.24.9.8 EVENTS\_RXDRDY Address offset: 0x108 Data received in RXD (but potentially not yet transferred to Data RAM) | Bit r | number | | 31 30 29 2 | 28 27 26 25 | 4 23 22 21 20 19 18 17 16 1 | .5 14 13 12 11 10 | 987 | 6 5 4 | 1 3 2 | 1 0 | |-------|------------------|--------------|------------|-------------|-----------------------------|-------------------|-------------|--------|-------|-----| | ID | | | | | | | | | | А | | Rese | et 0x00000000 | | 0 0 0 0 | 0 0 0 0 | 00000000 | 0 0 0 0 0 | 0 0 0 | 0 0 0 | 0 0 | 0 0 | | ID | | | | | Description | | | | | | | Α | RW EVENTS_RXDRDY | | | | Data received in RXD (but | potentially not y | et transfer | red to | | | | | | | | | Data RAM) | | | | | | | | | NotGenerated | 0 | | Event not generated | | | | | | | | | Generated | 1 | | Event generated | V | | | | | ## 6.24.9.9 EVENTS\_ENDRX Address offset: 0x110 Receive buffer is filled up ## 6.24.9.10 EVENTS\_TXDRDY Address offset: 0x11C Data sent from TXD | Bit n | umber | | 31 | 30 | 29 | 28 | 3 27 | 7 26 | 25 | 5 24 | 4 23 | 3 2 | 2 2 | 1 2 | 0 1 | 9 1 | 8 1 | 7 1 | 5 1! | 5 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 ( | 6 ! | 5 4 | 1 3 | 2 | 1 | 0 | |-------|------------------|--------------|----|----|----|----|------|------|----|------|------|-----|------|------|-----|------|------|-----|------|------|----|----|----|----|---|-----|-----|-----|-----|-----|---|---|---| | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | | Rese | et 0x00000000 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) ( | 0 | ) ( | 0 ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 ( | 0 ( | 0 ( | 0 | 0 | 0 | 0 | | ID | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | RW EVENTS_TXDRDY | | | | | | | | | | D | ata | se | nt f | fro | m T | ΧD | | | | | | | | | | | | | | | | | | | | NotGenerated | 0 | | | | | | | | E۱ | /en | nt n | ot g | ger | nera | ited | ł | | | | | | | | | | | | | | | | | | | Generated | 1 | | | | | | | | E۱ | /en | nt g | ene | era | ted | | | | | | | | | | | | | | | | | | #### 6.24.9.11 EVENTS\_ENDTX Address offset: 0x120 Last TX byte transmitted | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|-----------------|--------------|-------------------------|-----------------------------------------------------------------| | ID | | | | A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW EVENTS_ENDTX | | | Last TX byte transmitted | | | | NotGenerated | 0 | Event not generated | | | | Generated | 1 | Event generated | ## 6.24.9.12 EVENTS\_ERROR Address offset: 0x124 Error detected | Bit number | | 31 30 29 2 | 28 27 26 25 | 24 23 22 21 20 | 0 19 18 17 | 16 15 | 14 13 | 12 11 | 10 9 | 8 7 | 7 6 | 5 | 4 3 | 2 | 1 0 | |------------------|--------------|------------|-------------|----------------|------------|-------|-------|-------|------|-----|-----|---|-----|---|-----| | ID | | | | | | | | | | | | | | | Α | | Reset 0x00000000 | | 0 0 0 | 0 0 0 0 | 0 0 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 | 0 0 | 0 | 0 0 | | ID Acce Field | | | | Description | | | | | | | | | | | | | A RW EVENTS | S_ERROR | | | Error detec | ted | | | | | | | | | | | | | NotGenerated | 0 | | Event not g | enerated | | | | | | | | | | | | | Generated | 1 | | Event gene | rated | | | | | | | | | | | ## 6.24.9.13 EVENTS\_RXTO Address offset: 0x144 Receiver timeout ## 6.24.9.14 EVENTS\_RXSTARTED Address offset: 0x14C UART receiver has started | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW EVENTS_RXSTARTED | | | UART receiver has started | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | ## 6.24.9.15 EVENTS\_TXSTARTED Address offset: 0x150 **UART** transmitter has started | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | А | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW EVENTS_TXSTARTED | | | UART transmitter has started | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | ## 6.24.9.16 EVENTS\_TXSTOPPED Address offset: 0x158 Transmitter stopped | Bit r | number | | 31 30 29 28 27 2 | 26 25 24 | 23 22 2 | 21 20 : | 19 18 | 3 17 | 16 15 | 14 1 | 3 12 | 11 | 10 9 | 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 | |-------|---------------------|--------------|------------------|----------|---------|----------|-------|------|-------|------|------|----|------|---|---|---|---|-----|-----|---|---| | ID | | | | | | | | | | | | | | | | | | | | | Α | | Res | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 ( | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 | | ID | | | | | Descri | ption | | | | | | | | | | | | | | | | | Α | RW EVENTS_TXSTOPPED | | | | Transn | nitter : | stopp | oed | | | | | | | | | | | | | | | | | NotGenerated | 0 | | Event | not ge | nera | ted | | | | | | | | | | | | | | | | | Generated | 1 | | Event ( | genera | ated | | | | | | | | | | | | | | | ## 6.24.9.17 SHORTS Address offset: 0x200 Shortcuts between local events and tasks | Bit n | umber | | 31 30 2 | 9 28 | 27 26 | 25 | 24 2 | 3 22 2 | 1 20 | 19 | 18 : | 17 1 | 6 1 | .5 1 | 4 13 | 12 | 11 | 10 | 9 | 8 | 7 6 | 5 5 | 5 4 | - 3 | 2 | 1 0 | |-------|------------------|----------|---------|------|-------|----|------|--------|-------|-------|------|------|------|------|------|----|-----|------|-----|-----|-----|-----|-----|-----|---|-----| | ID | | | | | | | | | | | | | | | | | | | | | [ | ) ( | 2 | | | | | Rese | t 0x00000000 | | 0 0 ( | 0 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | ) ( | 0 | 0 | 0 | 0 0 | | ID | Acce Field | Value ID | Value | | | | D | escrip | | | | | | | | | | | | | | | | | | | | С | RW ENDRX_STARTRX | | | | K | | S | nortcu | it be | etwe | en | eve | nt E | ND | RX a | nd | tas | sk S | TAR | TRX | | | | | | | | | | Disabled | 0 | ١. | | | D | isable | sho | rtcu | t | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | E | nable | shoi | rtcut | : | | | | | | | | | | | | | | | | | D | RW ENDRX_STOPRX | | | | | | S | nortcu | t be | etwe | en | eve | nt E | END | RX a | nd | tas | sk S | ГОР | RX | | | | | | | | | | Disabled | 0 | | | | D | isable | sho | rtcu | t | | | | | | | | | | | | | | | | | | | Enabled | 1 | | | | Ε | nable | shoi | rtcut | | | | | | | | | | | | | | | | | #### 6.24.9.18 INTEN Address offset: 0x300 Enable or disable interrupt | Bit number | | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|-------------------|-----------------------------------------------------------------------| | ID | | | L JIH GFE D CBA | | Reset 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A RW CTS | | | Enable or disable interrupt for event CTS | | | Disabled | 0 | Disable | | | Enabled | 1 | Enable | | B RW NCTS | | | Enable or disable interrupt for event NCTS | | | Disabled | 0 | Disable | | | Enabled | 1 | Enable | | Bit r | number | | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|------------------|------------------------------------------------------------------------| | ID | | | | L J I H G F E D C B A | | Res | et 0x00000000 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | С | RW RXDRDY | | | Enable or disable interrupt for event RXDRDY | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | D | RW ENDRX | | | Enable or disable interrupt for event ENDRX | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | E | RW TXDRDY | | | Enable or disable interrupt for event TXDRDY | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | F | RW ENDTX | | | Enable or disable interrupt for event ENDTX | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | G | RW ERROR | | | Enable or disable interrupt for event ERROR | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | Н | RW RXTO | | | Enable or disable interrupt for event RXTO | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | I | RW RXSTARTED | | | Enable or disable interrupt for event RXSTARTED | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | J | RW TXSTARTED | | | Enable or disable interrupt for event TXSTARTED | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | L | RW TXSTOPPED | | | Enable or disable interrupt for event TXSTOPPED | | | | Disabled | 0 | Disable | | | | Enabled | 1 | Enable | | | | | | | 6.24.9.19 INTENSET Address offset: 0x304 Enable interrupt | Bit r | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|------------------------|-----------------------------------------------------------------| | ID | | | | L JIH GFE D CBA | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | | | Α | RW CTS | | | Write '1' to enable interrupt for event CTS | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | В | RW NCTS | | | Write '1' to enable interrupt for event NCTS | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | С | RW RXDRDY | | | Write '1' to enable interrupt for event RXDRDY | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | | | | | | | Reset 0x00000000 | 4 3 2 3 | 1 ( | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----| | D Accc Field Value D Value Description | D C I | ВА | | D RW ENDRX Set | 0 0 0 | 0 ( | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled ENUTYDRDY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled FOUNTY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled FOUNTY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled Enabled 1 Read: Enabled FOUNTY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled FOUNTY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled FOUNTY FOUNT SET 1 Enable Enabled 1 Read: Enabled FOUNTY FOUNT SET 1 Enabled FOUNTY FOUNTY FOUNT SET 1 Enabled FOUNTY FOUNT SET 1 Enabled FOUNTY FOUNT SET 1 Enabled ENABLES | | | | Disabled Disabled Enabled Disabled Enabled Disabled | | | | E RW TXDRDY Set 1 Enable Disabled 0 Read: Enable Enable Enable Enable Disabled 1 Read: Enable Disabled 0 Read: Disabled Enable Enable Disabled 0 Read: Disabled Enable Enable Enable Enable Enable Enable Enable Enable Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Enable Enable Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Enabled Enable En | | | | E RW TXDRDY Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled F RW ENDTX Set 1 Enable Disabled 0 Read: Disabled F Disabled 0 Read: Disabled Enabled 1 Read: Enabled F RW ENDTX Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled F RW ERROR Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event ERROR Enabled 0 Read: Disabled Enabled 1 Read: Enabled H RW RXTO Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXTO Feable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXTO Feable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Feable Read: Disabled Enabled 0 Read: Disabled Enabled Read: Disabled Enabled Read: Enabled Write '1' to enable interrupt for event RXSTARTED Feable Read: Enabled Write '1' to enable interrupt for event RXSTARTED Read: Enabled Write '1' to enable interrupt for event RXSTARTED Feable Read: Enabled Write '1' to enable interrupt for event TXSTARTED | | | | Set 1 Read: Disabled 0 Read: Disabled 1 Read: Enabled 1 Read: Enabled 1 Read: Disabled 1 Read: Enabled Disabled 1 Read: Disabled 1 Read: Enabled Rea | | | | Disabled Disabled Disabled Read: Disabled | | | | F RW ENDTX Set 1 Enable G RW ERROR Finabled 0 Read: Enabled F RW ERROR Finabled 1 Read: Enabled G RW ERROR Finabled 0 Read: Enabled Set 1 Enable Disabled 0 Read: Disabled Disabled 0 Read: Enabled Finable Disabled 0 Read: Disabled Enable Disabled 1 Read: Enabled Finable Disabled 0 Read: Disabled Enable Disabled 1 Read: Enabled H RW RXTO Finable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Finable Disabled 0 Read: Disabled Finable Disabled 1 Read: Enabled Finable | | | | F RW ENDTX Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled G RW ERROR Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event ERROR Franchise Enabled Bead: Disabled 1 Read: Enabled Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event ERROR Franchise Enabled Write '1' to enable interrupt for event RXTO Enable Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXTO Franchise Enabled Write '1' to enable interrupt for event RXSTARTED Franchise Enabled Write '1' to enable interrupt for event RXSTARTED Franchise Enabled Write '1' to enable interrupt for event RXSTARTED Franchise Enabled Write '1' to enable interrupt for event TXSTARTED Franchise Enabled Write '1' to enable interrupt for event TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Set 1 Read: Disabled GRW ERROR Set 1 Read: Enabled Disabled 1 Read: Enabled Set 1 Enable Disabled 0 Read: Enabled Finable 1 Disabled 1 Read: Enabled Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event ERROR HRW RXTO Set 1 Read: Enabled Disabled 0 Read: Disabled Enable 1 Read: Enabled Read: Disabled Enable 1 Read: Enabled Write '1' to enable interrupt for event RXTO Enable Read: Enabled Write '1' to enable interrupt for event RXSTARTED Finable 1 Read: Enabled Read: Disabled Read: Enabled Disabled 0 Read: Disabled Enable Read: Enabled Disabled 1 Read: Enabled Disabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Finable Read: Enabled Write '1' to enable interrupt for event TXSTARTED | | | | Disabled 0 Read: Disabled Enabled 1 Read: Enabled GRW ERROR Write '1' to enable interrupt for event ERROR Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled HRW RXTO Write '1' to enable interrupt for event RXTO Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Finable Read: Enabled Write '1' to enable interrupt for event RXSTARTED RW RXSTARTED Set 1 Enable Set 1 Enable Read: Disabled Read: Disabled Read: Disabled Read: Disabled Read: Enabled Write '1' to enable interrupt for event RXSTARTED Read: Enabled Write '1' to enable interrupt for event RXSTARTED Read: Disabled Read: Disabled Read: Enabled Write '1' to enable interrupt for event TXSTARTED | | | | Enabled 1 Read: Enabled GRW ERROR Set 1 Enable Disabled 0 Read: Disabled Enabled HRW RXTO Set 1 Enable Enabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXTO Finabled 0 Read: Disabled Enabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXTO Finabled 1 Read: Enabled Write '1' to enable interrupt for event RXTO Finabled 0 Read: Enabled Write '1' to enable interrupt for event RXTARTED Finable 0 Read: Disabled Enable 0 Read: Disabled Read: Enabled Write '1' to enable interrupt for event TXSTARTED Finable 0 Read: Enabled Write '1' to enable interrupt for event TXSTARTED | | | | G RW ERROR Set 1 Enable Disabled 0 Read: Disabled Enabled H RW RXTO Set 1 Enable Write '1' to enable interrupt for event ERROR Read: Enabled Write '1' to enable interrupt for event RXTO Enabled Disabled 0 Read: Disabled Enabled Enabled Read: Enabled Write '1' to enable interrupt for event RXTO Enable Enable Disabled 0 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Enable Disabled 0 Read: Enabled Read: Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Read: Enabled Write '1' to enable interrupt for event TXSTARTED | | | | Set 1 Read: Enabled H RW RXTO Set 1 Mrite '1' to enable interrupt for event RXTO Enabled 0 Read: Disabled Write '1' to enable interrupt for event RXTO Enable Disabled 0 Read: Disabled Enable Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Finable Read: Enabled Write '1' to enable interrupt for event RXSTARTED Enable Disabled 0 Read: Disabled Read: Disabled Disabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Read: Enabled Write '1' to enable interrupt for event TXSTARTED | | | | Disabled 0 Read: Disabled H RW RXTO Set 1 Enabled Disabled 0 Read: Enabled Nortic '1' to enable interrupt for event RXTO Read: Disabled Read: Disabled Read: Disabled Read: Disabled Read: Enabled Write '1' to enable interrupt for event RXTO Read: Disabled Read: Enabled Write '1' to enable interrupt for event RXSTARTED Enable Disabled 0 Read: Disabled Read: Disabled Write '1' to enable interrupt for event RXSTARTED Read: Enabled Write '1' to enable interrupt for event TXSTARTED | | | | H RW RXTO Write '1' to enable interrupt for event RXTO Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Read: Enabled Read: Enabled Write '1' to enable interrupt for event RXSTARTED Finable Note: '1' to enable interrupt for event RXSTARTED Set 1 Enable Disabled 0 Read: Disabled Enabled J RW TXSTARTED Write '1' to enable interrupt for event TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | H RW RXTO Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXTO Finable Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Set 1 Enable Disabled 0 Read: Disabled Disabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Read: Disabled Write '1' to enable interrupt for event TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Disabled 0 Read: Disabled Enabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Set 1 Enable Disabled 0 Read: Disabled Disabled 1 Read: Enabled Write '1' to enable interrupt for event RXSTARTED Write '1' to enable interrupt for event TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Enabled I RW RXSTARTED Set Disabled Disabled Enabled T Read: Enabled Write '1' to enable interrupt for event RXSTARTED Read: Disabled Read: Disabled Read: Enabled Write '1' to enable interrupt for event TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Write '1' to enable interrupt for event RXSTARTED Set Disabled Disabled Enable Finable Write '1' to enable interrupt for event RXSTARTED Write '1' to enable interrupt for event RXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled J RW TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Disabled 0 Read: Disabled Enabled 1 Read: Enabled J RW TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | Enabled 1 Read: Enabled J RW TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | J RW TXSTARTED Write '1' to enable interrupt for event TXSTARTED | | | | | | | | Set 1 Enable | | | | | | | | Disabled 0 Read: Disabled | | | | Enabled 1 Read: Enabled | | | | L RW TXSTOPPED Write '1' to enable interrupt for event TXSTOPPED | | | | Set 1 Enable | | | | Disabled 0 Read: Disabled | | | | Enabled 1 Read: Enabled | | | ## 6.24.9.20 INTENCLR Address offset: 0x308 Disable interrupt | Bit number | | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |------------------|----------|------------------------|------------------------------------------------------------------| | ID | | | L JIH GFE D CBA | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | | | A RW CTS | | | Write '1' to disable interrupt for event CTS | | | Clear | 1 | Disable | | | Disabled | 0 | Read: Disabled | | | Enabled | 1 | Read: Enabled | | B RW NCTS | | | Write '1' to disable interrupt for event NCTS | | | Clear | 1 | Disable | | | Disabled | 0 | Read: Disabled | | Bit n | umber | | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | |-------|---------------|----------|-------------------|-------------------------------------------------------------------| | ID | | | | L JIH GFE D CBA | | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | | | | | Enabled | 1 | Read: Enabled | | С | RW RXDRDY | | | Write '1' to disable interrupt for event RXDRDY | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | D | RW ENDRX | | | Write '1' to disable interrupt for event ENDRX | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Ε | RW TXDRDY | | | Write '1' to disable interrupt for event TXDRDY | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | F | RW ENDTX | | | Write '1' to disable interrupt for event ENDTX | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | G | RW ERROR | | | Write '1' to disable interrupt for event ERROR | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | Н | RW RXTO | | | Write '1' to disable interrupt for event RXTO | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | I | RW RXSTARTED | | • | Write '1' to disable interrupt for event RXSTARTED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | J | RW TXSTARTED | | | Write '1' to disable interrupt for event TXSTARTED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | | L | RW TXSTOPPED | | | Write '1' to disable interrupt for event TXSTOPPED | | | | Clear | 1 | Disable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | 1 | Read: Enabled | ## 6.24.9.21 ERRORSRC Address offset: 0x480 Error source Note: this register is read / write one to clear. | Bit n | umber | | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|------------|-------------------------|-----------------------------------------------------------------| | ID | | | | D C B A | | Rese | et 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW OVERRUN | | | Overrun error | | | | | | A start bit is received while the previous data still lies in | | | | | | RXD. (Previous data is lost.) | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | В | RW PARITY | | | Parity error | | | | | | A character with bad parity is received, if HW parity check is | | | | | | enabled. | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | С | RW FRAMING | | | Framing error occurred | | | | | | A valid stop bit is not detected on the serial data input after | | | | | | all bits in a character have been received. | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | | D | RW BREAK | | | Break condition | | | | | | The serial data input is '0' for longer than the length of a | | | | | | data frame. (The data frame length is 10 bits without parity | | | | | AU | bit, and 11 bits with parity bit.). | | | | NotPresent | 0 | Read: error not present | | | | Present | 1 | Read: error present | ## 6.24.9.22 ENABLE Address offset: 0x500 **Enable UART** | Bit n | umber | | 31 30 29 2 | 8 27 26 2 | 25 24 | 23 22 | 21 20 | 0 19 1 | 18 17 | 16 | 15 1 | 4 13 | 12 1 | 1 10 | 9 | 8 | 7 6 | 5 | 4 | 3 | 2 | 1 0 | |-------|---------------|----------|------------|-----------|-------|-------|---------|--------|-------|-----|------|------|------|------|---|-----|-----|---|---|---|-----|-----| | ID | | | | | | | | | | | | | | | | | | | | Α | A | А А | | Rese | et 0x00000000 | | 0 0 0 0 | 0 0 | 0 0 | 0 0 | 0 0 | 0 | 0 0 | 0 | 0 ( | 0 | 0 | 0 0 | 0 | 0 ( | 0 0 | 0 | 0 | 0 | 0 ( | o 0 | | ID | | Value ID | Value | | | | | | | | | | | | | | | | | | | | | Α | RW ENABLE | | | | | Enab | le or o | lisab | le UA | RTE | | | | | | | | | | | | | | | | Disabled | 0 | | | Disab | le UA | RTE | | | | | | | | | | | | | | | | | | Enabled | 8 | | | Enab | le UAI | RTE | | | | | | | | | | | | | | | ## 6.24.9.23 PSEL.RTS Address offset: 0x508 Pin select for RTS signal | Bit nu | umber | | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|-------------|--------------|-------------------------|---------------------------------------------------------------| | ID | | | С | АААА | | Rese | t OxFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.24.9.24 PSEL.TXD Address offset: 0x50C Pin select for TXD signal | Bit n | umber | | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 . | 18 17 16 15 14 | 4 13 12 11 10 9 | 9 8 7 6 | 5 4 | 3 2 | 1 0 | |-------|--------------|--------------|----------------|---------------------------|----------------|-----------------|---------|-----|-----|-------| | ID | | | С | 4 | | | | А | ΑА | А А А | | Rese | et OxFFFFFFF | | 1 1 1 1 1 | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 | 11111 | 1 1 1 1 | 1 1 | 1 1 | 1 1 | | ID | | | | Description | | | | | | | | Α | RW PIN | | [031] | Pin number | | | | | | | | С | RW CONNECT | | | Connection | | | | | | | | | | Disconnected | 1 | Disconnect | | | | | | | | | | Connected | 0 | Connect | | | | | | | #### 6.24.9.25 PSEL.CTS Address offset: 0x510 Pin select for CTS signal | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-----------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | C | A A A A | | Reset 0xFFFFFFF | | 1 1 1 1 1 1 1 | 1111111111111111111111111 | | ID Acce Field | Value ID | Value | Description | | A RW PIN | | [031] | Pin number | | C RW CONNECT | | | Connection | | | Disconnected | 1 | Disconnect | | | Connected | 0 | Connect | ## 6.24.9.26 PSEL.RXD Address offset: 0x514 Pin select for RXD signal | Bit no | umber | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |--------|-------------|--------------|------------------------|-----------------------------------------------------------------| | ID | | | С | АААА | | Rese | t 0xFFFFFFF | | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ID | | | | Description | | Α | RW PIN | | [031] | Pin number | | С | RW CONNECT | | | Connection | | | | Disconnected | 1 | Disconnect | | | | Connected | 0 | Connect | #### 6.24.9.27 BAUDRATE Address offset: 0x524 Baud rate. Accuracy depends on the HFCLK source selected. #### 6.24.9.28 RXD.PTR Address offset: 0x534 Data pointer **Note:** See the memory chapter for details about which memories are available for EasyDMA. #### 6.24.9.29 RXD.MAXCNT Address offset: 0x538 4454\_187 v0.5 Maximum number of bytes in receive buffer 323 | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 | |------------------------------------------------------------------------------------------------------------------------------------| | ID A A A A A A A A A A A A A A A A A A A | | | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | #### 6.24.9.30 RXD.AMOUNT Address offset: 0x53C Number of bytes transferred in the last transaction | Reset 0x000000000 | | |--------------------------------------------------------------------------------------------|-----| | | | | ID A A A A A A A A A A A A A A A A A A A | 0 0 | | | АА | | Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 1 0 | #### 6.24.9.31 TXD.PTR Address offset: 0x544 Data pointer ## 6.24.9.32 TXD.MAXCNT Address offset: 0x548 Maximum number of bytes in transmit buffer | ID | | | | |-------|---------------|------------------------|-----------------------------------------------------------------| | Rese | et 0x00000000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | A A A A A A A A A A A A A A A A A A A | | Bit n | umber | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | #### 6.24.9.33 TXD.AMOUNT Address offset: 0x54C Number of bytes transferred in the last transaction | A R AM | DUNT | [10x3FF] | Number of bytes transferred in the last transaction | |---------------|------|------------------------|-----------------------------------------------------------------| | ID Acce Fiel | | | | | Reset 0x00000 | 000 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | A A A A A A A A A A A A A A A A A A A | | Bit number | | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | | #### 6.24.9.34 CONFIG Address offset: 0x56C Configuration of parity and hardware flow control ### 6.24.10 Electrical specification ### 6.24.10.1 UARTE electrical specification | Symbol | Description | | Min. | Тур. | Max. | Units | |--------------------------|-----------------------------------------|------------------|------|------|------|-------| | f <sub>UARTE</sub> | Baud rate for UARTE <sup>33</sup> . | | | | 1000 | kbps | | t <sub>UARTE,CTSH</sub> | CTS high time | | 1 | | | μs | | t <sub>uarte,start</sub> | Time from STARTRX/STARTTX task to trans | smission started | | | | μs | ## 6.25 WDT — Watchdog timer A countdown watchdog timer using the low-frequency clock source (LFCLK) offers configurable and robust protection against application lock-up. The watchdog timer is started by triggering the START task. The watchdog can be paused during long CPU sleep periods for low power applications and when the debugger has halted the CPU. The watchdog is implemented as a down-counter that generates a TIMEOUT event when it wraps over after counting down to 0. When the watchdog timer is started through the START task, the watchdog counter is loaded with the value specified in the CRV register. This counter is also reloaded with the value specified in the CRV register when a reload request is granted. 4454\_187 v0.5 325 NORD High baud rates may require GPIOs to be set as High Drive, see GPIO chapter for more details. The watchdog's timeout period is given by: ``` timeout [s] = (CRV + 1) / 32768 ``` When started, the watchdog will automatically force the 32.768 kHz RC oscillator on as long as no other 32.768 kHz clock source is running and generating the 32.768 kHz system clock, see chapter CLOCK — Clock control on page 60. ### 6.25.1 Reload criteria The watchdog has eight separate reload request registers, which shall be used to request the watchdog to reload its counter with the value specified in the CRV register. To reload the watchdog counter, the special value 0x6E524635 needs to be written to all enabled reload registers. One or more RR registers can be individually enabled through the RREN register. ### 6.25.2 Temporarily pausing the watchdog By default, the watchdog will be active counting down the down-counter while the CPU is sleeping and when it is halted by the debugger. It is however possible to configure the watchdog to automatically pause while the CPU is sleeping as well as when it is halted by the debugger. ### 6.25.3 Watchdog reset A TIMEOUT event will automatically lead to a watchdog reset. See Reset on page 51 for more information about reset sources. If the watchdog is configured to generate an interrupt on the TIMEOUT event, the watchdog reset will be postponed with two 32.768 kHz clock cycles after the TIMEOUT event has been generated. Once the TIMEOUT event has been generated, the impending watchdog reset will always be effectuated. The watchdog must be configured before it is started. After it is started, the watchdog's configuration registers, which comprise registers CRV, RREN, and CONFIG, will be blocked for further configuration. The watchdog can be reset from several reset sources, see Reset behavior on page 52. When the device starts running again, after a reset, or waking up from OFF mode, the watchdog configuration registers will be available for configuration again. ### 6.25.4 Registers | Base address | Peripheral | Instance | Description | Configuration | |--------------|------------|----------|----------------|---------------| | 0x40010000 | WDT | WDT | Watchdog timer | | Table 98: Instances | Register | Offset | Description | |----------------|--------|----------------------------------------------| | TASKS_START | 0x000 | Start the watchdog | | EVENTS_TIMEOUT | 0x100 | Watchdog timeout | | INTENSET | 0x304 | Enable interrupt | | INTENCLR | 0x308 | Disable interrupt | | RUNSTATUS | 0x400 | Run status | | REQSTATUS | 0x404 | Request status | | CRV | 0x504 | Counter reload value | | RREN | 0x508 | Enable register for reload request registers | | Register | Offset | Description | |----------|--------|------------------------| | CONFIG | 0x50C | Configuration register | | RR[0] | 0x600 | Reload request 0 | | RR[1] | 0x604 | Reload request 1 | | RR[2] | 0x608 | Reload request 2 | | RR[3] | 0x60C | Reload request 3 | | RR[4] | 0x610 | Reload request 4 | | RR[5] | 0x614 | Reload request 5 | | RR[6] | 0x618 | Reload request 6 | | RR[7] | 0x61C | Reload request 7 | Table 99: Register overview ### 6.25.4.1 TASKS\_START Address offset: 0x000 Start the watchdog ### 6.25.4.2 EVENTS\_TIMEOUT Address offset: 0x100 Watchdog timeout | Bit number | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------------------|--------------|----------------------|------------------------------------------------------------------| | ID | | | A | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$ | | ID Acce Field | | Value | Description | | A RW EVENTS_TIMEOUT | | | Watchdog timeout | | | NotGenerated | 0 | Event not generated | | | Generated | 1 | Event generated | ### 6.25.4.3 INTENSET Address offset: 0x304 Enable interrupt | Bit n | umber | | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |-------|---------------|----------|---------------------|--------------------------------------------------------------------| | ID | | | | Α | | Rese | et 0x00000000 | | 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | | | Description | | Α | RW TIMEOUT | | | Write '1' to enable interrupt for event TIMEOUT | | | | Set | 1 | Enable | | | | Disabled | 0 | Read: Disabled | | | | Enabled | | Read: Enabled | ### 6.25.4.4 INTENCLR Address offset: 0x308 Disable interrupt ### 6.25.4.5 RUNSTATUS Address offset: 0x400 Run status #### 6.25.4.6 REQSTATUS Address offset: 0x404 Request status #### 6.25.4.7 CRV Address offset: 0x504 Counter reload value | ID Acce Field | Valu | | | | | | | | | _ | ion | _ | _ | | | Ī | _ | | | i | i | Ī | i | | _ | | | |-----------------|------|------|-----|------|------|-----|-----|-----|-----|-------|------|----|------|-----|------|----|----|------|------|---|---|---|---|----|-----|-----|-----| | Reset 0xFFFFFFF | 1 | 1 | 1 | 1 | 1 1 | 1 1 | 1 1 | 1 | 1 1 | 1 | 1 | 1 | 1 | 1 1 | 1 | 1 | 1 | 1 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 . | . 1 | 1 1 | | ID | Α | Α / | Α, | A | A A | 4 Α | Α Α | Δ, | Д Д | A | . A | Α | A | Δ / | A | Α | Α | A A | A | Α | Α | Α | Α | Α. | A A | A A | A A | | Bit number | 313 | 30 2 | 9 2 | 28 2 | 27 2 | 6 2 | 5 2 | 4 2 | 3 2 | 2 2 1 | 1 20 | 19 | 18 1 | 7 1 | 6 15 | 14 | 13 | 12 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 0 | clock 6.25.4.8 RREN Address offset: 0x508 Enable register for reload request registers | Bit number | | 31 30 29 28 27 | 7 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | |---------------------|----------|----------------|--------------------------------------------------------------------------| | ID | | | HGFEDCBA | | Reset 0x00000001 | | 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID Acce Field | | | Description | | A-H RW RR[i] (i=07) | | | Enable or disable RR[i] register | | | Disabled | 0 | Disable RR[i] register | | | Enabled | 1 | Enable RR[i] register | ### 6.25.4.9 CONFIG Address offset: 0x50C Configuration register ### 6.25.4.10 RR[n] (n=0..7) Address offset: $0x600 + (n \times 0x4)$ Reload request n | | Reload | 0x6E524635 | Value to request a reload of the watchdog timer | |------------------|--------|----------------------|----------------------------------------------------------------| | A W RR | | | Reload request register | | ID Acce Field | | | | | Reset 0x00000000 | | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | ID | | A A A A A A | A A A A A A A A A A A A A A A A A A A | | Bit number | | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | # 6.25.5 Electrical specification ## 6.25.5.1 Watchdog Timer Electrical Specification | Symbol | Description | Min. | Тур. | Max. | Units | |-----------------|-------------------|--------|------|------|-------| | t <sub>wn</sub> | Time out interval | 458 μs | | 36 h | | # 7 Hardware and layout ## 7.1 Pin assignments The pin assignment figures and tables describe the pinouts for the product variants of the chip. There are also recommendations for how the GPIO pins should be configured, in addition to any usage restrictions. ### 7.1.1 WLCSP ball assignments The nRF52805 ball assignment table and figure describe the assignments for this variant of the chip. Figure 116: WLCSP ball assignments, top view Balls not mentioned in the ball assignments table below are not connected (NC) and must be soldered to the PCB. | Pin | Name | Туре | Description | |-----|---------------|--------------------------|--------------------------------------------------------------------------| | A1 | XC1 | Analog input | Connection for 32 MHz crystal | | A2 | XC2 | Analog input | Connection for 32 MHz crystal | | A3 | DEC2 | Power | 1.3 V regulator supply decoupling (radio supply) | | A4 | DEC4 | Power | 1.3 V analog supply. Input from DC/DC converter. Output from 1.3 V LDO. | | A5 | DCC | Power | DC/DC converter output (3.3 V PWM) | | A6 | VDD | Power | Power (battery) supply | | В3 | VSS | Power | Ground | | B4 | VSS | Power | Ground | | B6 | DEC1 | Power | 0.9 V regulator digital supply decoupling | | C1 | VSS_PA | Power | Ground | | D3 | VSS | Power | Ground | | D4 | VSS | Power | Ground | | D5 | P0.01 | Digital I/O | General purpose I/O | | | XL2 | Analog input | Connection for 32.768 kHz crystal (LFXO) | | D6 | P0.00 | Digital I/O | General purpose I/O | | | XL1 | Analog input | Connection for 32.768 kHz crystal (LFXO) | | E1 | ANT | RF | Single-ended radio antenna connection | | E3 | VSS | Power | Ground | | E4 | VSS | Power | Ground | | F1 | SWDIO | Digital I/O | Serial wire debug I/O for debug and programming | | F2 | P0.20 | Digital I/O | General purpose I/O | | F4 | P0.14 | Digital I/O | General purpose I/O | | F5 | P0.04<br>AIN2 | Digital I/O Analog input | General purpose I/O SAADC input | | F6 | P0.05 | Digital I/O | General purpose I/O | | | | - | | | C1 | AIN3 | Analog input | SAADC input | | G1 | SWDCLK | Digital input | Serial wire debug clock input for debug and programming | | 63 | DO 31 | Digital I/O | | | G2 | P0.21 | Digital I/O | General purpose I/O | | | nRESET | | Configurable as pin reset | | G3 | P0.18 | Digital I/O | General purpose I/O | | G4 | P0.16 | Digital I/O | General purpose I/O | | G5 | P0.12 | Digital I/O | General purpose I/O | | G6 | VDD | Power | Power (battery) supply | Table 100: WLCSP ball assignments # 7.2 Mechanical specifications The mechanical specifications for the packages show the dimensions in millimeters. ### 7.2.1 WLCSP 2.482 x 2.464 mm package Dimensions in millimeters for the nRF52805 WLCSP 2.482 x 2.464 mm package. Figure 117: WLCSP 2.482 x 2.464 mm package | | Α | A1 | А3 | b | C1 | D | E | D2 | E2 | е | K | L | |------|-------|------|-------|-------|-----|-------|-------|-----|-----|-----|-----|-----| | Min. | 0.419 | 0.12 | 0.299 | 0.197 | | | | | | | | | | Nom. | 0.477 | | 0.327 | | 0.2 | 2.482 | 2.464 | 2.0 | 2.0 | 0.4 | 1.0 | 1.0 | | Max. | 0.535 | 0.18 | 0.355 | 0.257 | | | | | | | | | Table 101: WLCSP dimensions in millimeters ## 7.3 Reference circuitry To ensure good RF performance when designing PCBs, it is highly recommended to use the PCB layouts and component values provided by Nordic Semiconductor. Documentation for the different package reference circuits, including Altium Designer files, PCB layout files, and PCB production files can be downloaded from the product page for the nRF52805 on www.nordicsemi.com. # 8 # Recommended operating conditions The operating conditions are the physical parameters that the chip can operate within. | Symbol | Parameter | Notes | Min. | Nom. | Max. | Units | |--------------|--------------------------------------------|-------|------|------|------|-------| | VDD | Supply voltage, independent of DCDC enable | | 1.7 | 3.0 | 3.6 | V | | $t_{R\_VDD}$ | Supply rise time (0 V to 1.7 V) | | | | 60 | ms | | TA | Operating temperature | | -40 | 25 | 85 | °C | Table 102: Recommended operating conditions **Important:** The on-chip power-on reset circuitry may not function properly for rise times longer than the specified maximum. ## 8.1 WLCSP light sensitivity WLCSP package variants are sensitive to visible and near infrared light, which means that a final product design must shield the chip properly. For the CAAA package variant, the marking side is covered with a light absorbing film, while the side edges of the chip and the ball side must be protected by coating or other means. # 9 Absolute maximum ratings Maximum ratings are the extreme limits to which the chip can be exposed for a limited amount of time without permanently damaging it. Exposure to absolute maximum ratings for prolonged periods of time may affect the reliability of the device. | | Note | Min. | Max. | Unit | |------------------------------------------|----------------------------|------------------|-----------|--------------------| | Supply voltages | | | | | | VDD | | -0.3 | +3.9 | V | | VSS | | | 0 | V | | I/O pin voltage | | | | | | $V_{I/O}$ , $VDD \le 3.6 V$ | | -0.3 | VDD + 0.3 | V | | V <sub>I/O</sub> , VDD > 3.6 V | | -0.3 | 3.9 | V | | Radio | | | | | | RF input level | | ~ ~ ~ ~ ~ | 10 | dBm | | Environmental WLCSP 2.482 x 2.464 mm pac | kage | | | | | Storage temperature | | -40 | +125 | °C | | MSL | Moisture Sensitivity Level | | 1 | | | ESD HBM | Human Body Model | | 2 | kV | | ESD HBM Class | Human Body Model Class | | 2 | | | ESD CDM | Charged Device Model | | 1 | kV | | Flash memory | A . | | | | | Endurance | | 10 000 | | Write/erase cycles | | Retention | X | 10 years at 40°C | | | Table 103: Absolute maximum ratings # 10 Ordering information This chapter contains information on IC marking, ordering codes, and container sizes. # 10.1 IC marking The IC package is marked like described below. | N | 5 | 2 | 8 | 0 | 5 | |-----------------------------------------------------------------------------------------------------------|----|---------------------------------------------------------------------|----|-------------------------------|---------| | <p< td=""><td>P&gt;</td><td><v< td=""><td>V&gt;</td><td><h></h></td><td><p></p></td></v<></td></p<> | P> | <v< td=""><td>V&gt;</td><td><h></h></td><td><p></p></td></v<> | V> | <h></h> | <p></p> | | <y< td=""><td>Y&gt;</td><td><w< td=""><td>W&gt;</td><td><l< td=""><td>L&gt;</td></l<></td></w<></td></y<> | Y> | <w< td=""><td>W&gt;</td><td><l< td=""><td>L&gt;</td></l<></td></w<> | W> | <l< td=""><td>L&gt;</td></l<> | L> | Figure 118: Package marking ### 10.2 Box labels Here are the box labels used for the IC. Figure 119: Inner box label Figure 120: Outer box label ## 10.3 Order code Here are the nRF52805 order codes and definitions. Figure 121: Order code | Abbrevitation | Definition and implemented codes | |-----------------------------|----------------------------------------------------------------------| | N52/nRF52 | nRF52 Series product | | 805 | Part code | | <pp></pp> | Package variant code | | <vv></vv> | Function variant code | | <h><p><f></f></p></h> | Build code | | | H - Hardware version code | | | P - Production configuration code (production site, etc.) | | | F - Firmware version code (only visible on shipping container label) | | <yy><ww><ll></ll></ww></yy> | Tracking code | | | YY - Year code | | | WW - Assembly week number | | | LL - Wafer lot code | | <cc></cc> | Container code | Table 104: Abbreviations # 10.4 Code ranges and values Defined here are the nRF52805 code ranges and values. | <pp></pp> | Package | Size (mm) | Pin/Ball count | Pitch (mm) | |-----------|---------|---------------|----------------|------------| | CA | WLCSP | 2.482 x 2.464 | 28 | 0.4 | Table 105: Package variant codes | <vv></vv> | Flash (kB) | RAM (kB) | |-----------|------------|----------| | AA | 192 | 24 | Table 106: Function variant codes | <h>&gt;</h> | Description | |-------------|----------------------------------------------------| | [A Z] | Hardware version/revision identifier (incremental) | Table 107: Hardware version codes | <p></p> | Description | |---------|---------------------------------------------| | [09] | Production device identifier (incremental) | | [A Z] | Engineering device identifier (incremental) | Table 108: Production configuration codes | <f></f> | Description | |------------|------------------------------------------| | [A N, P Z] | Version of preprogrammed firmware | | [0] | Delivered without preprogrammed firmware | Table 109: Production version codes | <yy></yy> | Description | *. (A) | |-----------|-------------------------------|--------| | [15 99] | Production year: 2015 to 2099 | | Table 110: Year codes | <ww></ww> | Description | |-----------|--------------------| | [152] | Week of production | Table 111: Week codes | <ll></ll> | Description | |-----------|---------------------------------| | [AA ZZ] | Wafer production lot identifier | Table 112: Lot codes | <cc></cc> | Description | |-----------|-------------| | R7 | 7" Reel | | R | 13" Reel | | Т | Tray | Table 113: Container codes # 10.5 Product options Defined here are the nRF52805 product options. | Order code | MOQ (minimum ordering quantity) | Comment | |------------------|---------------------------------|-------------------------------| | nRF52805-CAAA-R7 | 1500 | Availability to be announced. | | nRF52805-CAAA-R | 7000 | | Table 114: nRF IC order codes # 11 Legal notices By using this documentation you agree to our terms and conditions of use. Nordic Semiconductor ASA may change these terms and conditions at any time without notice. ### 11.1 Liability disclaimer Nordic Semiconductor ASA reserves the right to make changes without further notice to the product to improve reliability, function or design. Nordic Semiconductor ASA does not assume any liability arising out of the application or use of any product or circuits described herein. Information in this document is believed to be accurate and reliable. Nordic Semiconductor ASA does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. If there are any discrepancies, ambiguities or conflicts in Nordic Semiconductor's documentation, the Product Specification prevails. Nordic Semiconductor ASA reserves the right to make corrections, enhancements, and other changes to this document without notice. ### 11.2 Life support applications Nordic Semiconductor ASA products are not designed for use in life support appliances, devices, or systems where malfunction of these products can reasonably be expected to result in personal injury. Nordic Semiconductor ASA customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Nordic Semiconductor ASA for any damages resulting from such improper use or sale. # 11.3 RoHS and REACH statement Nordic Semiconductor products meet the requirements of Directive 2002/95/EC of the European Parliament and of the Council on the Restriction of Hazardous Substances (RoHS) and the requirements of the REACH regulation (EC 1907/2006) on Registration, Evaluation, Authorization and Restriction of Chemicals. The SVHC (Substances of Very High Concern) candidate list is continually being updated. Complete hazardous substance reports, material composition reports and latest version of Nordic Semiconductor's REACH statement can be found on our website <a href="http://www.nordicsemi.com">http://www.nordicsemi.com</a>. ### 11.4 Trademarks All trademarks, service marks, trade names, product names and logos appearing in this documentation are the property of their respective owners. # 11.5 Copyright notice $^{\odot}$ 2018 Nordic Semiconductor ASA. All rights are reserved. Reproduction in whole or in part is prohibited without the prior written permission of the copyright holder. COMPANY WITH QUALITY SYSTEM CERTIFIED BY DNV GL = ISO 9001 =