**ON Semiconductor** 

Is Now

# Onsemi

To learn more about onsemi<sup>™</sup>, please visit our website at <u>www.onsemi.com</u>

onsemi and ONSEMI. and other names, marks, and brands are registered and/or common law trademarks of Semiconductor Components Industries, LLC dba "onsemi" or its affiliates and/or subsidiaries in the United States and/or other countries. onsemi owns the rights to a number of patents, trademarks, copyrights, trade secrets, and other intellectual property. A listing of onsemi product/patent coverage may be accessed at www.onsemi.com/site/pdf/Patent-Marking.pdf. onsemi reserves the right to make changes at any time to any products or information herein, without notice. The information herein is provided "as-is" and onsemi makes no warranty, representation or guarantee regarding the accuracy of the information, product factures, availability, functionality, or suitability of its products for any particular purpose, nor does onsemi assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation special, consequential or incidental damages. Buyer is responsible for its products and applications using onsemi products, including compliance with all laws, regulations and asfety requirements or standards, regardless of any support or applications information provided by onsemi. "Typical" parameters which may be provided in onsemi data sheets and/or by customer's technical experts. onsemi products and actal performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. onsemi products are not designed, intended, or authorized for use as a critical component in life support systems or any FDA Class 3 medical devices or medical devices with a same or similar classification in a foreign jurisdiction or any devices intended for implantation in the human body. Should Buyer purchase or use onsemi products for any such unintended or unauthorized application, Buyer shall indemnify and hold onsemi and its officers, employees, subsidiari

# NCS36510 Programming Manual

# **DEVICE OVERVIEW**

NCS36510 is an ultra-low power RF microcontroller System on Chip (SoC) that integrates the powerful and energy efficient ARM<sup>®</sup> Cortex<sup>®</sup>-M3 microprocessor, 640 kB of FLASH memory, 48 kB of RAM, 2.4 GHz 802.15.4 RF transceiver with hardware accelerated MAC, a DMA controller, and 18 GPIO. Peripherals include: UART (2), SPI (2), I<sup>2</sup>C (2), timers (3), PWM, RTC, 10-bit SAR ADC, and internal voltage and temperature sensors. Security features include 128/256 hardware accelerated AES encryption engine and a true random number generator. NCS36510 implements advanced low-power modes for ultra-low power consumption.

# Features

ARM® Cortex® –M3

- ARMv7–M Architecture
- Thumb® / Thumb-2 Subset Instruction Set
- Nested Vectored Interrupt Controller (NVIC) with 15 Built–in Exceptions and 20 External Interrupts with 4–bit Programmable Priority
- Non-Maskable Interrupt (NMI)
- Sleep, Deep Sleep, and Coma Mode Support
- Wake-up Interrupt Controller (WIC)
- SysTick Timer for Scheduler
- Bit Banding
- Little Endian

# Debugger

- Serial-Wire Debug Access Port (SW-DAP)
- Breakpoint and Single Stepping Support
- Micro Trace Buffer (MTB)
- Standard Trace with ITM and DWT Triggers and Counters
- Full Debug with DWT Matching
- Debug Part Lockout

# Memory

- 640 kB FLASH
  - Single Cycle 32-bit Fetch @ 32 MHz
  - Two Banks of 320 kB with Independent Power Controls
  - Both Banks Have Their Own 8 kB Onformation Block Section
  - ♦ 10,000 Program/Erase Cycles
  - 10 Year Data Retention at 85C



# **ON Semiconductor®**

www.onsemi.com

# **APPLICATION NOTE**

- 48 kB RAM
  - 16 kB or 32 kB Can be Retained in Coma Mode Flexible Clocking
- On-Chip High Speed (32 MHz) RC Oscillator
- On-Chip Low Power (32.768 kHz) RC Oscillator
- High Speed Crystal Oscillator (32 MHz)
- Low Power Crystal Oscillator (32.768 kHz)
- Automatic Calibration of On-Chip RC Oscillators to External High Speed Crystal Oscillator Timers
- General Purpose 16-bit Timers (3)
  - ♦ Pre-Load
  - Down Count
  - Interrupt on 0
  - Pre-scale Clock Divider
  - Free Running or Periodic Mode
- Integrated SysTick Timer
- Real Time Clock
  - On 32.768 kHz Clock Domain
  - Pre–Load
  - 15 bit Sub–Seconds Counter
  - 32 bit Seconds Counter
  - Both Counters Can Be Combined for ~ 136 Years and Can Implement a UNIX (POSIX or Epoch) Time Counter
- Watchdog Timer
  - On 32.768 kHz Clock Domain
    - ♦ Pre-Load
    - Max Timeout 30.5 us
    - Lockout Control

# 18 GPIO

- Programmable pull-up/pull-down
- Programmable drive strengths
- Open drain capable
- Programmable interrupts (edge/level, polarity)
- Allocation of GPIOn pins to peripherals through programmable crossbar

# UART (2x)

- One full featured 16550 UART
- One reduced feature UART with transmit, receive, clear to send, and ready to send
- Programmable baud rate

# Master/Slave SPI

- Programmable data width and direction
- Programmable phase and polarity

# 10-bit SAR ADC

- 10-bit 200 k-samples/second @ 4 Mhz
- Up to 4 external sample channels
- Single ended sampling
- Pseudo-differential sampling mode
- Ratio sampling mode
- Programmable input resistor divider
- Can sample internal power supply voltage and built-in temperature sensor

# **Security Features**

- Hardware AES Acceleration
  - Supports 128-bit and 256-bit encryption/decryption
  - CCM, CTR, and CBC modes
- True random number generator
- Debug port lock

| Table of Contents                                                 |    |
|-------------------------------------------------------------------|----|
| Block Diagram                                                     | 4  |
| Cortex-M3 Instruction Set Summary                                 | 5  |
| Cortex-M3 Microcontroller and Bus Fabric                          | 9  |
| Метогу Мар                                                        |    |
| DBG_Test_EN PIN                                                   |    |
| Flash Controller                                                  |    |
| Reset and Brownout Control                                        |    |
| Clocks                                                            |    |
| Timers                                                            |    |
| Digital Input / Output (Dio) Control                              |    |
| Crossbar Control                                                  |    |
| Direct Memory Access (DMA) Controller                             |    |
| 10 bit Successive Approximation (SAR) Analog to Digital Converter | 45 |
| PWM                                                               |    |
| IEEE 802.15.4 MAC                                                 | 49 |
| Radio Frequency (RF) Control                                      | 68 |
| Test Mode Control                                                 | 70 |
| Power Management                                                  |    |
| External Communication Interfaces                                 |    |
| Security Functions                                                | 83 |
|                                                                   |    |

# **BLOCK DIAGRAM**



Figure 1. Block Diagram

# **CORTEX-M3 INSTRUCTION SET SUMMARY**

The processor implements the ARMv7-M Thumb instruction set, including a number of 32-bit instructions that use Thumb-2 technology. The Cortex-M3 instruction set comprises:

- All of the 16-bit Thumb instructions from ARMv6 excluding SETEND and BLX.
- The 32-bit Thumb instructions excluding instructions related to Co-processor support (not supported on Cortex-M3) and the following HINT instructions (which behave as NOP if used): DBG, PLD, PLI, and YIELD.

The following instruction set summary is provided by ARM online at: https://developer.arm.com/docs/ddi0337/latest/programme rs-model/instruction-set-summary/cortex-m3-instruction s and is provided here for convenience.

The following table shows the Cortex-M3 instructions and their cycle counts. The cycle counts are based on a system with zero wait states.

Within the assembler syntax, depending on the operation, the <op2> field can be replaced with one of the following options:

• a simple register specifier, for example Rm

Table 1. Cortex-M3 Instruction Set Table

- an immediate shifted register, for example Rm, LSL #4
- a register shifted register, for example Rm, LSL R<sub>S</sub>
- an immediate value, for example #0xE000E000. For brevity, not all load and store addressing modes are shown.

The table below uses the following abbreviations in the Cycles column:

- P: The number of cycles required for a pipeline refill. This ranges from 1 to 3 depending on the alignment and width of the target instruction, and whether the processor manages to speculate the address early.
- B: The number of cycles required to perform the barrier operation. For and DSB and DMB, the minimum number of cycles is zero. For ISB, the minimum number of cycles is equivalent to the number required for a pipeline refill.
- N: The number of registers in the register list to be loaded or stored, including PC or LR.
- W: The number of cycles spent waiting for an appropriate event.

See the ARMv7-M Architecture Reference Manual for more information about the ARMv7-M Thumb instructions.

| Operation     | Description              | Assembler                           | Cycles           |
|---------------|--------------------------|-------------------------------------|------------------|
|               | Register                 | MOV Rd, <op2></op2>                 | 1                |
| Maura         | 16-bit immediate         | MOVW Rd, # <imm></imm>              | 1                |
| Move          | Immediate into top       | MOVT Rd, # <imm></imm>              | 1                |
|               | To PC                    | MOV PC, Rm                          | 1 + P            |
|               | Add                      | ADD Rd, Rn, <op2></op2>             | 1                |
| <b>A</b> .1.1 | Add to PC                | ADD PC, PC, Rm                      | 1 + P            |
| Add           | Add with carry           | ADC Rd, Rn, <op2></op2>             | 1                |
|               | Form address             | ADR Rd, <label></label>             | 1                |
|               | Subtract                 | SUB Rd, Rn, <op2></op2>             | 1                |
| Subtract      | Subtract with borrow     | SBC Rd, Rn, <op2></op2>             | 1                |
|               | Reverse                  | RSB Rd, Rn, <op2></op2>             | 1                |
|               | Multiply                 | MUL Rd, Rn, Rm                      | 1                |
|               | Multiply accumulate      | MLA Rd, Rn, Rm                      | 2                |
|               | Multiply subtract        | MLS Rd, Rn, Rm                      | 2                |
| Multiply      | Long signed              | SMULL RdLo, RdHi, Rn, Rm            | 3 to 5 (Note 1)  |
|               | Long unsigned            | UMULL RdLo, RdHi, Rn, Rm            | 3 to 5 (Note 1)  |
|               | Long signed accumulate   | SMLAL RdLo, RdHi, Rn, Rm            | 4 to 7 (Note 1)  |
|               | Long unsigned accumulate | UMLAL RdLo, RdHi, Rn, Rm            | 4 to 7 (Note 1)  |
|               | Signed                   | SDIV Rd, Rn, Rm                     | 2 to 12 (Note 2) |
| Divide        | Unsigned                 | UDIV Rd, Rn, Rm                     | 2 to 12 (Note 2) |
| Osturata      | Signed                   | SSAT Rd, # <imm>, <op2></op2></imm> | 1                |
| Saturate      | Unsigned                 | USAT Rd, # <imm>, <op2></op2></imm> | 1                |

# Table 1. Cortex-M3 Instruction Set Table

| Operation | Description                 | Assembler                          | Cycles         |
|-----------|-----------------------------|------------------------------------|----------------|
| Compare   | Compare CMP Rn, <op2></op2> |                                    | 1              |
| Compare   | Negative                    | CMN Rn, <op2></op2>                | 1              |
|           | AND                         | AND Rd, Rn, <op2></op2>            | 1              |
|           | Exclusive OR                | EOR Rd, Rn, <op2></op2>            | 1              |
|           | OR                          | ORR Rd, Rn, <op2></op2>            | 1              |
| Lesier    | OR NOT                      | ORN Rd, Rn, <op2></op2>            | 1              |
| Logical   | Bit clear                   | BIC Rd, Rn, <op2></op2>            | 1              |
|           | Move NOT                    | MVN Rd, <op2></op2>                | 1              |
|           | AND test                    | TST Rn, <op2></op2>                | 1              |
|           | Exclusive OR test           | TEQ Rn, <op1></op1>                |                |
|           | Logical shift left          | LSL Rd, Rn, # <imm></imm>          | 1              |
|           | Logical shift left          | LSL Rd, Rn, Rs                     | 1              |
|           | Logical shift right         | LSR Rd, Rn, # <imm></imm>          | 1              |
| Shift     | Logical shift right         | LSR Rd, Rn, Rs                     | 1              |
|           | Arithmetic shift right      | ASR Rd, Rn, # <imm></imm>          | 1              |
|           | Arithmetic shift right      | ASR Rd, Rn, Rs                     | 1              |
|           | Rotate right                | ROR Rd, Rn, # <imm></imm>          | 1              |
| Rotate    | Rotate right                | ROR Rd, Rn, Rs                     | 1              |
|           | With extension              | RRX Rd, Rn                         | 1              |
| Count     | Leading zeroes              | CLZ Rd, Rn                         | 1              |
|           | Word                        | LDR Rd, [Rn, <op2>]</op2>          | 2 (Note 3)     |
|           | To PC                       | LDR PC, [Rn, <op2>]</op2>          | 2 (Note 3) + P |
|           | Halfword                    | LDRH Rd, [Rn, <op2>]</op2>         | 2 (Note 3)     |
|           | Byte                        | LDRB Rd, [Rn, <op2>]</op2>         | 2 (Note 3)     |
|           | Signed halfword             | LDRSH Rd, [Rn, <op2>]</op2>        | 2 (Note 3)     |
|           | Signed byte                 | LDRSB Rd, [Rn, <op2>]</op2>        | 2 (Note 3)     |
|           | User word                   | LDRT Rd, [Rn, # <imm>]</imm>       | 2 (Note 3)     |
| Load      | User halfword               | LDRHT Rd, [Rn, # <imm>]</imm>      | 2 (Note 3)     |
|           | User byte                   | LDRBT Rd, [Rn, # <imm>]</imm>      | 2 (Note 3)     |
|           | User signed halfword        | LDRSHT Rd, [Rn, # <imm>]</imm>     | 2 (Note 3)     |
|           | User signed byte            | LDRSBT Rd, [Rn, # <imm>]</imm>     | 2 (Note 3)     |
|           | PC relative                 | LDR Rd,[PC, # <imm>]</imm>         | 2 (Note 3)     |
|           | Doubleword                  | LDRD Rd, Rd, [Rn, # <imm>]</imm>   | 1 + N          |
|           | Multiple                    | LDM Rn, { <reglist>}</reglist>     | 1 + N          |
|           | Multiple including PC       | LDM Rn, { <reglist>, PC}</reglist> | 1 + N + P      |
|           | Word                        | STR Rd, [Rn, <op2>]</op2>          | 2 (Note 3)     |
|           | Halfword                    | STRH Rd, [Rn, <op2>]</op2>         | 2 (Note 3)     |
|           | Byte                        | STRB Rd, [Rn, <op2>]</op2>         | 2 (Note 3)     |
|           | Signed halfword             | STRSH Rd, [Rn, <op2>]</op2>        | 2 (Note 3)     |
|           | Signed byte                 | STRSB Rd, [Rn, <op2>]</op2>        | 2 (Note 3)     |
|           | User word                   | STRT Rd, [Rn, # <imm>]</imm>       | 2 (Note 3)     |
|           |                             |                                    |                |

# Table 1. Cortex-M3 Instruction Set Table

| Operation    | Description             | Assembler                                    | Cycles              |
|--------------|-------------------------|----------------------------------------------|---------------------|
|              | User byte               | STRBT Rd, [Rn, # <imm>]</imm>                | 2 (Note 3)          |
|              | User signed halfword    | STRSHT Rd, [Rn, # <imm>]</imm>               | 2 (Note 3)          |
|              | User signed byte        | STRSBT Rd, [Rn, # <imm>]</imm>               | 2 (Note 3)          |
|              | Doubleword              | STRD Rd, Rd, [Rn, # <imm>]</imm>             | 1 + N               |
|              | Multiple                | STM Rn, { <reglist>}</reglist>               | 1 + N               |
|              | Push                    | PUSH { <reglist>}</reglist>                  | 1 + N               |
| Push         | Push with link register | PUSH { <reglist>, LR}</reglist>              | 1 + N               |
| _            | Рор                     | POP { <reglist>}</reglist>                   | 1 + N               |
| Рор          | Pop and return          | POP { <reglist>, PC}</reglist>               | 1 + N + P           |
|              | Load exclusive          | LDREX Rd, [Rn, # <imm>]</imm>                | 2                   |
|              | Load exclusive half     | LDREXH Rd, [Rn]                              | 2                   |
|              | Load exclusive byte     | LDREXB Rd, [Rn]                              | 2                   |
| Semaphore    | Store exclusive         | STREX Rd, Rt, [Rn, # <imm>]</imm>            | 2                   |
|              | Store exclusive half    | STREXH Rd, Rt, [Rn]                          | 2                   |
|              | Store exclusive byte    | STREXB Rd, Rt, [Rn]                          | 2                   |
|              | Clear exclusive monitor | CLREX                                        | 1                   |
|              | Conditional             | B <cc> <label></label></cc>                  | 1 or 1 + P (Note 4) |
|              | Unconditional           | B <label></label>                            | 1 + P               |
|              | With link               | BL <label></label>                           | 1 + P               |
|              | With exchange           | BX Rm                                        | 1 + P               |
| Branch       | With link and exchange  | BLX Rm                                       | 1 + P               |
|              | Branch if zero          | CBZ Rn, <label></label>                      | 1 or 1 + P (Note 4) |
|              | Branch if non-zero      | CBNZ Rn, <label></label>                     | 1 or 1 + P (Note 4) |
|              | Byte table branch       | TBB [Rn, Rm]                                 | 2 + P               |
|              | Halfword table branch   | TBH [Rn, Rm, LSL#1]                          | 2 + P               |
|              | Supervisor call         | SVC # <imm></imm>                            | _                   |
|              | If-then-else            | IT <cond></cond>                             | 1 (Note 5)          |
|              | Disable interrupts      | CPSID <flags></flags>                        | 1 or 2              |
| State change | Enable interrupts       | CPSIE <flags></flags>                        | 1 or 2              |
|              | Read special register   | MRS Rd, <specreg></specreg>                  | 1 or 2              |
|              | Write special register  | MSR <specreg>, Rn</specreg>                  | 1 or 2              |
|              | Breakpoint              | BKPT # <imm></imm>                           | -                   |
|              | Signed halfword to word | SXTH Rd, <op2></op2>                         | 1                   |
|              | Signed byte to word     | SXTB Rd, <op2></op2>                         | 1                   |
| Extend       | Unsigned halfword       | UXTH Rd, <op2></op2>                         | 1                   |
|              | Unsigned byte           | UXTB Rd, <op2></op2>                         | 1                   |
|              | Extract unsigned        | UBFX Rd, Rn, # <imm>,<br/>#<imm></imm></imm> | 1                   |
| Bit field    | Extract signed          | SBFX Rd, Rn, # <imm>,<br/>#<imm></imm></imm> | 1                   |
|              | Clear                   | BFC Rd, Rn, # <imm>,<br/>#<imm></imm></imm>  | 1                   |
|              | Insert                  | BFI Rd, Rn, # <imm>, #<imm></imm></imm>      | 1                   |

### Table 1. Cortex–M3 Instruction Set Table

| Operation | Description                 | Assembler           | Cycles |
|-----------|-----------------------------|---------------------|--------|
|           | Bytes in word               | REV Rd, Rm          | 1      |
| Deverse   | Bytes in both halfwords     | REV16 Rd, Rm        | 1      |
| Reverse   | Signed bottom halfword      | REVSH Rd, Rm        | 1      |
|           | Bits in word                | RBIT Rd, Rm         | 1      |
|           | Send event                  | SEV                 | 1      |
|           | Wait for event              | WFE                 | 1 + W  |
| Hint      | Wait for interrupt          | WFI                 | 1 + W  |
|           | No operation                | NOP                 | 1      |
|           | Instruction synchronization | ISB                 | 1 + B  |
| Barriers  | Data memory                 | DMB                 | 1 + B  |
|           | Data synchronization        | DSB <flags></flags> | 1 + B  |

1. UMULL, SMULL, UMLAL, and SMLAL instructions use early termination depending on the size of the source values. These are interruptible, that is abandoned and restarted, with worst case latency of one cycle.

2. Division operations use early termination to minimize the number of cycles required based on the number of leading ones and zeroes in the input operands.

3. Neighboring load and store single instructions can pipeline their address and data phases. This enables these instructions to complete in a single execution cycle.

4. Conditional branch completes in a single cycle if the branch is not taken.

5. An IT instruction can be folded onto a preceding 16-bit Thumb instruction, enabling execution in zero cycles.

# CORTEX-M3 MICROCONTROLLER AND BUS FABRIC

NCS36510 integrates the powerful and energy efficient ARM Cortex–M3 processor that includes the integrated Nested Vectored Interrupt Controller (NVIC), Wake–up Interrupt Controller (WIC), and Debug Access Port (DAP). The processor uses the Thumb instruction set and is optimized for high performance with reduced code size and low power operation. The ARM Cortex–M3 efficiently handles multiple parallel peripherals and has integrated sleep modes. With industry standard tool chain and support, developing applications on the NCS36510 platform reduces time to market. Test and debug capability is enhanced with the ARM Serial Wire Debug Port with full debug capabilities. The microprocessor uses little–endian formatting.

The NCS36510 implementation of the ARM Cortex–M3 includes a 640 kB integrated FLASH memory (2 banks of 320 kB) with 48 kB of internal RAM memory (3 banks of 16 kB, 1 or 2 retainable in coma mode). The microprocessor, debug port, and memories are interconnected using the Advanced Microcontroller Bus Architecture (AMBA bus) AHB–Lite system interface bus. An AHB to APB Bridge is included to connect the peripherals.

Next to the regular ARM Cortex–M3 processor interrupts, the NCS36510 implements multiple external source interrupts for peripheral devices. A powerful nested, pre–emptive and priority based interrupt handling assure timely and flexible response to external events.

Low power features on NCS36510 include the WIC, adjustable clock rates, and different software controlled power modes to maximize opportunities to save power in final application.

### Serial Wire Debug Access Port (SW-DAP)

The Debug Access Port (DAP) is included in this ARM Cortex–M3 implementation. Standard ARM Cortex–M3 Serial Wire Debugging (SWD) debugging is supported by NCS36510. JTAG is not supported

The NCS36510 implements full trace support for the Cortex–M3 which includes the Data Watchpoint and Trace Unit (DWT) with comparators and counters, Instrumentation Trace Macrocell (ITM), and Embedded Trace Macrocell (ETM).

The Trace Port Interface Unit (TPIU) supports Serial Wire Viewer (SWV) mode.

Refer to the ARM Cortex–M3 technical reference manual for a full definition of the debug system and its capabilities.

The Debug Port is disabled at power-up if the part is locked, and may be enabled by firmware. Driving the DBG\_TEST\_EN pin high will prevent the part from entering coma mode (see the PMU description).

The Debug Access Port interface implementation is the ARM Serial Wire Debug Port (SW–DP) connected to pins DIO[13] (SWCLK), DIO[12] (SWDIO), and DIO[11] (SWO). To enable the DAP drive the DBG\_TEST\_EN pin high and DIO[13] and DIO[12] are automatically reconfigured for DAP usage. The DIO[11] pin will only connect to SWO if the TRCENA bit is enabled.

Use any SWD compliant hardware debugger interface to interact with the internals of the NCS36510.

NCS36510 is optimized for battery powered applications and therefore uses reduced size digital drivers in the DIO pins. In 3V mode, the maximum practical DAP speed is 1 MHz. Adding external buffers could increase this speed but on the ON Semiconductor development board an upper reliable limit has been found at 1MHz.

Not all, if any, SWD debuggers support 1V mode operation.

### **Nested Vectored Interrupt Controller (NVIC)**

The Cortex–M3 Nested Vectored Interrupt Controller (NVIC) supports priority based nested vectored interrupts. It includes 15 built–in or reserved exceptions and is configured with an additional 20 interrupts. Most interrupts have programmable priority. Priority levels available in the NVIC are 0, 64, 128, and 192. Lower numbers are higher priority. The priority of each group can be set separately by the firmware. While an interrupt is being serviced, only interrupts from a higher priority arrive at the same time, the earlier one (according to polling order) will be serviced first. The optional Wake–up Interrupt Controller (WIC) is included for low power mode support. Only a subset of the interrupts are included in the wake–up controller.

| Exception Number | Exception Type    | Priority     | Description                                                                     |
|------------------|-------------------|--------------|---------------------------------------------------------------------------------|
| 1                | Reset             | -3 (Highest) | Reset                                                                           |
| 2                | NMI               | -2           | Non-maskable interrupt. This<br>is set to the watchdog inter-<br>rupt.          |
| 3                | Hard fault        | -1           | All fault conditions if the corre-<br>sponding fault handler is not<br>enabled. |
| 4                | MemManage fault   | Programmable | Memory management fault                                                         |
| 5                | Bus fault         | Programmable | Bus fault                                                                       |
| 6                | Usage fault       | Programmable | Exceptions resulting from pro-<br>gram error.                                   |
| 7–10             | Reserved          |              |                                                                                 |
| 11               | SVC               | Programmable | Supervisor Call                                                                 |
| 12               | Debug Monitor     | Programmable | Debug monitor (breakpoints,<br>watchpoints, or external debug<br>requests)      |
| 13               | Reserved          | Programmable |                                                                                 |
| 14               | PendSV            | Programmable | Pendable Service Call                                                           |
| 15               | SYSTICK           | Programmable | System Tick Timer                                                               |
| 16               | Timer 0           | Programmable | Timer 0 interrupt                                                               |
| 17               | Timer 1           | Programmable | Timer 1 interrupt                                                               |
| 18               | Timer 2           | Programmable | Timer 2 interrupt                                                               |
| 19               | UART              | Programmable | UART interrupt                                                                  |
| 20               | SPI               | Programmable | SPI interrupt                                                                   |
| 21               | I2C               | Programmable | I2C interrupt                                                                   |
| 22               | GPIO              | Programmable | GPIO interrupt                                                                  |
| 23               | RTC               | Programmable | Real-time-clock interrupt                                                       |
| 24               | Flash Controller  | Programmable | Flash Controller.                                                               |
| 25               | MAC               | Programmable | MAC interrupt                                                                   |
| 26               | AES               | Programmable | AES interrupt                                                                   |
| 27               | ADC               | Programmable | ADC interrupt                                                                   |
| 28               | Clock Calibration | Programmable | Clock calibration interrupt                                                     |
| 29               | UART #2           | Programmable | UART Interrupt                                                                  |
| 30               | UVI               | Programmable | Under Voltage Indicator Inter-<br>rupt                                          |
| 31               | DMA               | Programmable | DMA interrupt                                                                   |
| 32               | CDBGPWRUPREQ      | Programmable | Debug request                                                                   |
| 33               | SPI #2            | Programmable | SPI #2 Interrupt                                                                |
| 34               | I2C #2            | Programmable | I2C #2 Interrupt                                                                |
| 35               | FVDDH Comp        | Programmable | FVDDH Supply Comparator<br>Trip                                                 |

### Table 2. Cortex–M3 Instruction Set Table

# **MEMORY MAP**

The 32 bit memory address space is broken up into regions for code, data, and multi-use. Memory elements consist of registers, RAM, and FLASH. A memory region is dedicated to the IOP and APB peripheral access. There are also regions for built in Cortex-M3 registers and NCS36510 peripherals. As in most Cortex-M3 designs there are many unused portions of the memory space. Individual memory regions and elements are described in subsequent sections.

# Flash

NCS36510 contains a total of 640 kB of FLASH memory, organized as two banks of 320 kB each (81,920 words by 32 bits). Two independent FLASH banks are used to allow either OTA upgrades or dual stack applications. If a FLASH bank is unused, it can be powered down to save power.

Both main FLASH banks include an additional 8 kB information block (2048 words by 32 bits).

By default the FLASH A information block contains the bootloader and factory programmed trim values. There are a minimum of three application related trims that can be programmed by the customer: 32.768 kHz external oscillator, 32 MHz external oscillator, and the RSSI offset. These application trims can be determined during the design phase, and for a given PCB design they can be set to a constant value for all boards of the same design. At the factory these are set to a nominal value.

The bootloader is also stored in the FLASH A information block. To reprogram the bootloader it is required to drive the DBG\_TEST\_EN pin high and to write an unlock code to the FLASH. The factory trim contents must be read out, the entire FLASH information block erased, and then the bootloader and factory trims written back in. If the factory trims are lost on a device it will become inoperable as factory trims are not recoverable.

The FLASH B information block does not contain any factory trim information.

# Flash Alias and Remap

NCS36510 has a FLASH remap feature that allows the FLASH A and FLASH B to change positions in the memory map when activated. This makes it easier to reboot the system from FLASH B if doing over the air firmware updates.

Another related feature is the FLASH alias. The FLASH alias allows the FLASH A and FLASH B contents to be visible in a fixed address space regardless of the remap setting.

Both FLASH remap and alias features are shown in the memory map diagrams.

During ON Semiconductor factory test, the factory trim values and bootloader are written to the FLASH A information block. No factory information is written to the FLASH B information block. Software must be careful when using the FLASH remap feature as the factory trims and bootloader could be missed since FLASH A and FLASH B change places in the memory map. An easy way to avoid issues is to use the FLASH A information block alias during boot up because the alias memory map does not depend on the remap setting. The ON Semiconductor software already takes care of this remap functionality, but this feature is important to understand for customers writing their own software.

# RAM

The NCS36510 has three banks of 16kB each RAM. In coma mode either one or two of these banks can be retained.

Test Modes

0x4001F000 0x4001E000

|                             |            |                                                              |                                                         | ,   | Test Modes        | 0X4001F000               |
|-----------------------------|------------|--------------------------------------------------------------|---------------------------------------------------------|-----|-------------------|--------------------------|
|                             |            |                                                              |                                                         | /   | Device Option     | 0x4001E000               |
|                             |            |                                                              |                                                         | i   | PMU               | 0x4001D000               |
| ROM table 0xE00FF0          | 00         |                                                              | 0xFFFFFFFF                                              |     | Pad Control       | 0x4001C000               |
|                             |            | Unused                                                       | 0xE0100000                                              |     | Clock Control     | 0x4001B000               |
| System 0xE00420             |            |                                                              |                                                         |     | Reserved          | 0x4001A000               |
| ETM 0xE00410                |            |                                                              | 0xE00FFFFF                                              | · / | RF/Analog Control | 0x40019000               |
| TPIU 0xE00400               |            | CM3 Reserved                                                 |                                                         | i   | Reset Control     | 0x40018000               |
|                             |            | 486003-8976 (65476-05-07) (966008)                           |                                                         | 1   | Flash Control     | 0x40017000               |
| Reserved 0xE003FF           |            |                                                              | 0xE0000000                                              | 1   | AES               | 0x40016000               |
| 0xE000F0                    |            | Unused                                                       |                                                         | /   | SAR ADC           |                          |
| NVIC 0xE000E0               | _ /        |                                                              | 0x5FFFFFFF                                              | ſ   |                   | 0x40015000<br>0x40014000 |
| Reserved 0xE000DF           |            |                                                              |                                                         |     | MAC Config        |                          |
| 0xE00030                    |            | Peripherals (0.5 G                                           | iB)                                                     |     | Reserved          | 0x40013000               |
| FPB 0xE00020                | 00         |                                                              | 0x40000000                                              |     |                   | 0x40012000               |
| DWT 0xE00010                | 00         |                                                              | 0x3FFFFFFF                                              | l   | Randomizer        | 0x40011000               |
| ITM 0xE00000                | 00         | RAM A (16kB)                                                 | 0,0111111                                               | È.  | Crossbar          | 0x40010000               |
|                             |            |                                                              | 0                                                       | l`\ | RTC               | 0x4000F000               |
|                             |            |                                                              | 0x3FFFC000<br>0x3FFFBFFF                                |     | Reserved          | 0x4000E000               |
|                             |            |                                                              | UX3FFFBFFF                                              |     | I2C #2            | 0x4000D000               |
|                             |            | RAM B (16kB)                                                 |                                                         | i i | GPIO              | 0x4000C000               |
|                             |            |                                                              | 0x3FFF8000<br>0x3FFF7FFF                                | ι N | PWM               | 0x4000B000               |
|                             |            | DAM C (16kB)                                                 | UX3FFF/FFF                                              | ١   | Watchdog          | 0x4000A000               |
|                             |            | RAM C (16kB)                                                 |                                                         | ١   | SPI#2             | 0x40009000               |
|                             |            |                                                              | 0x3FFF4000                                              | . \ | UART #2           | 0x40008000               |
|                             |            | Unused                                                       |                                                         | N 1 | 12C               | 0x40007000               |
|                             |            |                                                              | 0x2400041C                                              |     | SPI               |                          |
|                             |            | DMA (7B)                                                     |                                                         |     |                   | 0x40006000               |
|                             |            |                                                              | 0x24000400                                              | l \ | UART              | 0x40005000               |
|                             | x00351FFF  | Unused                                                       |                                                         |     | Reserved          | 0x40004FFF               |
|                             |            |                                                              | 0x2400015F                                              |     |                   | 0x40003000               |
| FLASH B Alias (320kB        | 3) \       | MAC LUT (96B)                                                | 0X2400013F                                              | i i | Timer 2           | 0x40002000               |
| Program Memory              |            |                                                              | 0x24000100                                              | ) i | Timer 1           | 0x40001000               |
| (                           | 0x00302000 |                                                              | 0x240000FF                                              |     | Timer 0           | 0x4000000                |
|                             | x00301FFF  | MAC RAM (256B)                                               |                                                         |     |                   |                          |
| FLASH B Information         |            |                                                              |                                                         |     |                   |                          |
|                             | i i        |                                                              | 0x24000000                                              |     |                   |                          |
| Block Alias (8kB)           | 1          | Unused                                                       |                                                         |     |                   |                          |
| (                           | Dx00300000 |                                                              |                                                         | 1   |                   |                          |
| Unused                      |            |                                                              |                                                         |     |                   |                          |
|                             | x00251FFF  | FLASH Alias                                                  |                                                         |     |                   |                          |
| FLASH A Alias (320kB        |            |                                                              |                                                         |     |                   |                          |
|                             | ·/         |                                                              |                                                         |     |                   |                          |
| Program Memory              |            | Unused                                                       |                                                         |     |                   |                          |
|                             | Dx00202000 |                                                              | 0x00151FFF                                              |     |                   |                          |
|                             | x00201FFF  |                                                              |                                                         |     |                   |                          |
| FLASH A Information         |            | FLASH B (320kB)                                              | )                                                       |     | NCS36             | \$510                    |
| Block Alias(8kB)            |            | Program Memory                                               |                                                         |     |                   |                          |
| Bootloader and Factory Trim |            | · · · · · · · · · · · · · · · · · · ·                        | 0x00102000                                              |     | Memory            | / Man                    |
| (                           | Dx00200000 |                                                              | 0x00101FFF                                              |     |                   |                          |
|                             |            |                                                              | 0,00101111                                              |     | Defa              | ult                      |
|                             |            | FLASH B Information Blo                                      | ck (8kB)                                                |     | Dola              | ant                      |
|                             |            |                                                              | . ,                                                     |     |                   |                          |
|                             |            |                                                              |                                                         |     |                   |                          |
|                             |            |                                                              | 0x00100000                                              |     |                   |                          |
|                             |            | Unused                                                       | 0x00100000                                              |     |                   |                          |
|                             |            | Unused                                                       |                                                         |     |                   |                          |
|                             |            |                                                              | 0x00051FFF                                              |     |                   |                          |
|                             |            | Unused<br>FLASH A (320kB)                                    | 0x00051FFF                                              |     |                   |                          |
|                             |            |                                                              | 0x00051FFF                                              |     |                   |                          |
|                             |            | FLASH A (320kB)                                              | 0x00051FFF                                              |     |                   |                          |
|                             |            | FLASH A (320kB)                                              | 0x00051FFF<br>0x00002000                                |     |                   |                          |
|                             |            | FLASH A (320kB)<br>Program Memory                            | 0x00051FFF<br>0x00002000<br>0x00001FFF                  |     |                   |                          |
|                             |            | FLASH A (320kB)<br>Program Memory<br>FLASH A Information Blo | 0x00051FFF<br>0<br>0x00002000<br>0x00001FFF<br>ck (8kB) |     |                   |                          |
|                             |            | FLASH A (320kB)<br>Program Memory                            | 0x00051FFF<br>0<br>0x00002000<br>0x00001FFF<br>ck (8kB) |     |                   |                          |
|                             |            | FLASH A (320kB)<br>Program Memory<br>FLASH A Information Blo | 0x00051FFF<br>0<br>0x00002000<br>0x00001FFF<br>ck (8kB) |     |                   |                          |

Figure 2. Default Memory Map



Figure 3. Remapped Memory Map

| Peripheral Register      | Address     | Access | Description                                                                                      |
|--------------------------|-------------|--------|--------------------------------------------------------------------------------------------------|
| TIMER 0                  |             |        |                                                                                                  |
| Load                     | 0x4000_0000 | R/W    | Initial timer value                                                                              |
| Value                    | 0x4000_0004 | RO     | Current value of the timer                                                                       |
| Control                  | 0x4000_0008 | R/W    | Provides enable/disable, mode, and prescale configuration                                        |
| Clear                    | 0x4000_000C | WO     | Clears the interrupt                                                                             |
| TIMER 1                  |             |        | · · ·                                                                                            |
| Load                     | 0x4000_1000 | R/W    | Initial timer value                                                                              |
| Value                    | 0x4000_1004 | RO     | Current value of the timer                                                                       |
| Control                  | 0x4000_1008 | R/W    | Provides enable/disable, mode, and prescale configuration                                        |
| Clear                    | 0x4000_100C | WO     | Clears the interrupt                                                                             |
| TIMER 2                  | ·           |        |                                                                                                  |
| Load                     | 0x4000_2000 | R/W    | Initial timer value                                                                              |
| Value                    | 0x4000_2004 | RO     | Current value of the timer                                                                       |
| Control                  | 0x4000_2008 | R/W    | Provides enable/disable, mode, and prescale configuration                                        |
| Clear                    | 0x4000_200C | WO     | Clears the interrupt                                                                             |
| UART 1                   |             |        |                                                                                                  |
| Receive data             | 0x4000_5000 | RO     | Receive data                                                                                     |
| Transmit data            | 0x4000_5000 | WO     | Transmit data                                                                                    |
| Divisor latch LSB        | 0x4000_5000 | RW     | Least significant byte for input to baud generator                                               |
| Divisor latch MSB        | 0x4000_5004 | RW     | Most significant byte for input to baud generator                                                |
| Interrupt enable         | 0x4000_5004 | RO     | UART interrupt enables                                                                           |
| Interrupt identification | 0x4000_5008 | RO     | UART interrupt type/status register                                                              |
| FIFO control             | 0x4000_500C | WO     | Enable FIFOs, clear FIFOs, etc.                                                                  |
| Line control             | 0x4000_500C | RW     | Specifies asynchronous data communications exchange format and sets the divisor latch access bit |
| Modem control            | 0x4000_5010 | RW     | Controls interface with the modem                                                                |
| Line status              | 0x4000_5014 | RO     | Data transfer status information                                                                 |
| Modem status             | 0x4000_5018 | RO     | Current state of modem control lines                                                             |
| Scratch register         | 0x4000_501C | RW     | Modem scratch register                                                                           |
| SPI 1                    | ·           |        |                                                                                                  |
| Transmit data            | 0x4000_6000 | R/W    | Transmit data                                                                                    |
| Receive data             | 0x4000_6004 | R/W    | Receive data                                                                                     |
| Serial clock divisor     | 0x4000_6008 | R/W    | SPI block clock divider setting (divide MCU clock)                                               |
| Control                  | 0x4000_600C | R/W    | SPI control register                                                                             |
| Status                   | 0x4000_6010 | RO     | SPI status register                                                                              |
| Slave select             | 0x4000_6014 | R/W    | SPI slave select control                                                                         |
| Slave select polarity    | 0x4000_6018 | R/W    | SPI slave select polarity                                                                        |
| Interrupt enable         | 0x4000_601C | R/W    | SPI interrupt enables                                                                            |
| Interrupt status         | 0x4000_6020 | RO     | SPI interrupt status register                                                                    |
| Interrupt clear          | 0x4000_6024 | WO     | SPI interrupts clear register                                                                    |

| Peripheral Register      | Address         | Access | Description                                                                                      |
|--------------------------|-----------------|--------|--------------------------------------------------------------------------------------------------|
| SPI 1                    | - I             |        | · · · ·                                                                                          |
| Transmit FIFO watermark  | 0x4000_6028     | R/W    | Set watermark for transmit FIFO half full flag                                                   |
| Receive FIFO watermark   | 0x4000_602C     | R/W    | Set watermark for receive FIFO half full flag                                                    |
| Transmit FIFO level      | 0x4000_6030     | RO     | Transmit FIFO level                                                                              |
| Receive FIFO level       | 0x4000_6034     | RO     | Receive FIFO level                                                                               |
| I2C 1                    |                 |        |                                                                                                  |
| Status                   | 0x4000_7000     | RO     | I2C status register, clears upon read                                                            |
| Read data                | 0x4000_7004     | RO     | Read data FIFO access                                                                            |
| Command                  | 0x4000_7008     | WO     | I2C configuration                                                                                |
| Interrupt Enable         | 0x4000_700C     | R/W    | Enable or disable I2C interrupts                                                                 |
| Control                  | 0x4000_7010     | R/W    | I2C control                                                                                      |
| Prescale                 | 0x4000_7014     | R/W    | I2C block clock divider setting (divide MCU clock)                                               |
| UART 2                   |                 |        |                                                                                                  |
| Receive data             | 0x4000_8000     | RO     | Receive data                                                                                     |
| Transmit data            | 0x4000_8000     | WO     | Receive data                                                                                     |
| Divisor latch LSB        | 0x4000_8000     | RW     | Least significant byte for input to baud generator                                               |
| Divisor latch MSB        | 0x4000_8004     | RW     | Most significant byte for input to baud generator                                                |
| Interrupt enable         | 0x4000_8004     | RO     | UART interrupt enables                                                                           |
| Interrupt identification | 0x4000_8008     | RO     | UART interrupt type/status register                                                              |
| FIFO control             | 0x4000_800C     | WO     | Enable FIFOs, clear FIFOs, etc.                                                                  |
| Line control             | 0x4000_800C     | RW     | Specifies asynchronous data communications exchange format and sets the divisor latch access bit |
| Modem control            | 0x4000_8010     | RW     | Controls interface with the modem                                                                |
| Line status              | 0x4000_8014     | RO     | Data transfer status information                                                                 |
| Modem status             | 0x4000_8018     | RO     | Current state of modem control lines                                                             |
| Scratch register         | 0x4000_801C     | RW     | Modem scratch register                                                                           |
| SPI 2                    |                 |        | ·                                                                                                |
| Transmit data            | 0x4000_9000     | R/W    | Transmit data                                                                                    |
| Receive data             | 0x4000_9004     | R/W    | Receive data                                                                                     |
| Serial clock divisor     | 0x4000_9008     | R/W    | SPI block clock divider setting (divide MCU clock)                                               |
| Control                  | 0x4000_900C     | R/W    | SPI control register                                                                             |
| Status                   | 0x4000_9010     | RO     | SPI status register                                                                              |
| Slave select             | 0x4000_9014     | R/W    | SPI slave select control                                                                         |
| Slave select polarity    | 0x4000_9018     | R/W    | SPI slave select polarity                                                                        |
| Interrupt enable         | 0x4000_901C     | R/W    | SPI interrupt enables                                                                            |
| Interrupt status         | 0x4000_9020     | RO     | SPI interrupt status register                                                                    |
| Interrupt clear          | 0x4000_9024     | WO     | SPI interrupts clear register                                                                    |
| Transmit FIFO watermark  | 0x4000_9028     | R/W    | Set watermark for transmit FIFO half full flag                                                   |
| Receive FIFO watermark   | 0x4000_902C     | R/W    | Set watermark for receive FIFO half full flag                                                    |
| Transmit FIFO level      | 0x4000_9030     | RO     | Transmit FIFO level                                                                              |
| Receive FIFO level       | <br>0x4000_9034 | RO     | Receive FIFO level                                                                               |

| Peripheral Register                 | Address     | Access              | Description                                                                                                                              |
|-------------------------------------|-------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| WDT                                 |             |                     |                                                                                                                                          |
| Load                                | 0x4000_A000 | R/W                 | Timer load value                                                                                                                         |
| Value                               | 0x4000_A004 | RO                  | Timer current value                                                                                                                      |
| Control                             | 0x4000_A008 | R/W                 | Enable                                                                                                                                   |
| Kick                                | 0x4000_A0C0 | WO                  | Kick (reload timer from load value)                                                                                                      |
| Lock                                | 0x4000_A100 | WO                  | Lock                                                                                                                                     |
| Status                              | 0x4000_A140 | [3] R/W<br>[2:0] RO | Status. Bit 3 is a R/W error bit (busy bit).                                                                                             |
| PWM                                 |             |                     |                                                                                                                                          |
| Duty Cycle                          | 0x4000_B000 | WO                  | Duty cycle configuration                                                                                                                 |
| Enable                              | 0x4000_B004 | WO                  | PWM output enable                                                                                                                        |
| Disable                             | 0x4000_B008 | WO                  | PWM output disable                                                                                                                       |
| Prescale enable                     | 0x4000_B00C | WO                  | Prescale select enable                                                                                                                   |
| Prescale disable                    | 0x4000_B010 | WO                  | Prescale select disable                                                                                                                  |
| Configuration and status            | 0x4000_B014 | RO                  | Read PWM configuration and status                                                                                                        |
| DIO                                 |             |                     |                                                                                                                                          |
| State/Set                           | 0x4000_C000 | R/W                 | Read to see current state of synchronized input<br>signals. Write ones to set corresponding outputs<br>to 1, writes of 0 have no effect. |
| Interrupts/Clear                    | 0x4000_C004 | R/W                 | Read to see current state of interrupts. Write<br>ones to set corresponding outputs to 0, writes of<br>0 have no effect.                 |
| Output Enable Set                   | 0x4000_C008 | WO                  | Write ones to set direction to output, writes of 0 have no effect on signal configuration                                                |
| Output Enable Clear –<br>Make input | 0x4000_C00C | WO                  | Write ones to set direction to input (clears output<br>enable), writes of 0 have no effect on signal con-<br>figuration                  |
| Enable interrupts set               | 0x4000_C010 | WO                  | Write ones to set enable interrupts, writes of 0 have no effect on interrupts configuration                                              |
| Enable interrupts clear             | 0x4000_C014 | WO                  | Write ones to set disable interrupts, writes of 0 have no effect on interrupts configuration                                             |
| Edge interrupts select              | 0x4000_C018 | WO                  | Write ones to set interrupt to edge-sensitive,<br>writes of 0 have no effect on interrupts configura-<br>tion                            |
| Level interrupts select             | 0x4000_C01C | WO                  | Write ones to set interrupt to level-sensitive,<br>writes of 0 have no effect on interrupts configura-<br>tion                           |
| Level interrupts set                | 0x4000_C020 | WO                  | Write ones to set interrupts to active high or rising edge, writes of 0 have no effect on interrupts con-<br>figuration                  |
| Level interrupts clear              | 0x4000_C024 | WO                  | Write ones to clear interrupt for active low or fall-<br>ing edge, writes of 0 have no effect on interrupts<br>configuration             |
| Any edge interrupts set             | 0x4000_C028 | WO                  | Write ones to override interrupt edge selection<br>and interrupt on any edge, writes of 0 have no<br>effect on interrupts configuration  |
| Any edge interrupts clear           | 0x4000_C02C | WO                  | Write ones to clear edge selection override, writes<br>of 0 have no effect on interrupts configuration                                   |
| Interrupts clear                    | 0x4000_C030 | WO                  | Write ones to clear edge sensitive interrupts,<br>writes of 0 have no effect on interrupts configura-<br>tion                            |

| Peripheral Register | Address     | Access | Description                                                                                       |
|---------------------|-------------|--------|---------------------------------------------------------------------------------------------------|
| DIO                 |             |        |                                                                                                   |
| Control             | 0x4000_C034 | WO     | Controls loopback/normal mode operation                                                           |
| I2C 2               |             |        | ·                                                                                                 |
| Status              | 0x4000_D000 | RO     | I2C status register, clears upon read                                                             |
| Read data           | 0x4000_D004 | RO     | Read data FIFO access                                                                             |
| Command             | 0x4000_D008 | WO     | I2C configuration                                                                                 |
| Interrupt enable    | 0x4000_D00C | R/W    | Enable or disable I2C interrupts                                                                  |
| Control             | 0x4000_D010 | R/W    | I2C control                                                                                       |
| Prescale            | 0x4000_D014 | R/W    | I2C block clock divider setting (divide MCU clock)                                                |
| RTC                 |             |        | ·                                                                                                 |
| Sub-second counter  | 0x4000_F000 | R/W    | Sub-second counter. A write loads the written value and a read returns the current counter value. |
| Second counter      | 0x4000_F004 | R/W    | Second counter. A write loads the written value and a read returns the current counter value.     |
| Sub-second alarm    | 0x4000_F008 | R/W    | Sub-second alarm value                                                                            |
| Second alarm        | 0x4000_F00C | R/W    | Second alarm value                                                                                |
| RTC control         | 0x4000_F010 | R/W    | Control register for enables and interrupts                                                       |
| RTC status          | 0x4000_F014 | WO/RO  | Status register for errors, busy, and interrupts                                                  |
| RTC clear           | 0x4000_F018 | WO     | Clears the interrupt status                                                                       |
| CROSSBAR (XBAR)     |             |        |                                                                                                   |
| DIO[0] control      | 0x4001_0000 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[1] control      | 0x4001_0004 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[2] control      | 0x4001_0008 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[3] control      | 0x4001_000C | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[4] control      | 0x4001_0010 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[5] control      | 0x4001_0014 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[6] control      | 0x4001_0018 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[7] control      | 0x4001_001C | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[8] control      | 0x4001_0020 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[9] control      | 0x4001_0024 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[10] control     | 0x4001_0028 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[11] control     | 0x4001_002C | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[12] control     | 0x4001_0030 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[13] control     | 0x4001_0034 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[14] control     | 0x4001_0038 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[15] control     | 0x4001_003C | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[16] control     | 0x4001_0040 | R/W    | Crossbar settings for given DIO pin                                                               |
| DIO[17] control     | 0x4001_0044 | R/W    | Crossbar settings for given DIO pin                                                               |
| TRNG                | ı L         |        |                                                                                                   |
| Value               | 0x4001_1000 | R/W    | On a write sets the seed value, on a read returns random number                                   |
| Control             | 0x4001_1004 | R/W    | Control register                                                                                  |

| Peripheral Register          | Address             | Access           | Description                                                         |
|------------------------------|---------------------|------------------|---------------------------------------------------------------------|
| TRNG                         | I                   |                  |                                                                     |
| Write buffer LSW             | 0x4001_1008         | R/W              | Byte swap write buffer - Least significant word                     |
| Write buffer MSW             | 0x4001_100C         | R/W              | Byte swap write buffer – Most significant word                      |
| Read buffer LSW              | 0x4001_1010         | RO               | Byte swap read buffer – Least significant word                      |
| Read buffer MSW              | 0x4001_1014         | RO               | Byte swap read buffer – Most significant word                       |
| Meta-stable latch TRNG value | 0x4001_1018         | RO               | Meta-stable latch TRNG value                                        |
| White noise TRNG value       | 0x4001_101C         | RO               | White noise TRNG value                                              |
| IEEE 802.15.4 MEDIUM ACC     | ESS CONTROL (MAC) - | EXPERT REGISTERS |                                                                     |
| Sequencer                    | 0x4001_4000         | R/W              | Used to control MAC sequence operation                              |
| Sequence options             | 0x4001_4004         | R/W              | Set options that change behavior of basic events                    |
| Control                      | 0x4001_4008         | R/W              | Control register                                                    |
| Status                       | 0x4001_4010         | RO               | Status register                                                     |
| Options                      | 0x4001_4014         | R/W              | Options register                                                    |
| PANID                        | 0x4001_4018         | R/W              | Sets the MAC PAN ID                                                 |
| Short address                | 0x4001_401C         | R/W              | Device 16-bit short address                                         |
| Long address (MSW)           | 0x4001_4020         | R/W              | The upper 32-bits of the device ID                                  |
| Long address (LSW)           | 0x4001_4024         | R/W              | The lower 32-bits of the device ID                                  |
| Divider                      | 0x4001_4028         | R/W              | Prescaler divider for the protocol timer                            |
| RX/TX warmups                | 0x4001_402C         | R/W              | Set the warmup time for the transmitter & receiver                  |
| Clear interrupts             | 0x4001_4030         | WO               | Clears active interrupts                                            |
| Enable interrupts            | 0x4001_4034         | R/W              | Enables/Disables certain interrupts                                 |
| Interrupt status             | 0x4001_4038         | RO               | Interrupt status                                                    |
| Timer enable                 | 0x4001_4040         | R/W              | Protocol timer control                                              |
| Timer disable                | 0x4001_4044         | R/W              | Protocol timer control                                              |
| Timer                        | 0x4001_4048         | R/W              | Protocol timer                                                      |
| Start time                   | 0x4001_404C         | R/W              | Event start time                                                    |
| Stop time                    | 0x4001_4050         | R/W              | Event stop time                                                     |
| Timer status                 | 0x4001_4054         | RO               | Start and stop timer status                                         |
| Protocol timer state         | 0x4001_4058         | RO               | Protocol timer state                                                |
| Finish time                  | 0x4001_4060         | RO               | Records event finish time                                           |
| Slot offset                  | 0x4001_4064         | R/W              | Slot offset                                                         |
| Time stamp                   | 0x4001_4068         | RO               | Records the protocol timer when the frame length field is received. |
| Coordinator short address    | 0x4001_406C         | R/W              | Coordinator short address                                           |
| Coordinator long address     | 0x4001_4070         | R/W              | Coordinator long address (MSW)                                      |
| Coordinator long address     | 0x4001_4074         | R/W              | Coordinator long address (LSW)                                      |
| RX Length                    | 0x4001_4088         | RO               | The length of the received frame                                    |
| TX Length                    | 0x4001_408C         | R/W              | The length of the transmit frame                                    |
| TX sequence number           | 0x4001_4090         | R/W              | Sequence number to be used for the transmit frame                   |
| TX ACK delay                 | 0x4001_4094         | R/W              | Delay from end of frame receive to start of ACK transmit            |

| Peripheral Register       | Address             | Access           | Description                                                                                         |
|---------------------------|---------------------|------------------|-----------------------------------------------------------------------------------------------------|
| IEEE 802.15.4 MEDIUM ACC  | ESS CONTROL (MAC) - | EXPERT REGISTERS | ·                                                                                                   |
| RX ACK delay              | 0x4001_4098         | R/W              | Delay from end of frame transmit to begin of auto-<br>matic receive ACK                             |
| TX flush                  | 0x4001_409C         | R/W              | Set extra time to hold transmitter on at the end of a transmitted frame                             |
| CCA                       | 0x4001_40A0         | R/W              | Set CCA measurement length & delay between<br>CCA measurements for a slotted mode transmis-<br>sion |
| ACK stop                  | 0x4001_40A4         | R/W              | Length of time receive hardware will wait for in-<br>coming ACK                                     |
| TX CCA delay              | 0x4001_40A8         | R/W              | Delay from last CCA measurement to start of<br>frame transmit                                       |
| Long address LUT          | 0x4001_40AC         | R/W              | Long address look up table (LUT)                                                                    |
| Short Address LUT         | 0x4001_40B0         | R/W              | Short address look up table (LUT)                                                                   |
| Frame match result        | 0x4001_40B4         | RO               | Result vector from frame matching                                                                   |
| Frame match long address  | 0x4001_40B8         | RO               | Long address from LUT for frame matched ad-<br>dressed                                              |
| Frame match short address | 0x4001_40BC         | RO               | Short address from LUT for frame matched ad-<br>dressed                                             |
| AGC control               | 0x4001_40C0         | R/W              | Receiver Automatic Gain Control (AGC) control register                                              |
| AGC settings              | 0x4001_40C4         | R/W              | Receiver Automatic Gain Control (AGC) settings register                                             |
| AGC status                | 0x4001_40C8         | RO               | Receiver Automatic Gain Control (AGC) status register                                               |
| AGC gain table 0          | 0x4001_40CC         | R/W              | Receiver Automatic Gain Control (AGC) gain ta-<br>ble 0                                             |
| AGC gain table 1          | 0x4001_40D0         | R/W              | Receiver Automatic Gain Control (AGC) gain ta-<br>ble 1                                             |
| AGC gain table 2          | 0x4001_40D4         | R/W              | Receiver Automatic Gain Control (AGC) gain ta-<br>ble 2                                             |
| AGC gain table 3          | 0x4001_40D8         | R/W              | Receiver Automatic Gain Control (AGC) gain ta-<br>ble 3                                             |
| Demodulator control 0     | 0x4001_4100         | R/W              | Receiver demodulator control 0                                                                      |
| Demodulator control 1     | 0x4001_4104         | R/W              | Receiver demodulator control 1                                                                      |
| Demodulator control 2     | 0x4001_4108         | R/W              | Receiver demodulator control 2                                                                      |
| Demodulator status        | 0x4001_410C         | RO               | Receiver demodulator status                                                                         |
| SAR ADC                   |                     |                  | •                                                                                                   |
| Control                   | 0x4001_5000         | R/W              | Control the ADC                                                                                     |
| Delay                     | 0x4001_5004         | R/W              | Sets timing critical values of the ADC                                                              |
| Data                      | 0x4001_5008         | RO               | Data from the ADC                                                                                   |
| Interrupt                 | 0x4001_500C         | R/W              | Interrupt control                                                                                   |
| Prescaler                 | 0x4001_5010         | R/W              | Prescaler for the ADC clock                                                                         |
| Status                    | 0x4001_5014         | RO               | Status                                                                                              |
| AES                       |                     |                  |                                                                                                     |
| Key 0                     | 0x4001_6000         | WO               | Least significant word of key                                                                       |
| Key 1                     | 0x4001_6004         | WO               | Next significant word of key                                                                        |

| Peripheral Register | Address     | Access | Description                                                           |
|---------------------|-------------|--------|-----------------------------------------------------------------------|
| AES                 |             |        |                                                                       |
| Key 2               | 0x4001_6008 | WO     | Next significant word of key                                          |
| Key 3               | 0x4001_600C | WO     | Most significant word of 128 bit key                                  |
| Key 4               | 0x4001_6010 | WO     | Next significant word of key                                          |
| Key 5               | 0x4001_6014 | WO     | Next significant word of key                                          |
| Key 6               | 0x4001_6018 | WO     | Next significant word of key                                          |
| Key 7               | 0x4001_601C | WO     | Most significant word of 256 bit key                                  |
| Counter 0           | 0x4001_6020 | R/W    | Least significant word of counter                                     |
| Counter 1           | 0x4001_6024 | R/W    | Next significant word of counter                                      |
| Counter 2           | 0x4001_6028 | R/W    | Next significant word of counter                                      |
| Counter 3           | 0x4001_602C | R/W    | Most significant word of counter                                      |
| Counter result 0    | 0x4001_6030 | RO     | Least significant word of counter result                              |
| Counter result 1    | 0x4001_6034 | RO     | Next significant word of counter result                               |
| Counter result 2    | 0x4001_6038 | RO     | Next significant word of counter result                               |
| Counter result 3    | 0x4001_603C | RO     | Most significant word of counter result                               |
| CBC result 0        | 0x4001_6040 | RO     | Least significant word of CBC result                                  |
| CBC result 1        | 0x4001_6044 | RO     | Next significant word of CBC result                                   |
| CBC result 2        | 0x4001_6048 | RO     | Next significant word of CBC result                                   |
| CBC result 3        | 0x4001_604C | RO     | Next significant word of CBC result                                   |
| Control             | 0x4001_6050 | R/W    | Clear interrupt, clear CBC accumulator, start en-<br>cryption command |
| Mode                | 0x4001_6054 | R/W    | Set encryption mode, length, and enable/disable interrupt mask        |
| Status              | 0x4001_6058 | RO     | Status register                                                       |
| MAC Initial value 0 | 0x4001_605C | R/W    | Least significant word of the 128-bit CBC initial data                |
| MAC Initial value 1 | 0x4001_6060 | R/W    | Next significant word of the 128-bit CBC initial data                 |
| MAC Initial value 2 | 0x4001_6064 | R/W    | Next significant word of the 128-bit CBC initial data                 |
| MAC Initial value 3 | 0x4001_6068 | R/W    | Most significant word of the 128-bit CBC initial data                 |
| Data 0              | 0x4001_6070 | R/W    | Least significant word of data to encrypt                             |
| Data 1              | 0x4001_6074 | R/W    | Next significant word of data to encrypt                              |
| Data 2              | 0x4001_6078 | R/W    | Next significant word of data to encrypt                              |
| Data 3              | 0x4001_607C | R/W    | Most significant word of data to encrypt                              |
| FLASH Control       |             |        |                                                                       |
| Status              | 0x4001_7000 | RO     | Flash Controller Status Registers                                     |
| Control             | 0x4001_7004 | R/W    | Flash Control Register                                                |
| Command             | 0x4001_7008 | R/W    | Flash Command Register                                                |
| Address             | 0x4001_700C | R/W    | Flash Address Register                                                |
| Unlock command      | 0x4001_7010 | R/W    | Unlock command required before unlocking either<br>FLASH A or B       |
|                     |             |        |                                                                       |

| Peripheral Register               | Address            | Access                           | Description                                                                                                                                                                       |
|-----------------------------------|--------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FLASH Control                     | L                  |                                  |                                                                                                                                                                                   |
| Unlock FLASH B                    | 0x4001_7018        | R/W                              | Unlock FLASH B                                                                                                                                                                    |
| Interrupt                         | 0x4001_701C        | RO                               | Interrupt status                                                                                                                                                                  |
| Reset Control                     |                    |                                  |                                                                                                                                                                                   |
| Reset sources                     | 0x4001_8000        | RO                               | Status of all reset sources                                                                                                                                                       |
| Clear reset sources               | 0x4001_8004        | WO                               | Clears the reset sources register                                                                                                                                                 |
| Hardware revision number          | 0x4001_8008        | RO                               | Specifies the hardware revision number                                                                                                                                            |
| Control                           | 0x4001_800C        | R/W                              | External RESETN reset and WDT reset impact or debug logic                                                                                                                         |
| RF AND ANALOG CONTROL             | – EXPERT REGISTERS |                                  |                                                                                                                                                                                   |
| TX frequency control              | 0x4001_9000        | R/W                              | Sets the transmit integer and fractional divider words for PLL                                                                                                                    |
| RX frequency control              | 0x4001_9004        | R/W                              | Sets the receive integer and fractional divider words for PLL                                                                                                                     |
| Transmit power                    | 0x4001_9010        | R/W                              | Sets the output transmit power, not the same as<br>settings required by IEEE 802.15.4 as handled by<br>the MAC software. This is the raw power control<br>to the power amplifier. |
| Receiver gain                     | 0x4001_9014        | RO                               | Current receiver gain value from AGC module                                                                                                                                       |
| FVDDH supply comparator threshold | 0x4001_9084        | R/W                              | Sets the threshold to compare against                                                                                                                                             |
| Transmitter trim                  | 0x4001_9094        | [3:0] R/W                        | Transmitter pre-driver tank circuit trim. Board design dependent.                                                                                                                 |
| CLOCK CONTROL                     |                    |                                  |                                                                                                                                                                                   |
| Control                           | 0x4001_B000        | [4] R/W<br>[3:2] WO<br>[1:0] R/W | RTC clock enable<br>Enable/disable 32MHz/32.768kHz internal oscilla<br>tor calibration<br>32MHz oscillator source internal or external                                            |
| Status                            | 0x4001_B004        | RO                               | Status register for state of DBG_TEST_EN pin<br>and clock calibrations and clock source readiness                                                                                 |
| Interrupt enable                  | 0x4001_B008        | R/W                              | Clock calibration interrupt enable register                                                                                                                                       |
| Clear                             | 0x4001_B00C        | WO                               | Clear the interrupt & status registers                                                                                                                                            |
| Peripheral disable                | 0x4001_B010        | R/W                              | Peripheral block disable register (gates clock to peripheral blocks)                                                                                                              |
| FCLK prescaler                    | 0x4001_B014        | R/W                              | FCLK prescaler value                                                                                                                                                              |
| TRACECLK prescaler                | 0x4001_B018        | R/W                              | Trace clock prescaler value                                                                                                                                                       |
| Internal 32MHz trim               | 0x4001_B020        |                                  | The internal 32MHz RC oscillator trim value                                                                                                                                       |
| Internal 32.768kHz trim           | 0x4001_B024        |                                  | The internal 32kHz RC oscillator trim value                                                                                                                                       |
| External 32MHz trim               | 0x4001_B028        |                                  | The external 32MHz crystal oscillator trim and settings                                                                                                                           |
| External 32.768kHz trim           | 0x4001_B02C        |                                  | The external 32.768kHz crystal oscillator trim and settings                                                                                                                       |
| DIO PAD CONTROL                   |                    |                                  |                                                                                                                                                                                   |
| DIO[0] and control                | 0:4001 0000        |                                  | Output driver configuration (open drain or puch)                                                                                                                                  |

| DIO[0] pad control | 0x4001_C000 | R/W | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad |
|--------------------|-------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|
| DIO[1] pad control | 0x4001_C004 | R/W | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad |

# Table 3. PERIPHERAL REGISTER TABLE SUMMARY

Status

| Peripheral Register | Address     | Access | Description                                                                                                                                                                                                                                          |
|---------------------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIO PAD CONTROL     | · •         |        |                                                                                                                                                                                                                                                      |
| DIO[2] pad control  | 0x4001_C008 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[3] pad control  | 0x4001_C00C | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[4] pad control  | 0x4001_C010 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[5] pad control  | 0x4001_C014 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[6] pad control  | 0x4001_C018 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[7] pad control  | 0x4001_C01C | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[8] pad control  | 0x4001_C020 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[9] pad control  | 0x4001_C024 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[10] pad control | 0x4001_C028 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[11] pad control | 0x4001_C02C | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[12] pad control | 0x4001_C030 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[13] pad control | 0x4001_C034 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[14] pad control | 0x4001_C038 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[15] pad control | 0x4001_C03C | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[16] pad control | 0x4001_C040 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| DIO[17] pad control | 0x4001_C044 | R/W    | Output driver configuration (open drain or push/<br>pull), drive strength, and/or weak pull (up/down/<br>both/none) setting for related DIO pad                                                                                                      |
| POWER MANAGEMENT UN | IIT (PMU)   |        | · · ·                                                                                                                                                                                                                                                |
| Control             | 0x4001_D000 |        | Control settings including UVI, Debugger power<br>mode behavior, pre-regulator settings in active<br>and coma modes, internal and external slow and<br>fast clock controls, coma mode RAM controls,<br>and power mode behavior after WFI instruction |
| <u></u>             |             |        |                                                                                                                                                                                                                                                      |

RO

Status

0x4001\_D004

# Table 3. PERIPHERAL REGISTER TABLE SUMMARY

| Peripheral Register         | Address     | Access                 | Description                                                                            |  |  |  |
|-----------------------------|-------------|------------------------|----------------------------------------------------------------------------------------|--|--|--|
| POWER MANAGEMENT UNIT (PMU) |             |                        |                                                                                        |  |  |  |
| FVDD power up               | 0x4001_D00C |                        | Flash power supply up timer                                                            |  |  |  |
| FVDD power down             | 0x4001_D010 |                        | Flash power supply down timer                                                          |  |  |  |
| UVI time base               | 0x4001_D018 | [13:8] RO<br>[5:0] R/W | Read only value for number of cycles comparator<br>is high<br>Threshold for comparator |  |  |  |
| RAM trim                    | 0x4001_D01C |                        | FMS?                                                                                   |  |  |  |

### Table 4. DMA REGISTER TABLE SUMMARY

| Register            | Address     | Access | Description                  |
|---------------------|-------------|--------|------------------------------|
| DMA                 |             |        |                              |
| Control             | 0x2400_0400 | R/W    | Control register             |
| Source address      | 0x2400_0404 | R/W    | Source address register      |
| Destination address | 0x2400_0408 | R/W    | Destination address register |
| Transfer size       | 0x2400_040C | R/W    | Transfer size register       |
| Status              | 0x2400_0410 | RO     | Status register              |
| Interrupt enable    | 0x2400_0414 | R/W    | Interrupt enable register    |
| Interrupt status    | 0x2400_0418 | RO     | Interrupt status register    |

# DBG\_TEST\_EN Pin

The DBG\_TEST\_EN pin has several system level impacts that need to be understood by the software developer. This section documents all the interactions this pin's state has on the system. Further details are located throughout the document but summarized here.

The DBG\_TEST\_EN pin must be driven high to enable SW–DAP debugging. See the SW–DAP section for more details about debugging.

If programming the FLASH A information blocks, or in other words programming the bootloader or modifying factory trims, the DBG\_TEST\_EN pin must be high as well

# FLASH CONTROLLER

### Description

The flash controller is used to interface with the two FLASH arrays A, and B.

During boot-up or when coming out of deep-sleep mode there is a delay before the FLASH is available for read, write, or erase operations. This delay is due to the start-up time of the internal FLASH power supplies. During this power-up time, the busy bit will be set to high in the status register. Since the processor may start to try to boot during this time, the FLASH controller will store the address and read command but not assert the ready signal until the FLASH becomes available and the correct address has been read. The read will complete at that point and the data will be returned on the bus. The error bits in the status register will be set to the code for attempted access while the FLASH array is busy powering up. as the unlock codes written to the FLASH controller (the DBG\_TEST\_EN state influences some timeouts in the FLASH controller also). Further details are given in the FLASH controller section.

Warning: The NCS36510 has a POR test mode intended for use during ON Semiconductor factory testing only. If the DBG\_TEST\_EN pin is high, and the RESETN pin low while powering up the device, this POR test mode will be activated. The DIO[0] pin will mirror the internal POR signal. The only way to exit this mode is to power down the device, and restart with the DBG\_TEST\_EN pin low and or the RESETN pin high.

However if a write is attempted while the FLASH is busy powering up, that write will be ignored and the status register will show an error for attempted access while the array is busy powering up. If interrupts are enabled for access error, that interrupt will be generated.

Two types of erase operations are allowed: a page erase and a mass erase. A page erase will erase a single page in a memory region. A mass erase will erase an entire array. Once an erase operation is complete the FLASH arrays are written to via a write operation on the AHB bus.

It is only allowed to do two write cycles to a single location per erase cycle. Meaning for a 32 bit wide array, software can only write to a single location twice before the location must be erased again. Hardware does not perform any monitoring of this condition.

While a FLASH instance is being programmed, it cannot support any other access. In some circumstances, it may be advantageous to have the HREADYOUT signal simply prevent whatever is attempting access to the FLASH have all transactions freeze until the write operation completes. For other cases, having, for instance, the CPU hang until the write operation completes is not desired. The 'Block AHB bus during write' bit in the Control register allows for both methods. If this bit is cleared (0), then the processor, debugger, etc. can perform a write and continue on with other operations immediately. In this mode, the busy bits must be polled, or an interrupt used to determine when the flash becomes available. If this bit is set (1), then the process writing the FLASH will hang until the flash completes writing. This is mode is required to use DMA to write to the FLASH.

| Function                                                               | Bits                                      | Default                               | Туре             | Description                                                                                                                                                                                                            |
|------------------------------------------------------------------------|-------------------------------------------|---------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FLASH Controller Status Regis                                          | ster: 0x4001_7000                         | -                                     | I.               | -                                                                                                                                                                                                                      |
| Status register that indicates if an<br>and/or FLASH B are busy. Clean |                                           | errors are encounte                   | ered, if FLASH   | A and/or FLASH B are unlocked, and if FLASH A                                                                                                                                                                          |
| Error type                                                             | [7:5]                                     | 0x00                                  | RO               | 000 – No error<br>111 – Attempt to access an array powering up<br>001 – Attempt to erase bootloader<br>(DBG_TEST_EN = low)<br>010 – Attempt to access array during erase<br>100 – Attempt to access array during write |
| FLASH B unlocked indicator                                             | [3]                                       | 0x0                                   | RO               | 0 – FLASH B is locked<br>1 – FLASH B is unlocked                                                                                                                                                                       |
| FLASH A unlocked indicator                                             | [2]                                       | 0x0                                   | RO               | 0 – FLASH A is locked<br>1 – FLASH A is unlocked                                                                                                                                                                       |
| FLASH B busy indicator                                                 | [1]                                       | 0x0                                   | RO               | 0 – FLASH B is not busy<br>1 – FLASH B is busy                                                                                                                                                                         |
| FLASH A busy indicator                                                 | [0]                                       | 0x0                                   | RO               | 0 – FLASH A is not busy<br>1 – FLASH A is busy                                                                                                                                                                         |
| FLASH Controller Control Regi                                          | ister: 0x4001_7004                        | 4                                     |                  |                                                                                                                                                                                                                        |
| FLASH controller control register controls.                            | for FLASH A and                           | B to control AHB b                    | us blocking, int | terrupt control, remap control, and power down                                                                                                                                                                         |
| Block AHB bus during write                                             | [6]                                       | 0x0                                   | R/W              | 0 – AHB HREADYOUT high during write<br>1 – AHB HREADYOUT low during write                                                                                                                                              |
| Error interrupts control                                               | [5]                                       | 0x0                                   | R/W              | 0 – Disable FLASH errors interrupts<br>1 – Enable FLASH errors interrupts                                                                                                                                              |
| Erase interrupts control                                               | [4]                                       | 0x0                                   | R/W              | 0 – Disable FLASH erase complete interrupts<br>1 – Enable FLASH erase complete interrupts                                                                                                                              |
| Write interrupts control                                               | [3]                                       | 0x0                                   | R/W              | 0 – Disable FLASH write complete interrupts<br>1 – Enable FLASH write complete interrupts                                                                                                                              |
| Enable remap function                                                  | [2]                                       | 0x0                                   | R/W              | 0 – Default memory map<br>1 – Remapped memory map                                                                                                                                                                      |
| FLASH A power down con-<br>trol                                        | [1]                                       | 0x0                                   | R/W              | 0 – FLASH A powered on<br>1 – FLASH A powered off                                                                                                                                                                      |
| FLASH B power down con-<br>trol                                        | [0]                                       | 0x0                                   | R/W              | 0 – FLASH B powered on<br>1 – FLASH B powered off                                                                                                                                                                      |
| Function                                                               | Bits                                      | Default                               | Туре             | Description                                                                                                                                                                                                            |
| FLASH Controller Command R<br>FLASH controller command regis           |                                           |                                       | e erase, or ma   | ss erase.                                                                                                                                                                                                              |
| Command                                                                | [1:0]                                     | 0x00                                  | R/W              | 00 – No operation, array is read-only<br>01 – Page erase<br>10 – Mass erase                                                                                                                                            |
|                                                                        | er for FLASH A and<br>example if this reg | B. When doing a lister is set to 0x00 | 0102FF and a     | e lower LSBs are ignored. During a mass erase<br>mass erase command is given, the entire main<br>00100200.                                                                                                             |

| Function                                                                                                                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                                                                                                                                                                                                                        | Default                                                                                                                                                                                                                 | Туре                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address pointer                                                                                                                                                                                                                                                                                                                                                                                                | [31:0]                                                                                                                                                                                                                                                                                                                      | 0x00000000                                                                                                                                                                                                              | R/W                                                                                      | Address pointer for FLASH page and mass<br>erase operations                                                                                                                                                                                                                                                                                                                                                                                   |
| Function                                                                                                                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                                                                                                                                                                                                                        | Default                                                                                                                                                                                                                 | Туре                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| procedure. After this register is<br>be written within 20 clock cycle                                                                                                                                                                                                                                                                                                                                          | er for FLASH A and E<br>written with the prop<br>(HCLK) or the FLAS<br>ck register and corres                                                                                                                                                                                                                               | B. This register mu<br>er unlock code, the<br>SH controller autor                                                                                                                                                       | e corresponding<br>matically relock                                                      | 0xBB781AE9 to start the FLASH A or B unlock<br>g unlock FLASH A and/or FLASH B registers mus<br>s. If the DBG_TEST_EN pin is high, there is no<br>I B unlock registers have to be unlocked before a                                                                                                                                                                                                                                           |
| FLASH unlock                                                                                                                                                                                                                                                                                                                                                                                                   | [31:0]                                                                                                                                                                                                                                                                                                                      | 0x4487E516                                                                                                                                                                                                              | R/W                                                                                      | Write to 0xBB781AE9 to start unlock se-<br>quence. See note above for timing re-<br>quirements and DBG_TEST_EN influence.                                                                                                                                                                                                                                                                                                                     |
| Function                                                                                                                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                                                                                                                                                                                                                        | Default                                                                                                                                                                                                                 | Туре                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| after the erase or write cycle c<br>FLASH A unlock                                                                                                                                                                                                                                                                                                                                                             | [31:0]                                                                                                                                                                                                                                                                                                                      | 0x4A926F66                                                                                                                                                                                                              | R/W                                                                                      | Write to 0xB56D9099 to complete unlock se-<br>quence. Requires unlocking register<br>0x40017010 first.                                                                                                                                                                                                                                                                                                                                        |
| Function                                                                                                                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                                                                                                                                                                                                                        | Default                                                                                                                                                                                                                 | Туре                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| FLASH controller unlock regist dure. The unlock FLASH regis                                                                                                                                                                                                                                                                                                                                                    | er for FLASH B. This<br>ter 0x40017010 must                                                                                                                                                                                                                                                                                 | register must be w<br>be unlocked befor                                                                                                                                                                                 |                                                                                          | D9099 to complete the FLASH B unlock proce-<br>an take effect. This register automatically relocks                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                | er for FLASH B. This<br>ter 0x40017010 must                                                                                                                                                                                                                                                                                 | register must be w<br>be unlocked befor                                                                                                                                                                                 |                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| FLASH controller unlock regist<br>dure. The unlock FLASH regis<br>after the erase or write cycle c<br>FLASH B unlock<br><b>Function</b>                                                                                                                                                                                                                                                                        | er for FLASH B. This<br>ter 0x40017010 must<br>ompletes on FLASH E<br>[31:0]<br>Bits                                                                                                                                                                                                                                        | register must be w<br>be unlocked befor<br>3.<br>0x4A926F66<br>Default                                                                                                                                                  | e this unlock ca                                                                         | An take effect. This register automatically relocks<br>Write to 0xB56D9099 to complete unlock se-<br>quence. Requires unlocking register                                                                                                                                                                                                                                                                                                      |
| FLASH controller unlock regist<br>dure. The unlock FLASH regis<br>after the erase or write cycle c<br>FLASH B unlock<br>FUNCTION<br>FLASH Controller Interrupt S<br>FLASH related interrupts may<br>1. Access errors. If the sy<br>bit 5 of the FLASH Co-<br>interrupt may be cleared<br>2. Erase complete. On co-<br>interrupt will be general<br>reading the FLASH co-<br>3. Program complete. Or            | er for FLASH B. This<br>ter 0x40017010 must<br>ompletes on FLASH E<br>[31:0]<br>Bits<br>tatus Register: 0x40<br>be generated under th<br>ystem attempts to accontrol Register is set to<br>ed by reading the FLA<br>ompletion of either a p<br>ated when an erase op<br>ntroller status register<br>a completion of writing | ox4A926F66<br>Default<br>0x4A926F66<br>Default<br>01_701C<br>nree conditions:<br>ess an array while<br>a 1, an attempt to<br>SH controller state<br>page erase, or a more<br>peration completes<br>a data to an address | e it is busy powe<br>access the arrus register.<br>ass erase. If bit<br>s, either page o | An take effect. This register automatically relocks           Write to 0xB56D9099 to complete unlock sequence. Requires unlocking register 0x40017010 first.           Description                                                                                                                                                                                                                                                            |
| FLASH controller unlock regist<br>dure. The unlock FLASH regis<br>after the erase or write cycle c<br>FLASH B unlock<br>FLASH Controller Interrupt S<br>FLASH related interrupts may<br>1. Access errors. If the sy<br>bit 5 of the FLASH Co<br>interrupt may be cleared<br>2. Erase complete. On co<br>interrupt will be generat<br>reading the FLASH co<br>3. Program complete. Or<br>will be generated when | er for FLASH B. This<br>ter 0x40017010 must<br>ompletes on FLASH E<br>[31:0]<br>Bits<br>tatus Register: 0x40<br>be generated under th<br>ystem attempts to accontrol Register is set to<br>ed by reading the FLA<br>ompletion of either a p<br>ated when an erase op<br>ntroller status register<br>a completion of writing | ox4A926F66<br>Default<br>0x4A926F66<br>Default<br>01_701C<br>nree conditions:<br>ess an array while<br>a 1, an attempt to<br>SH controller state<br>page erase, or a more<br>peration completes<br>a data to an address | e it is busy powe<br>access the arrus register.<br>ass erase. If bit<br>s, either page o | An take effect. This register automatically relocks           Write to 0xB56D9099 to complete unlock sequence. Requires unlocking register 0x40017010 first.           Description   ering up, being programmed, or being erased. If ay while it is busy will generate an interrupt. The t 4 of the FLASH control register is set to a 1, an r mass erase. The interrupt may be cleared by FLASH control register is set to a 1, an interrupt |

### RESET AND BROWNOUT CONTROL Description

NCS36510 has various reset sources: Power–On Reset (POR) and Brownout (BO), external reset, software reset, and watchdog timer reset.

The Cortex–M3 lockup bit is also made available, but does not directly cause any reset to be applied.

### Internal Power-On Reset and Brownout

The POR and BO functions are combined in the Power Management Unit (PMU). During startup, the POR is released when V3V is at a high enough voltage to support the internal digital logic voltage regulators. After power up the voltage at V1V is monitored and if it gets too low, a brownout reset is generated. A POR and a brownout have the same effect on the system which is a full reset including the processor debug logic. Upon POR or BO the processor jumps to the reset vector and the system reboots.

### External Reset

When the external reset pin is driven low, the NCS36510 is held in reset. The processor debug logic is not reset.

Warning: The NCS36510 has a POR test mode intended for use during ON Semiconductor factory testing only. If the DBG\_TEST\_EN pin is high, and the RESETN pin low while powering up the device, this POR test mode will be activated. The DIO[0] pin will mirror the internal POR signal. The only way to exit this mode is to power down the device, and restart with the DBG\_TEST\_EN pin low and or the RESETN pin high.

### Software Reset

Software reset can be called when switching from one application to the other, after remap of the FLASH banks, or on exit of a processor exception. The software requested reset will not reset all processor or peripheral device registers.

### Watchdog Timer Reset

NCS36510 implements a programmable watchdog timer. The watchdog timer is disabled by default and the application software needs to instantiate the watchdog timer driver and enable it. The WDT has a register locking safety mechanism to prevent errant software from corrupting the WDT registers. While locked the only supported operation is a clear. The watchdog is on the 32.768 kHz clock domain so it has a minimum resolution of  $30.5 \,\mu$ S. It is 18 bits wide giving it a maximum timeout time of 8 seconds. When the WDT overflows, the system is reset and the reset sources register is updated to indicate the system was reset by the watchdog timer. If a debugger is attached then the WDT is paused.

| Function                                                             | Bits            | Default            | Туре            | Description                                                                                                                                                  |
|----------------------------------------------------------------------|-----------------|--------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset Sources Register: 0x4001                                       | _8000           |                    |                 | ·                                                                                                                                                            |
| Register describing what source the Watchdog.                        | he last NCS3651 | 0 reset came from. | Choices include | POR/BO, software reset, external reset, and                                                                                                                  |
| POR/BO Reset                                                         | [4]             | 0x0                | RO              | 0 – POR/BO reset did NOT occur<br>1 – POR/BO reset DID occur                                                                                                 |
| Software Reset – SYSRESE-<br>TREQ                                    | [3]             | 0x0                | RO              | 0 – Software reset did NOT occur<br>1 – Software reset DID occur                                                                                             |
| External Reset                                                       | [2]             | 0x0                | RO              | 0 – External reset did NOT occur<br>1 – External reset DID occur                                                                                             |
| Watchdog Reset                                                       | [1]             | 0x0                | RO              | 0 – Watchdog reset did NOT occur<br>1 – Watchdog reset DID occur                                                                                             |
| Cortex–M3 lockup                                                     | [0]             | 0x0                | RO              | 0 – MCU did NOT lockup<br>1 – MCU DID lockup<br>Note: Lockup event does NOT reset<br>NCS36510 and the lockup bit only indi-<br>cates that a lockup occurred. |
| Function                                                             | Bits            | Default            | Туре            | Description                                                                                                                                                  |
| Clear Reset Sources Register: 0<br>Clear the reset sources register. | x4001_8004      |                    |                 |                                                                                                                                                              |
| Clear reset sources                                                  | [31:0]          | n/a                | WO              | Write any value to this register to clear re-<br>set sources register.                                                                                       |
| Function                                                             | Bits            | Default            | Туре            | Description                                                                                                                                                  |
| Hardware Revision Register: 0x<br>Hardware revision number is avai   | -               | er.                |                 |                                                                                                                                                              |
| Hardware revision number                                             | [31:0]          | 0x80215405         | RO              |                                                                                                                                                              |

### Table 6. REGISTERS

| Function                                                                                                | Bits | Default | Туре | Description                                                                                                                  |  |  |
|---------------------------------------------------------------------------------------------------------|------|---------|------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| Reset Sources Control Register: 0x4001_800C<br>External reset and Watchdog reset impact on debug logic. |      |         |      |                                                                                                                              |  |  |
| External Reset and Watchdog<br>impact on debug logic                                                    | [0]  | 0x0     | R/W  | 0 – External reset and watchdog WILL re-<br>set debug logic<br>1 – External reset and watchdog will NOT<br>reset debug logic |  |  |

### CLOCKS Description

There are two major clock domains on NCS36510. There is a high speed 32 MHz oscillator domain and a low speed 32.768 kHz oscillator domain. During coma mode operation the only clock available is the 32.768 kHz oscillator.

The high speed 32MHz oscillator has two sources. Either the internal oscillator or an external crystal based oscillator. The crystal based clock is needed for 802.15.4 RF carrier frequency accuracy requirements. The internal oscillator is typically used for fast boot up before the external crystal oscillator is enabled and ready. The 32 MHz system clock (FCLK) can be divided by the following values: 1, 2, 3, 4, 5, 6, 7, and 8.

The low speed 32.768 kHz oscillator has two sources. Either the internal oscillator or an external crystal based oscillator. The 32.768 kHz internal oscillator is typically used during low power modes as it has the lowest power consumption. If accuracy is a higher priority over power consumption then the external 32.768 kHz oscillator can be used instead.

Both the internal 32MHz and internal 32.768 kHz oscillators can be calibrated against the required 32 MHz crystal oscillator. Both internal oscillators are sensitive to temperature changes of the NCS36510. Periodic calibration is recommended if frequency accuracy is important.

Both crystal oscillators have a boost mode that is automatically controlled during crystal oscillator startup.

The boost mode injects extra energy into the resonant crystal circuit formed by the crystal and the internal amplifier and shunt caps. The gain of the internal amplifier can be set by software and the internal shunt capacitors can be programmed, allowing fine tune pulling of the external crystal for frequency fine-tuning. After startup, the boost mode automatically disables to lower power consumption.

By default, the system clock is gated to all the peripherals. The peripheral disable register bits for the required peripherals must be cleared to enable the system clock to clock the desired peripheral. When disabled, register writes to the peripherals will be silently ignored and will have no effect.

# **Debug Port Lockout**

The debug access port (DAP) lock is used to disable the serial wire debug port to prevent access to the internal buses and memory for security sensitive applications. During power–up the word at address 0x00001FC8 in the FLASH memory will immediately be read by the ON Semiconductor bootloader firmware. If the value read is set to 0x00D1EDEB, the DAP lock enable bit will be set in the clock control register and the debug port will be disabled. The debug port is disabled by gating the clock, which is why the lock enable is in the clock control register.

| Function                                                                                                 | Bits | Default          | Туре          | Description                                                                      |  |  |  |
|----------------------------------------------------------------------------------------------------------|------|------------------|---------------|----------------------------------------------------------------------------------|--|--|--|
| Clock Control Register: 0x4001_B000                                                                      |      |                  |               |                                                                                  |  |  |  |
| Control the NCS36510 clocking options. The Debug Access Port (DAP) lock enable is also in this register. |      |                  |               |                                                                                  |  |  |  |
| Real Time Clock (RTC) control                                                                            | [4]  | 0x0              | R/W           | 0 – RTC disabled<br>1 – RTC enabled                                              |  |  |  |
| Calibrate internal 32 MHz os-<br>cillator                                                                | [3]  | 0x0              | WO            | 0 – Disable calibration<br>1 – Enable calibration                                |  |  |  |
| Calibrate internal 32.768 kHz<br>oscillator                                                              | [2]  | 0x0              | WO            | 0 – Disable calibration<br>1 – Enable calibration                                |  |  |  |
| DAP lock enable                                                                                          | [1]  | 0x0              | R/W           | 0 – No effect, reset will disable dap lock<br>1 – Enable DAP lock                |  |  |  |
| High speed oscillator select                                                                             | [0]  | 0x0              | R/W           | 0 – Use internal 32 MHz oscillator<br>1 – Use external 32 MHz crystal oscillator |  |  |  |
| Clock Status Register: 0x4001_E<br>Various clock related status register                                 |      | e of the DBG_TES | ST_EN pin als | o visible in this register.                                                      |  |  |  |

| Function                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                   | Default                                                                                                | Туре                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| State of the DBG_TEST_EN pin                                                                                                                                                                                                                                                                                   | [31]                                                                                                                   | 0x0                                                                                                    | RO                                                                                  | 0 – DBG_TEST_EN pin is at logic level 0<br>1 – DBG_TEST_EN pin is at logic level 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Internal 32 MHz oscillator cali-<br>bration complete                                                                                                                                                                                                                                                           | [5]                                                                                                                    | 0x0                                                                                                    | RO                                                                                  | 0 – Calibration not started and/or not<br>completed<br>1 – Calibration is finished                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Internal 32 MHz oscillator cali-<br>bration status                                                                                                                                                                                                                                                             | [4]                                                                                                                    | 0x0                                                                                                    | RO                                                                                  | 0 – Not started or finished successfully<br>1 – Calibration failed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Internal 32.768 kHz oscillator<br>calibration complete                                                                                                                                                                                                                                                         | [3]                                                                                                                    | 0x0                                                                                                    | RO                                                                                  | 0 – Calibration not started and/or not<br>completed<br>1 – Calibration is finished                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Internal 32.768 kHz oscillator calibration status                                                                                                                                                                                                                                                              | [2]                                                                                                                    | 0x0                                                                                                    | RO                                                                                  | 0 – Not started or finished successfully<br>1 – Calibration failed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| External 32.768 kHz crystal os-<br>cillator status                                                                                                                                                                                                                                                             | [1]                                                                                                                    | 0x0                                                                                                    | RO                                                                                  | 0 – Not running or not stable<br>1 – Running and stable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| External 32 MHz crystal os-<br>cillator status                                                                                                                                                                                                                                                                 | [0]                                                                                                                    | 0x0                                                                                                    | RO                                                                                  | 0 – Not running or not stable<br>1 – Running and stable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Function                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                   | Default                                                                                                | Туре                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Clock Interrupts Register: 0x400                                                                                                                                                                                                                                                                               | _B008                                                                                                                  |                                                                                                        |                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Manage clock related interrupts.                                                                                                                                                                                                                                                                               |                                                                                                                        |                                                                                                        |                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Calibrate internal 32 MHz os-<br>cillator interrupt enable                                                                                                                                                                                                                                                     | [1]                                                                                                                    | 0x0                                                                                                    | R/W                                                                                 | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Calibrate internal 32.768 kHz<br>oscillator interrupt enable                                                                                                                                                                                                                                                   | [0]                                                                                                                    | 0x0                                                                                                    | R/W                                                                                 | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Function                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                   | Default                                                                                                | Туре                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Clock Interrupts Register: 0x400<br>Clear clock related interrupts and s                                                                                                                                                                                                                                       | -                                                                                                                      |                                                                                                        |                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Clock interrupt and status reg-<br>ister clear                                                                                                                                                                                                                                                                 | [31:0]                                                                                                                 | 0x0                                                                                                    | n/a                                                                                 | Writing any value to this register will clear all clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13101 01001                                                                                                                                                                                                                                                                                                    |                                                                                                                        |                                                                                                        | ,                                                                                   | related interrupts and the clock status register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Function                                                                                                                                                                                                                                                                                                       | Bits                                                                                                                   | Default                                                                                                | Туре                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Function<br>Peripheral Clock Disable Registe<br>To save power, the clocks to the pe                                                                                                                                                                                                                            | r: 0x4001_B0<br>ripherals are<br>locks are disa                                                                        | 10<br>gated by default.                                                                                | Type                                                                                | related interrupts and the clock status register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Function<br>Peripheral Clock Disable Registe<br>To save power, the clocks to the per<br>therefore usable. If the peripheral c                                                                                                                                                                                  | r: 0x4001_B0<br>ripherals are<br>locks are disa                                                                        | 10<br>gated by default.                                                                                | Type                                                                                | related interrupts and the clock status register Description disable will enable the peripheral to be clocked and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Function<br>Peripheral Clock Disable Registe<br>To save power, the clocks to the per<br>therefore usable. If the peripheral c<br>eral clock, PCLK, follows the FCLK                                                                                                                                            | r: 0x4001_BC<br>ripherals are<br>locks are disa<br>if divided.                                                         | l<br>p <b>10</b><br>gated by default.<br>bled for a given p                                            | Type<br>Clearing the o<br>eripheral, wr                                             | related interrupts and the clock status register Description disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The periph- 1 – System clock to peripheral is gated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Function<br>Peripheral Clock Disable Registe<br>To save power, the clocks to the per<br>therefore usable. If the peripheral c<br>eral clock, PCLK, follows the FCLK<br>NCS36510 test modes                                                                                                                     | r: 0x4001_BC<br>ripherals are<br>locks are disa<br>if divided.<br>[31]                                                 | gated by default.<br>bled for a given p<br>0x1                                                         | Type<br>Clearing the<br>eripheral, wr                                               | related interrupts and the clock status register Description disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The periph- 1 – System clock to peripheral is gated 0 – System clock to peripheral is un–gated 1 – System clock to peripheral is gated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Function<br>Peripheral Clock Disable Registe<br>To save power, the clocks to the per<br>therefore usable. If the peripheral c<br>eral clock, PCLK, follows the FCLK<br>NCS36510 test modes<br>DMA                                                                                                              | r: 0x4001_BC<br>ripherals are<br>locks are disa<br>if divided.<br>[31]<br>[30]                                         | gated by default.<br>bled for a given p<br>0x1<br>0x1                                                  | Type<br>Clearing the oripheral, write<br>R/W<br>R/W                                 | related interrupts and the clock status register         Description         disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The peripheralites to their related registers will be ignored. The peripheral - System clock to peripheral is gated         1 – System clock to peripheral is gated         0 – System clock to peripheral is gated         1 – System clock to peripheral is gated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Function Peripheral Clock Disable Registe To save power, the clocks to the per therefore usable. If the peripheral c eral clock, PCLK, follows the FCLK NCS36510 test modes DMA Power management unit                                                                                                          | r: 0x4001_BC<br>ripherals are<br>locks are disa<br>if divided.<br>[31]<br>[30]<br>[29]                                 | pated by default.<br>bled for a given p<br>0x1<br>0x1<br>0x1                                           | Type<br>Clearing the<br>eripheral, wr<br>R/W<br>R/W<br>R/W                          | related interrupts and the clock status register         Description         disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The periph-         1 – System clock to peripheral is gated         0 – System clock to peripheral is un-gated         1 – System clock to peripheral is gated         0 – System clock to peripheral is gated         0 – System clock to peripheral is un-gated         1 – System clock to peripheral is un-gated         1 – System clock to peripheral is gated         0 – System clock to peripheral is gated         1 – System clock to peripheral is gated         1 – System clock to peripheral is gated         1 – System clock to peripheral is gated         0 – System clock to peripheral is gated         1 – System clock to peripheral is gated         1 – System clock to peripheral is gated                                                                                                                                                                                                                                                                                                   |
| Function         Peripheral Clock Disable Registe         To save power, the clocks to the peripheral clock, precedent of the peripheral clock, PCLK, follows the FCLK         NCS36510 test modes         DMA         Power management unit         Pad control                                               | r: 0x4001_BC<br>ripherals are<br>locks are disa<br>if divided.<br>[31]<br>[30]<br>[29]<br>[28]                         | gated by default.<br>bled for a given p<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1                             | Type<br>Clearing the<br>eripheral, wr<br>R/W<br>R/W<br>R/W                          | related interrupts and the clock status register         Description         disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The periph-         1 – System clock to peripheral is gated         0 – System clock to peripheral is un-gated         1 – System clock to peripheral is gated         0 – System clock to peripheral is gated         0 – System clock to peripheral is un-gated         1 – System clock to peripheral is un-gated         1 – System clock to peripheral is gated         0 – System clock to peripheral is gated         1 – System clock to peripheral is gated         1 – System clock to peripheral is gated         1 – System clock to peripheral is gated         0 – System clock to peripheral is gated         1 – System clock to peripheral is gated         1 – System clock to peripheral is gated                                                                                                                                                                                                                                                                                                   |
| Function         Peripheral Clock Disable Registe         To save power, the clocks to the peripheral of eral clock, PCLK, follows the FCLK         NCS36510 test modes         DMA         Power management unit         Pad control         Unused                                                           | r: 0x4001_BC<br>ripherals are disa<br>if divided.<br>[31]<br>[30]<br>[29]<br>[28]<br>[27]                              | 10<br>gated by default.<br>bled for a given p<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1                       | Type<br>Clearing the o<br>eripheral, wr<br>R/W<br>R/W<br>R/W<br>R/W                 | related interrupts and the clock status register         Description         disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The peripheralites to their related registers will be ignored. The peripheralites to their related registers will be ignored. The peripheral is gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is gated       1 – System clock to peripheral is gated         1 – System clock to peripheral is gated       1 – System clock to peripheral is gated         1 – System clock to peripheral is gated       1 – System clock to peripheral is gated         1 – System clock to peripheral is gated       1 – System clock to peripheral is gated                                                                                  |
| Function         Peripheral Clock Disable Registe         To save power, the clocks to the peripheral clock, usable. If the peripheral clock, PCLK, follows the FCLK         NCS36510 test modes         DMA         Power management unit         Pad control         Unused         Digital I/O control      | r: 0x4001_BC<br>ripherals are<br>locks are disa<br>if divided.<br>[31]<br>[30]<br>[29]<br>[28]<br>[27]<br>[26]         | gated by default.<br>bled for a given p<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1        | Type<br>Clearing the<br>eripheral, wr<br>R/W<br>R/W<br>R/W<br>R/W<br>R/W            | related interrupts and the clock status register         Description         disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The peripheral ites to their related registers will be ignored. The peripheral 0 – System clock to peripheral is un–gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is un–gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is gated         1 – System clock to peripheral is un–gated       1 – System clock to peripheral is un–gated         1 – System clock to peripheral is gated       0 – System clock to peripheral is un–gated         1 – System clock to peripheral is gated       1 – System clock to peripheral is gated         1 – System clock to peripheral is gated       1 – System clock to peripheral is un–gated |
| Function         Peripheral Clock Disable Registe         To save power, the clocks to the peripheral of eral clock, PCLK, follows the FCLK         NCS36510 test modes         DMA         Power management unit         Pad control         Unused         Digital I/O control         RF and analog control | r: 0x4001_BC<br>ripherals are<br>locks are disa<br>if divided.<br>[31]<br>[30]<br>[29]<br>[28]<br>[27]<br>[26]<br>[25] | gated by default.<br>bled for a given p<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1<br>0x1 | Type<br>Clearing the or<br>eripheral, wri<br>R/W<br>R/W<br>R/W<br>R/W<br>R/W<br>R/W | related interrupts and the clock status register         Description         disable will enable the peripheral to be clocked and ites to their related registers will be ignored. The peripheralites to their related registers will be ignored. The peripheral is un-gated         1 - System clock to peripheral is gated       0 - System clock to peripheral is un-gated         1 - System clock to peripheral is gated       0 - System clock to peripheral is gated         0 - System clock to peripheral is gated       0 - System clock to peripheral is un-gated         1 - System clock to peripheral is gated       0 - System clock to peripheral is un-gated         1 - System clock to peripheral is gated       0 - System clock to peripheral is un-gated         1 - System clock to peripheral is gated       0 - System clock to peripheral is un-gated         1 - System clock to peripheral is un-gated       1 - System clock to peripheral is un-gated         1 - System clock to peripheral is gated       0 - System clock to peripheral is gated         1 - System clock to peripheral is gated       1 - System clock to peripheral is un-gated                        |

| Function                                                                                                                                            | Bits    | Default | Туре         | Description                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAR ADC                                                                                                                                             | [21]    | 0x1     | R/W          | <ul> <li>1 – System clock to peripheral is gated</li> <li>0 – System clock to peripheral is un–gated</li> </ul>                                                                                                    |
| 802.15.4 hardware MAC                                                                                                                               | [20]    | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un-gated                                                                                                                              |
| Unused                                                                                                                                              | [19:18] | 0x1     | R/W          |                                                                                                                                                                                                                    |
| TRNG                                                                                                                                                | [17]    | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| Crossbar                                                                                                                                            | [16]    | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| RTC                                                                                                                                                 | [15]    | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| Unused                                                                                                                                              | [14]    | 0x1     | R/W          |                                                                                                                                                                                                                    |
| I2C 2                                                                                                                                               | [13]    | 0x1     | R/W          | <ul> <li>1 – System clock to peripheral is gated</li> <li>0 – System clock to peripheral is un–gated</li> </ul>                                                                                                    |
| GPIO                                                                                                                                                | [12]    | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| PWM                                                                                                                                                 | [11]    | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| Watchdog APB connected con-<br>trol register (Watchdog runs on<br>32.768 kHz domain, just the<br>control register is on high speed<br>clock domain) | [10]    | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un-gated                                                                                                                              |
| SPI 2                                                                                                                                               | [9]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| UART 2                                                                                                                                              | [8]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| I2C 1                                                                                                                                               | [7]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| SPI 1                                                                                                                                               | [6]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un-gated                                                                                                                              |
| UART 1                                                                                                                                              | [5]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| Unused                                                                                                                                              | [4:3]   | 0x11    | R/W          |                                                                                                                                                                                                                    |
| Timer 2                                                                                                                                             | [2]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| Timer 1                                                                                                                                             | [1]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un–gated                                                                                                                              |
| Timer 0                                                                                                                                             | [0]     | 0x1     | R/W          | 1 – System clock to peripheral is gated<br>0 – System clock to peripheral is un-gated                                                                                                                              |
| Function                                                                                                                                            | Bits    | Default | Туре         | Description                                                                                                                                                                                                        |
| System Clock Prescaler (FCLK) I<br>System clock divider, FCLK. Clock                                                                                | -       | —       | 32 MHz oscil | lator or the external 32 MHz crystal oscillator.                                                                                                                                                                   |
| FCLK prescaler value                                                                                                                                | [2:0]   | 0x03    | R/W          | 000 - Divide by 1001 - Divide by 2010 - Divide by 3011 - Divide by 4100 - Divide by 5101 - Divide by 6110 - Divide by 7111 - Divide by 8Note: It's recommended to sequence the divider values using grey encoding. |

| Function                                                                                                           | Bits            | Default             | Туре            | Description                                                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------------|-----------------|---------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRACECLK Prescaler Register: 0<br>Prescaler value for the debugger T<br>oscillator (FCLK).                         |                 | ock reference is o  | either the inte | ernal 32 MHz oscillator or the external 32 MHz crystal                                                                                                                                                                                                        |
| TRACECLK prescaler value                                                                                           | [7:0]           | 0x00                | R/W             | The output frequency is given by:                                                                                                                                                                                                                             |
| Function                                                                                                           | Bits            | Default             | Туре            | Description                                                                                                                                                                                                                                                   |
| Internal 32 MHz Oscillator Trim Va                                                                                 | alue Register   | : 0x4001_B020       |                 |                                                                                                                                                                                                                                                               |
| Trim value, typically used to center frequency. The calibration routine s                                          |                 |                     |                 | ossible to the 32 MHz external crystal oscillator<br>a debugger or software.                                                                                                                                                                                  |
| Internal 32 MHz oscillator trim value                                                                              | [5:0]           | 0x00                | R/W             | This value is set after calibration to the external 32 MHz crystal oscillator. Software and/or a debugger can overwrite it.                                                                                                                                   |
| Function                                                                                                           | Bits            | Default             | Туре            | Description                                                                                                                                                                                                                                                   |
|                                                                                                                    | the internal 32 | 2.768 kHz oscillat  | tor as close a  | as possible to the reference based on the 32 MHz exter-<br>also be written to by a debugger or software.<br>This value is set after calibration to the external 32<br>MHz crystal oscillator based reference. Software<br>and/or a debugger can overwrite it. |
| Function                                                                                                           | Bits            | Default             | Туре            | Description                                                                                                                                                                                                                                                   |
| External 32 MHz Oscillator Trim \                                                                                  | /alue Registe   | r 0x4001 B028       |                 |                                                                                                                                                                                                                                                               |
|                                                                                                                    | rnal crystal os | cillator analog cir | cuit for selec  | ted crystal. The amplifier drive strength, ready counter                                                                                                                                                                                                      |
| Internal analog amplifier gain<br>value                                                                            | [11:10]         | 0x11                | R/W             | 00 – Off<br>01 – Low gain mode = about 300 μA<br>10 – Mid gain mode = about 600 μA<br>11 – High gain mode = about 900 μA                                                                                                                                      |
| Ready signal delay control – fine<br>tune the delay before oscillator<br>signals the MCU it's ready                | [9:8]           | 0x00                | R/W             | 00 – Bit 12 = 4096 32 MHz clocks = 64 μs<br>01 – Bit 13 = 8192 32 MHz clocks = 128 μs<br>10 – Bit 14 = 16384 32 MHz clocks = 256 μs<br>11 – Bit 15 = 32768 32 MHz clocks = 512 μs                                                                             |
| Boost done signal delay control<br>– fine tune the duration of the<br>boost                                        | [7:6]           | 0x00                | R/W             | $\begin{array}{l} 00-Bit\ 12=4096\ 32\ MHz\ clocks=64\ \mu s\\ 01-Bit\ 13=8192\ 32\ MHz\ clocks=128\ \mu s\\ 10-Bit\ 14=16384\ 32\ MHz\ clocks=256\ \mu s\\ 11-Bit\ 15=32768\ 32\ MHz\ clocks=512\ \mu s \end{array}$                                         |
| Trim cap value                                                                                                     | [5:0]           | 0x20                | R/W             | 000000 = about 24.35 pF<br>000001 = about 24.65 pF<br>(approx. 0.3 per step)<br><br>111111 = about 43.55 pF                                                                                                                                                   |
| Function                                                                                                           | Bits            | Default             | Туре            | Description                                                                                                                                                                                                                                                   |
|                                                                                                                    |                 |                     |                 |                                                                                                                                                                                                                                                               |
| External 32.768 kHz Oscillator Tri<br>Trim values used to center the exter<br>boost counter delays, and internal s | rnal crystal os | cillator analog cir | cuit for selec  | ted crystal. The amplifier drive strength, ready and                                                                                                                                                                                                          |
| Internal analog amplifier gain<br>value                                                                            | [11:10]         | 0x11                | R/W             | 00 – Off<br>01 – Low gain mode = about 350 nA<br>10 – Mid gain mode = about 460 nA<br>11 – High gain mode = about 640 nA                                                                                                                                      |
| Ready signal delay control – fine<br>tune the delay before oscillator<br>signals the MCU it's ready                | [9:8]           | 0x00                | R/W             | 00 – Bit 12 = 4096 32.768 kHz clocks = 125 ms<br>01 – Bit 13 = 8192 32.768 kHz clocks = 250 ms<br>10 – Bit 14 = 16384 32.768 kHz clocks = 500 ms<br>11 – Bit 15 = 32768 32.768 kHz clocks = 1000 sec                                                          |

# Table 7. REGISTERS

| Function                                                                    | Bits  | Default | Туре | Description                                                                                                                                                                                          |
|-----------------------------------------------------------------------------|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Boost done signal delay control<br>– fine tune the duration of the<br>boost | [7:6] | 0x00    | R/W  | 00 – Bit 12 = 4096 32.768 kHz clocks = 125 ms<br>01 – Bit 13 = 8192 32.768 kHz clocks = 250 ms<br>10 – Bit 14 = 16384 32.768 kHz clocks = 500 ms<br>11 – Bit 15 = 32768 32.768 kHz clocks = 1000 sec |
| Internal programmable shunt ca-<br>pacitors                                 | [5:0] | 0x20    | R/W  | 000000 = about 20.9 pF<br>000001 = about 21.2 pF (approx. 0.3 per step)<br><br>111111 = about 40.1 pF                                                                                                |

# Internal Oscillator Calibration

To calibrate the internal 32MHz oscillator to the external crystal 32 MHz oscillator an internal state machine is used that utilizes a binary search algorithm and a phase detector to align the internal oscillator as close as possible to the external crystal 32 MHz oscillator reference.

Typically this calibration is done after exiting sleep mode or anytime a large temperature variation is encountered or expected.

A typical 32 MHz calibration should take at most 450  $\mu$ s and would entail the following steps:

- 1. Enable the external 32 MHz crystal oscillator and wait for it to stabilize
  - a. Set bit 0 of the clock control register
  - b. Wait for bit 0 of the clock control register to be a 1
- 2. Enable the internal 32 MHz oscillator and wait for it to stabilize
  - a. Clear bit 5 of the PMU control register
  - b. Wait at least 5µs
- 3. Set the interrupt enable
  - a. Set bit 1 of the clock interrupt enable register
- 4. Enable the calibration
  - a. Set bit 3 of the clock control register
- 5. Wait for the interrupt or poll the status register

# TIMERS

# SysTick Timer

# Description

The SysTick timer is a standard Cortex–M3 timer that is on all instances of Cortex–M3 MCUs. This standard SysTick timer increases software portability between hardware platforms.

The SysTick timer is integrated with the NVIC and can be used to generate a SYSTICK exception. The SYSTICK timer is often used to generate interrupts for an operating system to manage system tasks.

- a. Polling can be accomplished by waiting for bit 5 of the clock status register to clear
- 6. Determine success of the calibration a. Read bit 4 of the clock status register

A typical 32.768 kHz calibration should take at most 760 µs and would entail the following steps:

- 1. Enable the external 32 MHz crystal oscillator and wait for it to stabilize
  - a. Set bit 0 of the clock control register
  - b. Wait for bit 0 of the clock control register to be a 1
- 2. Enable the internal 32.768 kHz oscillator and wait for it to stabilize
  - a. Clear bit 4 of the PMU control register
  - b. Wait at least 5 μs
- 3. Set the interrupt enable
- a. Set bit 0 of the clock interrupt enable register 4. Enable the calibration
  - a. Set bit 2 of the clock control register
- 5. Wait for the interrupt or poll the status register
  - a. Polling can be accomplished by waiting for bit 3 of the clock status register to clear
- 6. Determine success of the calibration
  - a. Read bit 2 of the clock status register

Refer to the official ARM documentation for the usage model of the SysTick timer.

In the NCS36510 implementation the SysTick timer is always clocked by the MCU clock, FCLK. In coma mode this SysTick timer is not available and the Real Time Clock (RTC) must be used instead.

### Table 8. REGISTERS

| Function                                                                                                          | Bits         | Default | Туре           | Description                                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------|--------------|---------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| SysTick Control and Status Regis                                                                                  | ster: 0xE000 | E010    |                | -                                                                                                                                                       |
| Control and status register for SysT                                                                              | īck timer.   |         |                |                                                                                                                                                         |
| Count flag - COUNTFLAG                                                                                            | [16]         | 0x0     | RO             | Reads as 1 if counter reaches 0 since last time this register is read, clears on read                                                                   |
| Clock source – CLKSOURCE                                                                                          | [2]          | 0x0     | R/W            | 0 – External reference clock, STCLK<br>1 – FCLK, processor free running clock                                                                           |
|                                                                                                                   |              |         |                | NOTE: This implementation does not use STCLK                                                                                                            |
| Tick interrupt – TICKINT                                                                                          | [1]          | 0x0     | R/W            | 0 – Do not generate tick interrupt<br>1 – Generate tick interrupt                                                                                       |
| SysTick timer enable – ENABLE                                                                                     | [0]          | 0x0     | R/W            | 0 – Disable SysTick timer<br>1 – Enable SysTick timer                                                                                                   |
| SysTick Reload Value Register: 0                                                                                  | xE000_E014   |         |                | •                                                                                                                                                       |
| SysTick reload value register.                                                                                    |              | 1       | T              |                                                                                                                                                         |
| Reload value - RELOAD                                                                                             | [23:0]       | 0x0     | R/W            | Reload value for when timer reaches down count of 0                                                                                                     |
| Function                                                                                                          | Bits         | Default | Туре           | Description                                                                                                                                             |
| SysTick Current Value Register: 0<br>SysTick current value register.                                              | DXE000_E018  | 1       | I              | T                                                                                                                                                       |
| Current timer value - CURRENT                                                                                     | [23:0]       | 0x0     | R/W            | When read current timer value is returned                                                                                                               |
|                                                                                                                   |              |         |                | When written the counter value is set to 0 and also<br>clears COUNTFLAG in SysTick control/status regis-<br>ter                                         |
| Function                                                                                                          | Bits         | Default | Туре           | Description                                                                                                                                             |
| SysTick Calibration Value Register.<br>SysTick calibration value register.<br>Note for this implementation bit 31 | —            |         | e set to 0. Th | his implies this is a read only register.                                                                                                               |
| No external reference clock –<br>NOREF                                                                            | [31]         | 0x1     | RO             | Bit is hard-wired to 1 in hardware which means no external SysTick reference clock (STCLK) is available. Clock is always free running MCU clock (FCLK). |
| Calibration value skew – SKEW                                                                                     | [30]         | 0x0     | RO             | Calibration value is accurate                                                                                                                           |
|                                                                                                                   |              |         |                | In this implementation this bit is set to 0 in hardware                                                                                                 |
| Calibration value for 10ms                                                                                        | [23:0]       | 0x0     | RO             | Calibration value for 10ms                                                                                                                              |
|                                                                                                                   |              |         |                | In this implementation these bits are set to 0 in hard-<br>ware. This implies the calibration value is not avail-<br>able.                              |

# **Real Time Clock (RTC) Control**

Description

The RTC consists of two counters that are clocked by the 32.768 kHz clock. Both counters have their own alarm, interrupt, and clear functions.

The first counter is a 15 bit sub-second counter  $(2^{15} - 1/32768 = 1s)$ . It can be used for wait times less than one second.

The other counter is a 32 bit seconds counter. The seconds counter is incremented by the sub – second counter rollover.

The second counter can count up to ~136 years so it can be used as a UNIX (POSIX or Epoch) time counter if desired. When both second and sub – second counters are enabled the RTC will generate an interrupt when both counters expire, allowing for non – integer second timing (for example 3.6 s).

All RTC registers are on the 32.768 kHz domain. A write to any of these registers requires four 32.768 kHz clocks to allow for PCLK (peripheral clock) event synchronization handshake. Attempting to write to a register a second time during this write cycle is not allowed. This illegal write condition will set an error bit in the status register and the 2<sup>nd</sup> write will be ignored since the results would be unpredictable. If a second write is required very soon after

a first write, software may check the status of the write by reading the write busy bits of the status register. If the write

busy bit for the desired register reads a 1, then a consecutive write must wait.

| Function                                            | Bits            | Default             | Туре          | Description                                                        |
|-----------------------------------------------------|-----------------|---------------------|---------------|--------------------------------------------------------------------|
| RTC Sub-second Counter Value                        | -               |                     |               |                                                                    |
| RTC sub-second counter value. A                     | write loads the | e counter, a read   | returns curre | nt value.                                                          |
| Sub-second counter value                            | [14:0]          | 0x0                 | R/W           | Write loads the counter, a read returns the current value          |
| Function                                            | Bits            | Default             | Туре          | Description                                                        |
| RTC Second Counter Value Regi                       | ster: 0x4000_   | F004                |               |                                                                    |
| RTC second counter value. A write                   | e loads the co  | unter, a read retur | ns current va | alue.                                                              |
| Second counter value                                | [31:0]          | 0x0                 | R/W           | Write loads the counter, a read returns the current value          |
| Function                                            | Bits            | Default             | Туре          | Description                                                        |
| RTC Sub-second Alarm Register                       | : 0x4000 F00    | )8                  |               |                                                                    |
| RTC sub-second alarm value regis                    |                 |                     | ue, a read re | eturns current value.                                              |
| Sub-second alarm value                              | [14:0]          | 0x7FFF              | R/W           | Write loads the alarm value, a read returns the cur-<br>rent value |
| Function                                            | Bits            | Default             | Туре          | Description                                                        |
| RTC Second Alarm Register: 0x4                      | 000_F00C        |                     |               |                                                                    |
| RTC second alarm value register.                    | _               | the alarm value, a  | read returns  | s current value.                                                   |
| Second alarm value                                  | [31:0]          | 0xFFFFFFF<br>F      | R/W           | Write loads the alarm value, a read returns the cur-<br>rent value |
| Function                                            | Bits            | Default             | Туре          | Description                                                        |
| RTC Control Register: 0x4000_F0                     | 0010            |                     |               |                                                                    |
| - –                                                 |                 | nd sub-second co    | unters as we  | ell as their corresponding interrupts.                             |
| Second interrupt enable                             | [3]             | 0x0                 | R/W           | 1 – Interrupt enabled<br>0 – Interrupt disabled                    |
| Sub-second interrupt enable                         | [2]             | 0x0                 | R/W           | 1 – Interrupt enabled<br>0 – Interrupt disabled                    |
| Second counter enable                               | [1]             | 0x0                 | R/W           | 1 – Counter enabled<br>0 – Counter disabled                        |
| Sub-second counter enable                           | [0]             | 0x0                 | R/W           | 1 – Counter enabled<br>0 – Counter disabled                        |
| Function                                            | Bits            | Default             | Туре          | Description                                                        |
| RTC Status Register: 0x4000_F0                      | 14              |                     |               |                                                                    |
| RTC status register, clears on any                  | write.          |                     |               |                                                                    |
| Busy with second counter in-<br>terrupt clear write | [10]            | 0x0                 | R/W           | 1 – Busy<br>0 – Not busy                                           |
| Busy with a sub-second in-<br>terrupt clear write   | [9]             | 0x0                 | R/W           | 1 – Busy<br>0 – Not busy                                           |
| Busy with a control register write                  | [8]             | 0x0                 | R/W           | 1 – Busy<br>0 – Not busy                                           |
| Busy with a second alarm regis-<br>ter write        | [7]             | 0x0                 | R/W           | 1 – Busy<br>0 – Not busy                                           |
| Busy with a sub-second alarm                        | [6]             | 0x0                 | R/W           | 1 – Busy                                                           |

### Table 9. REGISTERS

| Function                                                                                                               | Bits                                                                                       | Default | Туре | Description                              |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|---------|------|------------------------------------------|--|--|--|--|
| Busy with a second counter reg-<br>ister write                                                                         | [5]                                                                                        | 0x0     | R/W  | 1 – Busy<br>0 – Not busy                 |  |  |  |  |
| Busy with a sub-second counter register write                                                                          | [4]                                                                                        | 0x0     | R/W  | 1 – Busy<br>0 – Not busy                 |  |  |  |  |
| Busy with any write                                                                                                    | [3]                                                                                        | 0x0     | R/W  | 1 – Busy<br>0 – Not busy                 |  |  |  |  |
| Reads error bit which is set<br>when a write occurs before a<br>previous write to the same regis-<br>ter has completed | [2]                                                                                        | 0x0     | R/W  | 1 – Error<br>0 – No error                |  |  |  |  |
| Second interrupt status                                                                                                | [1]                                                                                        | 0x0     | R/W  | 1 – Interrupt active<br>0 – No interrupt |  |  |  |  |
| Sub-second interrupt status                                                                                            | [0]                                                                                        | 0x0     | R/W  | 1 – Interrupt active<br>0 – No interrupt |  |  |  |  |
| Function                                                                                                               | Bits                                                                                       | Default | Туре | Description                              |  |  |  |  |
| • –                                                                                                                    | RTC Clear Register: 0x4000_F018         Write a 1 to clear corresponding interrupt source. |         |      |                                          |  |  |  |  |
| Second interrupt clear                                                                                                 | [1]                                                                                        | n/a     | WO   | 1 – Clear interrupt<br>0 – No effect     |  |  |  |  |
| Sub-second interrupt clear                                                                                             | [0]                                                                                        | n/a     | WO   | 1 – Clear interrupt<br>0 – No effect     |  |  |  |  |

### Watchdog Timer (WDT)

### Description

NCS36510 implements a programmable watchdog timer. The watchdog timer is disabled by default and the application software needs to instantiate the watchdog timer driver and enable it. The WDT has a register locking safety mechanism to prevent errant software from corrupting the registers. While locked the only supported operation is a clear. The watchdog is on the 32.768 kHz clock domain so it has a minimum resolution of 30.5  $\mu$ s. It is 18 bits wide giving it a maximum timeout time of 8 seconds. When the WDT overflows, the system is reset and the reset sources register is updated to indicate the system was reset by the watchdog timer. If a debugger is attached then the WDT is paused.

All WDT registers are on the 32.768 kHz domain. A write to any of these registers requires four 32.768 kHz clocks to allow for PCLK (peripheral clock) event synchronization handshake. Attempting to write to a register a second time during this write cycle is not allowed. This illegal write condition will set an error bit in the status register and the 2<sup>nd</sup> write will be ignored since the results would be unpredictable. If a second write is required very soon after a first write, software may check the status of the write by reading the write busy bits of the status register. If the write busy bit for the desired register reads a 1, then a consecutive write must wait.

The WDT is not active in coma mode as the MCU is completely powered down. Use the RTC for coma mode.

| Function                                                                          | Bits   | Default | Туре | Description                                                                                                        |  |  |  |  |
|-----------------------------------------------------------------------------------|--------|---------|------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| WDT Load Value Register: 0x4000_A000<br>Watchdog timer load value register.       |        |         |      |                                                                                                                    |  |  |  |  |
| Value that the WDT timer decre-<br>ments from                                     | [17:0] | 0x3FFFF | R/W  | After this register is written the WDT immediately restarts counting down from this value. The minimum value is 1. |  |  |  |  |
| Function                                                                          | Bits   | Default | Туре | Description                                                                                                        |  |  |  |  |
| WDT Current Value Register: 0x4000_A004<br>Watchdog timer current value register. |        |         |      |                                                                                                                    |  |  |  |  |
| Current down count value                                                          | [17:0] | 0x3FFFF | R/W  | Current WDT down count value                                                                                       |  |  |  |  |

### Table 10. REGISTERS

| Function                                                                                                                                                     | Bits                       | Default                                   | Туре                             | Description                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-------------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WDT Control Register: 0x4000_A                                                                                                                               | 008                        | •                                         |                                  |                                                                                                                                                                                                                                                |
| Watchdog timer control register.                                                                                                                             |                            |                                           |                                  |                                                                                                                                                                                                                                                |
| Watchdog enable                                                                                                                                              | [0]                        | 0x0                                       | R/W                              | 0 – WDT disabled<br>1 – WDT enabled                                                                                                                                                                                                            |
| WDT Kick Register: 0x4000_A0C                                                                                                                                | 0                          |                                           |                                  |                                                                                                                                                                                                                                                |
| Watchdog timer kick register. Whe                                                                                                                            | en written the w           | vatchdog timer st                         | arts over aga                    | in at the load value.                                                                                                                                                                                                                          |
| Watchdog kick                                                                                                                                                | [31:0]                     | n/a                                       | WO                               | A write of any value to this address will immediately restart the WDT down count from the load value                                                                                                                                           |
| Function                                                                                                                                                     | Bits                       | Default                                   | Туре                             | Description                                                                                                                                                                                                                                    |
| mechanism is meant to provide a                                                                                                                              | safequard agai             | SD to show the id                         | OCK Status. To                   | unlock, write the code 0x1ACCE551. This locking                                                                                                                                                                                                |
| mechanism is meant to provide a s<br>WDT register lock control                                                                                               | safeguard agai             | n/a                                       | re accessing<br>WO               | unlock, write the code 0x1ACCE551. This locking<br>the WDT.<br>0 – WDT registers are unlocked<br>1 – WDT registers are locked (see note above for                                                                                              |
| mechanism is meant to provide a s                                                                                                                            | safeguard agai             | nst rogue softwa<br>n/a                   | WO                               | the WDT.<br>0 – WDT registers are unlocked<br>1 – WDT registers are locked (see note above for<br>unlock procedure)                                                                                                                            |
| mechanism is meant to provide a s                                                                                                                            | afeguard agai              | nst rogue softwa                          | re accessing                     | the WDT.<br>0 – WDT registers are unlocked<br>1 – WDT registers are locked (see note above for                                                                                                                                                 |
| mechanism is meant to provide a s                                                                                                                            | [0]<br>Bits                | nst rogue softwa<br>n/a                   | WO                               | the WDT.<br>0 – WDT registers are unlocked<br>1 – WDT registers are locked (see note above for<br>unlock procedure)                                                                                                                            |
| mechanism is meant to provide a s<br>WDT register lock control<br>Function<br>WDT Status Register: 0x4000_A                                                  | [0]<br>Bits                | nst rogue softwa<br>n/a                   | WO                               | the WDT.<br>0 – WDT registers are unlocked<br>1 – WDT registers are locked (see note above for<br>unlock procedure)                                                                                                                            |
| mechanism is meant to provide a s<br>WDT register lock control<br>Function<br>WDT Status Register: 0x4000_A<br>WDT status register.                          | afeguard agai [0] Bits 140 | nst rogue softwa<br>n/a<br>Default        | WO<br>Type                       | the WDT.<br>0 – WDT registers are unlocked<br>1 – WDT registers are locked (see note above for<br>unlock procedure)<br>Description<br>1 – Error, next register write occurred before previ-<br>ous write completed                             |
| mechanism is meant to provide a s<br>WDT register lock control<br>Function<br>WDT Status Register: 0x4000_A<br>WDT status register.<br>Register access error | afeguard agai              | nst rogue softwa<br>n/a<br>Default<br>0x0 | re accessing<br>WO<br>Type<br>RO | the WDT.<br>0 – WDT registers are unlocked<br>1 – WDT registers are locked (see note above for<br>unlock procedure)<br>Description<br>1 – Error, next register write occurred before previ-<br>ous write completed<br>0 – No error<br>1 – Busy |

### 16-bit General Purpose Timers

Description

NCS36510 has three independent 16 bit down count timers (TIMER 0, 1, and 2). Each of the three independent timers can:

- Be clocked at either the system clock rate, or a choice of 8 prescale values; 0, 2, 8, 16, 32, 128, 256, and 1024
- Be loaded with a value from a preload register
- Generate an interrupt on 0 counts
- Be operated in free running or periodic modes. In periodic mode the interrupt is generated one clock later than the pre load value since 0 is included in the count.

| Function                                                                                                     | Bits            | Default         | Туре         | Description                                                                                         |  |  |  |
|--------------------------------------------------------------------------------------------------------------|-----------------|-----------------|--------------|-----------------------------------------------------------------------------------------------------|--|--|--|
| Timer Load Value Register (TIME<br>Load value register for timer.                                            | R 0, 1, 2): 0x4 | 000_0000, 0x400 | 00_1000, 0x4 | 000_2000                                                                                            |  |  |  |
| Timer load value                                                                                             | [15:0]          | 0x0             | R/W          | Value used for pre-loading the timer's counter. Value gets reloaded at each cycle in periodic mode. |  |  |  |
| Function                                                                                                     | Bits            | Default         | Туре         | Description                                                                                         |  |  |  |
| Timer Value Register (TIMER 0, 1, 2): 0x4000_0004, 0x4000_1004, 0x4000_2004<br>Current timer value register. |                 |                 |              |                                                                                                     |  |  |  |
| Current timer value                                                                                          | [15:0]          | 0x0             | R/W          | Read to return current timer value                                                                  |  |  |  |

#### Table 11. REGISTERS

| Function                                                                                        | Bits   | Default         | Туре                                                                        | Description                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------|--------|-----------------|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer Control Register (TIMER<br>Timer control register, used to en<br>bits always read back 0. |        | _ · _           |                                                                             | <b>_2008</b> to manage the pre-scale divider for the clock. Unused                                                                                                |
| Interrupt status                                                                                |        |                 | Returns interrupt active status<br>1 – Interrupt active<br>0 – No interrupt |                                                                                                                                                                   |
| Timer enable                                                                                    | [7]    | 0x0             | R/W                                                                         | 1 – Enable timer<br>0 – Disable timer                                                                                                                             |
| Timer periodic mode enable                                                                      | [6]    | 0x0             | R/W                                                                         | 1 – Enable periodic mode<br>0 – Disable periodic mode                                                                                                             |
| Timer clock prescale value                                                                      | [4:2]  | 0x0             | R/W                                                                         | 0 – No FCLK divider<br>1 – Divide by 16<br>2 – Divide by 256<br>3 – Divide by 2<br>4 – Divide by 8<br>5 – Divide by 32<br>6 – Divide by 128<br>7 – Divide by 1024 |
| Function                                                                                        | Bits   | Default         | Туре                                                                        | Description                                                                                                                                                       |
| Timer Clear Register (TIMER 0,<br>Timer interrupt clear registers, w                            | · · –  | 000C, 0x4000_10 | 0C, 0x4000_;                                                                | 200C                                                                                                                                                              |
| Clear interrupt                                                                                 | [15:0] | 0x0             | WO                                                                          | Write any value to this register to clear the interrupt                                                                                                           |

## DIGITAL INPUT/OUTPUT (DIO) CONTROL

#### Description

NCS36510 has 18 identical GPIO. The following list documents the programmable options available independently for each GPIO. Each GPIO input is compatible with CMOS levels and has hysteresis.

Options:

- Bi-directional capability
- Individually configurable interrupt lines
- Rising, falling, or both edge interrupt
- High, low, or both logic level interrupt

- Loopback mode
- Push pull or open drain
- Four programmable drive strengths
- Pullup, pulldown or neither

In the following registers, the DIO pins are aligned with their bit positions in the register. For example DIO11 corresponds to bit 11 in the register.

The DIO control and the crossbar must be configured to make sure that the DIO signals actually connect to the right DIO pads. See the crossbar section for more details.

| Function                                                             | Bits            | Default            | Туре            | Description                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------------|-----------------|--------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIO State/Set Register: 0x4000_C                                     | 000             |                    |                 |                                                                                                                                                                                                                                                                                                                                                 |
| Read this register to determine the drive the DIO signal high (set). | current state o | of the synchroniz  | ed DIO input    | signals. Alternatively, write a 1 to desired DIO pins to                                                                                                                                                                                                                                                                                        |
| Read synchronized DIO input or<br>drive a DIO output high            | [17:0]          | n/a                | wo              | <ul> <li>When read, the value returned is the current synchronized state for each DIO input. Each input must be enabled in the input direction register.</li> <li>When a 1 is written to any bit position, the corresponding DIO will output a 1 to the DIO pad (set). Each output must be enabled in the output direction register.</li> </ul> |
| Function                                                             | Bits            | Default            | Туре            | Description                                                                                                                                                                                                                                                                                                                                     |
| DIO Clear/Interrupts Register: 0x4                                   | 4000_C004       | ł                  | 1               | •                                                                                                                                                                                                                                                                                                                                               |
| Read this register to determine the low (clear).                     | current state o | of the DIO interru | ipts. Alternati | vely, write a 1 to desired DIO pins to drive the DIO signa                                                                                                                                                                                                                                                                                      |

| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------------------|-----------------|---------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read DIO input interrupts status<br>or drive a DIO output low                                              | [17:0]          | n/a                 | WO              | When read, the value returned is the current interrup state for each DIO input. Each input must be enabled in the input direction register.                                     |
|                                                                                                            |                 |                     |                 | When a 1 is written to any bit position, the corre-<br>sponding DIO will output a 0 to the DIO pad (clear).<br>Each output must be enabled in the output direction<br>register. |
| <b>DIO Output Enable Set Register:</b><br>Each DIO that is selected will have                              | _               |                     | her words thi   | s is an output enable set function.                                                                                                                                             |
| DIO output enable set                                                                                      | [17:0]          | 0x7FFFF             | R/W             | 1 – Enable selected DIO as an output<br>0 – No effect                                                                                                                           |
| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |
| DIO Output Enable Clear Registe                                                                            | er: 0x4000_C0   | 0C                  |                 |                                                                                                                                                                                 |
| Each DIO that is selected will have                                                                        | the direction   | of input. Or in oth | er words this   | is an output enable clear function.                                                                                                                                             |
| DIO output enable clear – make<br>input                                                                    | [17:0]          | 0x7FFFF             | R/W             | 1 – Disable selected DIO as an output<br>(make an input)<br>0 – No effect                                                                                                       |
| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |
| DIO Interrupt Enable Set Registe                                                                           | r: 0x4000_C0    | 10                  | 1               | 1                                                                                                                                                                               |
| Each DIO that is selected will have                                                                        | its interrupt e | nabled. Or in othe  | er words this   | is an interrupt enable set function.                                                                                                                                            |
| DIO interrupt enable set                                                                                   | [17:0]          | 0x0                 | R/W             | 1 – Enable selected DIO interrupt<br>0 – No effect                                                                                                                              |
| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |
| DIO Interrupt Enable Clear Regis                                                                           | _               |                     |                 |                                                                                                                                                                                 |
| Each DIO that is selected will have                                                                        | its interrupt d | isabled. Or in othe | er words this   | is an interrupt enable clear function.                                                                                                                                          |
| DIO interrupt enable clear                                                                                 | [17:0]          | 0x0                 | R/W             | 1 – Disable selected DIO Interrupt<br>0 – No effect                                                                                                                             |
| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |
| DIO Set Edge Sensitive Interrupt<br>Each DIO that is selected will have<br>function.                       | -               |                     | sitive. Or in c | ther words this is an edge sensitive interrupt enable set                                                                                                                       |
| DIO edge sensitive interrupt set                                                                           | [17:0]          | 0x0                 | R/W             | 1 – Enable edge sensitive interrupt<br>0 – No effect                                                                                                                            |
| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |
| DIO Set Level Sensitive Interrupt<br>Each DIO that is selected will have<br>function.                      | -               | _                   | sitive. Or in o | ther words this is a level sensitive interrupt enable set                                                                                                                       |
| DIO level sensitive interrupt set                                                                          | [17:0]          | 0x0                 | R/W             | 1 – Enable level sensitive interrupt<br>0 – No effect                                                                                                                           |
| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |
| DIO Set Interrupt Level/Direction<br>Each DIO that is selected will have<br>which was previously selected. | -               | —                   | rising edge ti  | riggered or logic level high triggered, depending on                                                                                                                            |
| DIO interrupt level/direction set                                                                          | [17:0]          | 0x0                 | R/W             | 1 – Rising edge or logic high triggered interrupt<br>0 – No effect                                                                                                              |
|                                                                                                            | 1               | ł                   | t _             | +                                                                                                                                                                               |
| Function                                                                                                   | Bits            | Default             | Туре            | Description                                                                                                                                                                     |

## Table 12. REGISTERS

| Function                                                                                    | Bits                      | Default                  | Туре             | Description                                                                                                                |
|---------------------------------------------------------------------------------------------|---------------------------|--------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------|
| DIO interrupt level/direction<br>clear                                                      | [17:0]                    | 0x0                      | R/W              | 1 – Falling edge or logic low triggered interrupt<br>0 – No effect                                                         |
| Function                                                                                    | Bits                      | Default                  | Туре             | Description                                                                                                                |
| DIO Set Any Edge Interrupt Over                                                             | ride Register:            | 0x4000_C028              | •                |                                                                                                                            |
| Each DIO that is selected will have viously selected.                                       | its interrupt be          | e set to be either       | rising or fallir | ng edge triggered, regardless of what settings were pre-                                                                   |
| DIO interrupt any direction over-<br>ride set                                               | [17:0]                    | 0x0                      | R/W              | 1 – Rising or falling edge triggered interrupt<br>0 – No effect                                                            |
| Function                                                                                    | Bits                      | Default                  | Туре             | Description                                                                                                                |
| DIO Clear Any Edge Interrupt Over<br>Each DIO that is selected will have<br>register above. | -                         | _                        | This is the cle  | ear register for the DIO set any edge interrupt override                                                                   |
| DIO interrupt any direction over-<br>ride clear                                             | [17:0]                    | 0x0                      | R/W              | <ul> <li>1 – Clear override interrupt, return to settings in non-<br/>override registers</li> <li>0 – No effect</li> </ul> |
| Function                                                                                    | Bits                      | Default                  | Туре             | Description                                                                                                                |
| DIO Clear Interrupt Register: 0x400<br>Each DIO that is selected will have                  | —                         | ding interrupt clea      | ared.            |                                                                                                                            |
| DIO interrupt clear                                                                         | [17:0]                    | 0x0                      | R/W              | 1 – Clear interrupt<br>0 – No effect                                                                                       |
| Function                                                                                    | Bits                      | Default                  | Туре             | Description                                                                                                                |
| Each DIO that is selected will have<br>DIO loopback enable                                  | its output sigr<br>[17:0] | al routed back to<br>0x0 | its input sigr   | nal.<br>1 – Mirror output signal back in as an input<br>0 – No effect                                                      |
| Function                                                                                    | Bits                      | Default                  | Туре             | Description                                                                                                                |
| DIO[0] Control Register: 0x4001                                                             | C000                      |                          |                  |                                                                                                                            |
| DIO[1] Control Register: 0x4001                                                             |                           |                          |                  |                                                                                                                            |
| DIO[2] Control Register: 0x4001                                                             |                           |                          |                  |                                                                                                                            |
| DIO[3] Control Register: 0x4001                                                             | COOC                      |                          |                  |                                                                                                                            |
| DIO[4] Control Register: 0x4001                                                             |                           |                          |                  |                                                                                                                            |
| DIO[5] Control Register: 0x4001                                                             | C014                      |                          |                  |                                                                                                                            |
| DIO[6] Control Register: 0x4001_                                                            | C018                      |                          |                  |                                                                                                                            |
| DIO[7] Control Register: 0x4001_                                                            | C01C                      |                          |                  |                                                                                                                            |
| DIO[8] Control Register: 0x4001_                                                            | C020                      |                          |                  |                                                                                                                            |
| DIO[9] Control Register: 0x4001_                                                            | C024                      |                          |                  |                                                                                                                            |
| DIO[10] Control Register: 0x4001                                                            | _C028                     |                          |                  |                                                                                                                            |
| DIO[11] Control Register: 0x4001                                                            | _C02C                     |                          |                  |                                                                                                                            |
| DIO[12] Control Register: 0x4001                                                            | —                         |                          |                  |                                                                                                                            |
| DIO[13] Control Register: 0x4001                                                            | —                         |                          |                  |                                                                                                                            |
| DIO[14] Control Register: 0x4001                                                            | —                         |                          |                  |                                                                                                                            |
| DIO[15] Control Register: 0x4001                                                            | —                         |                          |                  |                                                                                                                            |
| DIO[16] Control Register: 0x4001                                                            | —                         |                          |                  |                                                                                                                            |
| DIO[17] Control Register: 0x4001                                                            | —                         |                          |                  |                                                                                                                            |
| DBG_TEST_EN pin is high, the DI                                                             | ວ[11:13] pins ູ           | get automatically        | reconfigured     |                                                                                                                            |
|                                                                                             | ternal devices            | if the default driv      |                  | ammer may desire putting the drive strength to maxi-<br>not sufficient. Drive strength capabilities are reduced a          |

#### Table 12. REGISTERS

| Function                                                                   | Bits  | Default | Туре | Description                                                                  |
|----------------------------------------------------------------------------|-------|---------|------|------------------------------------------------------------------------------|
| Output driver type                                                         | [5]   | 0x0     | R/W  | 0 – Push/Pull<br>1 – Open drain pull down only (NMOS transistor)             |
| Output drive strength, typical at 3V (refer to datasheet)                  | [4:2] | 0x1     | R/W  | 000 – 1.4 mA<br>001 – 2.7 mA<br>010 – 5.3 mA<br>011 – 10.4 mA                |
| Pull enable and direction (approx. $10k\Omega$ res, see product datasheet) | [1:0] | 0x0     | R/W  | 00 – Pull down active<br>01 – No pull<br>10 – No pull<br>11 – Pull up active |

# **CROSSBAR CONTROL**

#### Description

To connect the UARTs, SPIs, I2Cs, DIOs, and PWM to the external DIO pins the crossbar must be utilized. Not every peripheral can reach every DIO pad so the system designer must make sure the physical PCB layout and the desired software configuration of the peripherals through the crossbar is compatible with system requirements.

If the DBG\_TEST\_EN pin is high, the crossbar settings are superseded by the debugger logic for DIO[13], DIO[12] and DIO[11].

The following table summarizes what peripherals can be connected to what DIO pins.

|        | 1                      |   | 1 |   |   |   |   |   | DI | C |   |   |   |   |   |   |   |   |   |
|--------|------------------------|---|---|---|---|---|---|---|----|---|---|---|---|---|---|---|---|---|---|
|        |                        | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|        |                        | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |   |   |   |   |   |   |   |   |   |   |
| _      | Transmit Data          |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   |   | Х |
| EL .   | Receive Data           |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   | Х |   |
| UART 1 | Clear To Send          |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   | Х |   |   |
|        | Request To<br>Send     |   |   |   |   |   |   |   |    |   |   |   |   |   |   | Х |   |   |   |
|        | Data Terminal<br>Ready |   |   |   |   |   |   |   |    |   |   |   |   |   | Х |   |   |   |   |
|        | Data Set Ready         |   |   |   |   |   |   |   |    |   |   |   |   | Х |   |   |   |   |   |
|        | Data Carrier           |   |   |   |   |   |   |   |    |   |   |   | Х |   |   |   |   |   |   |
|        | Detect                 |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   |   |   |
|        | Ring Indicator         |   |   |   |   |   |   |   |    |   |   | Х |   |   |   |   |   |   |   |
|        | •                      |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   |   |   |
|        | Transmit Data          |   |   |   |   |   |   |   |    |   | Х |   |   |   |   |   |   |   |   |
| UART 2 | Receive Data           |   |   |   |   |   |   |   |    | Х |   |   |   |   |   |   |   |   |   |
| AR     | Clear To Send          |   |   |   |   |   |   |   | Х  |   |   |   |   |   |   |   |   |   |   |
| Ď      | Request To             |   |   |   |   |   |   | Х |    |   |   |   |   |   |   |   |   |   |   |
|        | Send                   |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   |   |   |
|        | SCLK                   |   |   |   |   | Х |   | Х |    |   |   |   |   | Х |   |   | Х |   |   |
| 12C 1  | SDATA                  |   |   |   |   |   | Х |   | Х  |   |   |   |   |   | Х | Х |   |   |   |
|        |                        |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   |   |   |
| 12C 2  | SCLK                   | Х |   |   | Х |   |   |   |    |   |   |   |   |   |   |   |   |   |   |
| 120    | SDATA                  |   | Х | Х |   |   |   |   |    |   |   |   |   |   |   |   |   |   |   |
|        | 1                      |   |   |   |   |   |   |   |    |   |   |   |   |   |   |   |   |   |   |

| _     | SCLK     |   |          |   |          |          |          |   |   |   | Х |   |   |   | Х |   |   |   |   |
|-------|----------|---|----------|---|----------|----------|----------|---|---|---|---|---|---|---|---|---|---|---|---|
| SPI 1 | SDATAO   |   |          |   |          |          |          |   |   | Х |   |   |   | Х |   |   |   |   |   |
| S     | SDATAI   |   |          |   |          |          |          |   | Х |   |   |   | Х |   |   |   |   |   |   |
|       | SSNI     |   |          |   |          |          |          | Х |   |   |   | Х |   |   |   |   |   |   |   |
|       | SSNO<0>  |   |          |   |          |          | Х        |   |   |   | Х |   |   |   |   |   |   |   | Х |
|       | SSNO<1>  |   |          |   |          | Х        |          |   |   | Х |   |   |   |   |   |   |   | Х |   |
|       | SSNO<2>  |   |          |   |          |          |          |   | Х |   |   |   |   |   |   |   | Х |   |   |
|       | SSNO<3>  |   |          |   |          |          |          | Х |   |   |   |   |   |   |   | Х |   |   |   |
|       |          |   |          |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       | SCLK     |   |          |   | Х        |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
| ~     | SDATAO   |   |          | Х |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
| SPI 2 | SDATAI   |   | Х        |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
| S     | SSNI     | х |          |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       | SSNO<0>  | х |          |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       |          |   |          |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
| PWM   | Output   |   |          |   |          | х        | х        |   |   | Х |   | Х | Х |   |   |   |   |   |   |
| ۵     |          |   |          |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
| ᅌᆠᅌ   | 17       | х |          |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       | 16       | ~ | Х        |   |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       | 15       |   | ~        | Х |          |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       | 14       |   |          | ~ | Х        |          |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       | 13       |   |          |   | ~        | Х        |          |   |   |   |   |   |   |   |   |   |   |   |   |
|       | 12       |   |          |   |          | ~        | Х        |   |   |   |   |   |   |   |   |   |   |   |   |
|       | 11       |   |          |   |          |          | ~        | Х |   |   |   |   |   |   |   |   |   |   |   |
|       | 10       |   |          |   |          |          |          | ~ | Х |   |   |   |   |   |   |   |   |   |   |
|       | 9        |   |          |   |          |          |          |   | ~ | х |   |   |   |   |   |   |   |   |   |
|       | 8        |   |          |   |          |          |          |   |   | ~ | х |   |   |   |   |   |   |   |   |
|       | 7        |   |          |   |          |          |          |   |   |   | ~ | х |   |   |   |   |   |   |   |
|       | 6        |   |          |   |          |          |          |   |   |   |   | ~ | х |   |   |   |   |   |   |
|       | 5        |   |          |   |          |          |          |   |   |   |   |   | ~ | Х |   |   |   |   |   |
|       | 4        |   | <u> </u> | 1 | <u> </u> | <u> </u> | <u> </u> |   | 1 |   |   |   |   |   | Х |   |   |   |   |
|       | 3        |   |          |   |          |          |          |   |   |   |   |   |   |   |   | Х |   |   |   |
|       | 2        |   |          |   |          |          |          |   |   |   |   |   |   |   |   |   | х |   |   |
|       | 1        |   |          |   |          |          |          |   |   |   |   |   |   |   |   |   | ~ | х |   |
|       | 0        |   |          |   |          |          |          |   |   |   |   |   |   |   |   |   |   | ~ | Х |
|       | <b>`</b> |   | I        | I | I        | I        | I        |   | I | I | I |   |   |   |   |   | I |   | ~ |

| Function                                                                    | Bits          | Default | Туре | Description                                                 |
|-----------------------------------------------------------------------------|---------------|---------|------|-------------------------------------------------------------|
| Crossbar Control Register for DIC<br>Crossbar control register.             | D[0]: 0x4001_ | 0000    |      |                                                             |
| DIO[1]                                                                      | [2:0]         | 0x0     | R/W  | 111 – UART 1 Tx data<br>110 – SPI 1 SSNO[0]<br>000 – DIO[0] |
|                                                                             |               |         | _    |                                                             |
| Function                                                                    | Bits          | Default | Туре | Description                                                 |
| Function<br>Crossbar Control Register for DIC<br>Crossbar control register. |               |         | Туре | Description                                                 |

| Function                                                                                                                                          | Bits                                              | Default                                  | Туре                  | Description                                                                                                                                                                                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Crossbar Control Register for<br>Crossbar control register.                                                                                       | DIO[2]: 0x4001_                                   | _0008                                    |                       |                                                                                                                                                                                                 |
| DIO[2]                                                                                                                                            | [2:0]                                             | 0x0                                      | R/W                   | 111 – UART 1 clear to send<br>110 – SPI 1 SSNO[2]<br>101 – I2C 1 I2C SCLK<br>000 – DIO[2]                                                                                                       |
| Function                                                                                                                                          | Bits                                              | Default                                  | Туре                  | Description                                                                                                                                                                                     |
| Crossbar Control Register for<br>Crossbar control register.                                                                                       | DIO[3]: 0x4001                                    | 000C                                     |                       |                                                                                                                                                                                                 |
| DIO[3]                                                                                                                                            | [2:0] 0X0 110 – SPI 1 SSNO[3]                     |                                          | 101 – I2C 1 I2C SDATA |                                                                                                                                                                                                 |
| Function                                                                                                                                          | Bits                                              | Default                                  | Туре                  | Description                                                                                                                                                                                     |
| Crossbar Control Register for<br>Crossbar control register.<br>DIO[4]                                                                             | DIO[3]: 0x4001_                                   | 0010<br>0x0                              | R/W                   | 111 – UART 1 Data terminal ready                                                                                                                                                                |
|                                                                                                                                                   |                                                   |                                          |                       | 110 – SPI 1 SCLK<br>101 – I2C 1 I2C SDATA<br>000 – DIO[4]                                                                                                                                       |
| Function                                                                                                                                          | Bits                                              | Default                                  | Туре                  | Description                                                                                                                                                                                     |
| Crossbar Control Register for<br>Crossbar control register.                                                                                       | DIO[5]: 0x4001_                                   | 0014                                     | ·                     |                                                                                                                                                                                                 |
| DIO[5]                                                                                                                                            | [2:0]                                             | 0x0                                      | R/W                   | 111 – UART 1 data set ready<br>110 – SPI 1 SDATA0<br>101 – I2C 1 I2C SCLK<br>000 – DIO[5]                                                                                                       |
| Function                                                                                                                                          | Bits                                              | Default                                  | Туре                  | Description                                                                                                                                                                                     |
|                                                                                                                                                   |                                                   |                                          |                       |                                                                                                                                                                                                 |
| Crossbar Control Register for<br>Crossbar control register.                                                                                       | DIO[6]: 0x4001_                                   | _0018                                    |                       |                                                                                                                                                                                                 |
| •                                                                                                                                                 | DIO[6]: 0x4001_<br>[2:0]                          | _0018                                    | R/W                   | 111 – UART 1 data carrier detect<br>110 – SPI 1 SDATAI<br>100 – PWM output<br>000 – DIO[6]                                                                                                      |
| Crossbar control register.                                                                                                                        |                                                   | -                                        | R/W<br>Type           | 110 – SPI 1 SDATAI<br>100 – PWM output                                                                                                                                                          |
| Crossbar control register.<br>DIO[6]                                                                                                              | [2:0]<br>Bits                                     | 0x0<br>Default                           |                       | 110 – SPI 1 SDATAI<br>100 – PWM output<br>000 – DIO[6]                                                                                                                                          |
| Crossbar control register.<br>DIO[6]<br>Function<br>Crossbar Control Register for                                                                 | [2:0]<br>Bits                                     | 0x0<br>Default                           |                       | 110 – SPI 1 SDATAI<br>100 – PWM output<br>000 – DIO[6]                                                                                                                                          |
| Crossbar control register. DIO[6] Function Crossbar Control Register for Crossbar control register.                                               | [2:0]<br>Bits<br>DIO[7]: 0x4001_                  | 0x0<br>Default<br>_001C                  | Туре                  | 110 – SPI 1 SDATAI<br>100 – PWM output<br>000 – DIO[6]<br>Description<br>111 – UART 1 ring indicator<br>110 – SPI 1 SSNI<br>100 – PWM output                                                    |
| Crossbar control register. DIO[6] Function Crossbar Control Register for Crossbar control register. DIO[7]                                        | [2:0]<br>Bits<br>DIO[7]: 0x4001_<br>[2:0]<br>Bits | 0x0<br>Default<br>001C<br>0x0<br>Default | Type<br>R/W           | 110 – SPI 1 SDATAI         100 – PWM output         000 – DIO[6]         Description         111 – UART 1 ring indicator         110 – SPI 1 SSNI         100 – PWM output         000 – DIO[7] |
| Crossbar control register. DIO[6] Function Crossbar Control Register for Crossbar control register. DIO[7] Function Crossbar Control Register for | [2:0]<br>Bits<br>DIO[7]: 0x4001_<br>[2:0]<br>Bits | 0x0<br>Default<br>001C<br>0x0<br>Default | Type<br>R/W           | 110 – SPI 1 SDATAI         100 – PWM output         000 – DIO[6]         Description         111 – UART 1 ring indicator         110 – SPI 1 SSNI         100 – PWM output         000 – DIO[7] |

| Function                                                    | Bits            | Default | Туре | Description                                                                                                  |
|-------------------------------------------------------------|-----------------|---------|------|--------------------------------------------------------------------------------------------------------------|
| DIO[9]                                                      | [2:0]           | 0x0     | R/W  | 111 – UART 2 Rx data<br>110 – SPI 1 SDATAO<br>100 – PWM output<br>011 – SPI 1 SSN[1]<br>000 – DIO[9]         |
| Function                                                    | Bits            | Default | Туре | Description                                                                                                  |
| Crossbar Control Register for<br>Crossbar control register. | DIO[10]: 0x4001 | 1_0028  |      |                                                                                                              |
| DIO[10]                                                     | [2:0]           | 0x0     | R/W  | 111 – UART 2 clear to send<br>110 – SPI 1 SDATAI<br>101 – I2C 1 SDATA<br>011 – SPI 1 SSN[2]<br>000 – DIO[10] |
| Crossbar Control Register for<br>Crossbar control register. | DIO[11]: 0x4001 | I_002C  |      |                                                                                                              |
| DIO[11]                                                     | [2:0]           | 0x0     | R/W  | 111 – UART 2 request to send<br>110 – SPI 1 SSNI<br>101 – I2C 1 SCLK<br>011 – SPI 1 SSN[3]<br>000 – DIO[11]  |
| Function                                                    | Bits            | Default | Туре | Description                                                                                                  |
| Crossbar Control Register for<br>Crossbar control register. | DIO[12]: 0x4001 | 1_0030  |      |                                                                                                              |
| DIO[12]                                                     | [2:0]           | 0x0     | R/W  | 110 – SPI 1 SSNO[0]<br>101 – I2C 1 SDATA<br>100 – PWM output<br>000 – DIO[12]                                |
| Function                                                    | Bits            | Default | Туре | Description                                                                                                  |
| Crossbar Control Register for<br>Crossbar control register. | DIO[13]: 0x4001 | 1_0034  | •    |                                                                                                              |
| DIO[13]                                                     | [2:0]           | 0x0     | R/W  | 110 – SPI 1 SSNO[1]<br>101 – I2C 1 SCLK<br>100 – PWM output<br>000 – DIO[13]                                 |
| Function                                                    | Bits            | Default | Туре | Description                                                                                                  |
| Crossbar Control Register for<br>Crossbar control register. | DIO[14]: 0x4001 | 1_0038  |      |                                                                                                              |
| DIO[14]                                                     | [2:0]           | 0x0     | R/W  | 110 – SPI 2 SCLK<br>101 – I2C 2 SCLK<br>000 – DIO[14]                                                        |
| Function                                                    | Bits            | Default | Туре | Description                                                                                                  |
| Crossbar Control Register for<br>Crossbar control register. | DIO[15]: 0x4001 | 1_003C  |      |                                                                                                              |
| DIO[15]                                                     | [2:0]           | 0x0     | R/W  | 110 – SPI 2 SDATAO<br>101 – I2C 2 SDATA<br>000 – DIO[15]                                                     |
| Function                                                    | Bits            | Default | Туре | Description                                                                                                  |
| Crossbar Control Register for<br>Crossbar control register. | DIO[16]: 0x4001 | 1_0040  |      |                                                                                                              |
| DIO[16]                                                     | [2:0]           | 0x0     | R/W  | 110 – SPI 2 SDATAI<br>101 – I2C 2 SDATA<br>000 – DIO[16]                                                     |
|                                                             |                 |         |      |                                                                                                              |

| Function                                                        | Bits          | Default | Туре | Description                                                      |
|-----------------------------------------------------------------|---------------|---------|------|------------------------------------------------------------------|
| Crossbar Control Register for DIC<br>Crossbar control register. | D[17]: 0x4001 | _0040   |      |                                                                  |
| DIO[17]                                                         | [2:0]         | 0x0     | R/W  | 110 – SPI 2 SSNO[0] or SSNI<br>101 – I2C 2 SCLK<br>000 – DIO[17] |

## DIRECT MEMORY ACCESS (DMA) CONTROLLER

#### Description

The DMA controller is a single channel direct memory access controller. It can be used to directly transfer data from one memory to another.

After initial setup, the DMA controller initiates data transfer from the user specified source address to the internal FIFO. It then performs another transfer to move the data from the FIFO to the user specified destination address. The FIFO size is 32 words by 32 bits.

The DMA controller transfers data on word, 1/2 word, and byte aligned boundaries. The DMA controller supports beat modes of 4, 8, and 16 using incrementing bursts. Unspecified length bursts and single transfers are also supported. Wrapping bursts are not supported. The bursts are automatically controlled and are based on the number of specified bytes to transfer. Interrupts are generated upon transfer completion and/or error conditions. General programming sequence:

- Disable DMA in DMA control register
- Write source address, destination address, and transfer size to corresponding registers
- Enable the interrupt enable register
- Enable DMA in DMA control register
- Wait for interrupt or poll status register for done flag

| Function                                                                                | Bits            | Default | Туре        | Description                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------------------------|-----------------|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA Control Register: 0x2400_04                                                         | 100             | I       | 1           | •                                                                                                                                                                                                                                                          |
| DMA control register.                                                                   |                 |         |             |                                                                                                                                                                                                                                                            |
| DMA mode                                                                                | [2:1]           | 0x0     | R/W         | 00 – Memory to memory                                                                                                                                                                                                                                      |
| DMA enable                                                                              | [0]             | 0x0     | R/W         | 1 – Enabled<br>0 – Disabled                                                                                                                                                                                                                                |
| Function                                                                                | Bits            | Default | Туре        | Description                                                                                                                                                                                                                                                |
| DMA Source Address Register: 0                                                          | x2400_0404      | 1       |             |                                                                                                                                                                                                                                                            |
| DMA source address register.                                                            |                 |         |             |                                                                                                                                                                                                                                                            |
| Source address to read data from                                                        | [31:0]          | 0x0     | R/W         | A write configures the source address where the DMA controller will read from.                                                                                                                                                                             |
|                                                                                         |                 |         |             | A read returns the written data. The source address<br>can be on a word, 1/2 word or byte boundary, but is<br>required to be specified as a 32 bit address.                                                                                                |
| Function                                                                                | Bits            | Default | Туре        | Description                                                                                                                                                                                                                                                |
| DMA destination address register.                                                       | [31:0]          | 0x0     | R/W         | A write configures the destination address where the                                                                                                                                                                                                       |
| ta to                                                                                   | [01.0]          | UXU     | L1/ A A     | DMA controller will write to.                                                                                                                                                                                                                              |
|                                                                                         | [01.0]          | 0.00    | n, <b>v</b> |                                                                                                                                                                                                                                                            |
|                                                                                         | Bits            | Default | Туре        | DMA controller will write to.<br>A read returns the written data. The source address<br>can be on a word, 1/2 word or byte boundary, but is                                                                                                                |
| ta to Function                                                                          | Bits            |         |             | DMA controller will write to.<br>A read returns the written data. The source address<br>can be on a word, 1/2 word or byte boundary, but is<br>required to be specified as a 32 bit address.                                                               |
| ta to Function DMA Transfer Size Register: 0x24                                         | Bits            |         |             | DMA controller will write to.<br>A read returns the written data. The source address<br>can be on a word, 1/2 word or byte boundary, but is<br>required to be specified as a 32 bit address.                                                               |
| Tunction<br>Function<br>DMA Transfer Size Register: 0x24<br>DMA transfer size register. | Bits<br>00_040C | Default | Туре        | DMA controller will write to.<br>A read returns the written data. The source address can be on a word, 1/2 word or byte boundary, but is required to be specified as a 32 bit address.<br>Description<br>A write configures the size of the DMA data to be |

#### Table 14. REGISTERS

| Function                                                                 | Bits       | Default | Туре | Description                                        |
|--------------------------------------------------------------------------|------------|---------|------|----------------------------------------------------|
| Destination error                                                        | [2]        | 0x0     | RO   | 0 – No error<br>1 – Error                          |
| Source error                                                             | [1]        | 0x0     | RO   | 0 – No error<br>1 – Error                          |
| Transfer complete                                                        | [0]        | 0x0     | RO   | 0 – Not complete<br>1 – Complete                   |
| Function                                                                 | Bits       | Default | Туре | Description                                        |
| DMA Interrupt Enable Register: 0<br>DMA interrupt enable register.       | x2400_0414 |         |      |                                                    |
| Enable destination error interrupt                                       | [2]        | 0x0     | R/W  | 1 – Enable interrupt<br>0 – Disable interrupt      |
| Enable source error interrupt                                            | [1]        | 0x0     | R/W  | 1 – Enable interrupt<br>0 – Disable interrupt      |
| DMA transfer complete interrupt<br>enable                                | [0]        | 0x0     | R/W  | 1 – Enable interrupt<br>0 – Disable interrupt      |
| Function                                                                 | Bits       | Default | Туре | Description                                        |
| DMA Interrupt Status Register: 02<br>DMA interrupt status register. Clea | -          |         |      |                                                    |
| Destination error interrupt                                              | [2]        | 0x0     | RO   | 1 – Interrupt active<br>0 – No interrupt           |
| Source error interrupt                                                   | [1]        | 0x0     | RO   | 1 – Interrupt active<br>0 – No interrupt           |
| Transfer complete interrupt                                              | [0]        | 0x0     | RO   | 1 – Interrupt active<br>0 – No interrupt (or busy) |

## 10 BIT SUCCESSIVE APPROXIMATION (SAR) ANALOG TO DIGITAL CONVERTER (ADC)

#### Description

The NCS36510 has a fully integrated 10 bit SAR ADC.

The ADC is single ended to reduce power consumption. A six input multiplexer allows up to four external signals to be measured. The other two inputs are for internal temperature and battery voltage (V3V) sensors.

WARNING: Warning: The user has the responsibility to respect the absolute maximum ratings. The voltage on the ADC pins cannot exceed V3V + 0.3 V, regardless of the input scaling. Several modes of ADC operation are available including absolute, ratio based, and pseudo – differential.

All ADC conversions are referenced to an internal fixed reference of nominally 950 mV. Absolute conversions represent the input signal compared to this fixed reference.

A programmable scale factor can be used to enable a resistive voltage divider at the A[x] pins to divide the

The SAR ADC completes a conversion as fast as 5  $\mu$ s with a 4 MHz sample clock in 20 clock cycles. To support a wide range of input voltages, there is a programmable resistive voltage divider on the external inputs. The table below shows the ideal settings.

incoming voltage. Please note that the only high impedance setting is the scale factor of 1.0. The following table documents the possible scale factor settings and their maximum input voltages.

| Scale Factor | Maximum Input Voltage | Input Resistance |
|--------------|-----------------------|------------------|
| 1.00         | 0.950 V               | High Impedance   |
| 0.69         | 1.3 V                 | 80 kΩ            |
| 0.53         | 1.7 V                 | 52 kΩ            |
| 0.43         | 2.1 V                 | 43 kΩ            |
| 0.36         | 2.5 V                 | 38 kΩ            |
| 0.31         | 2.9 V                 | 36 kΩ            |
| 0.28         | 3.3 V                 | 34 kΩ            |
| 0.24         | 3.6 V                 | 32 kΩ            |

#### Table 15. MINIMUM ROW TIME AND BLANKING NUMBERS

For applications that require measuring an external signal versus an external reference, a ratio based conversion mode is supported. Two ADC conversions are done back to back and automatically divided to get a ratio. Pseudo – differential mode is similar to ratio based mode, except the final computation is the difference of the two signals instead of the ratio.

Ratio based pseudo – differential mode consists of three conversions. The first two are taken as a differential signal, the third is considered as a reference. The resulting differential voltage is automatically divided by the third conversion resulting in a pseudo – differential ratio.

This SAR ADC, like all ADCs, has a finite input time constant. The mux has a finite resistance, and the input of the ADC has a finite capacitance. The input voltage must be fully settled to get an accurate conversion. The input time constant also depends on the scale factors programmed. The following table contains typical values for time constants as a function of the input scale factor. For maximum accuracy, at least 7 time constants of settling time are recommended. The following table has recommended settling times for various scale factors.

#### Table 16. MINIMUM ROW TIME AND BLANKING NUMBERS

| Scale Factor | Time constant, τ | 7 τ     |
|--------------|------------------|---------|
| 1.00         | 160 ns           | 1.12 μs |
| 0.69         | 110 ns           | 770 ns  |
| 0.53         | 85 ns            | 595 ns  |
| 0.43         | 68 ns            | 476 ns  |
| 0.36         | 58 ns            | 406 ns  |
| 0.31         | 50 ns            | 350 ns  |
| 0.28         | 44 ns            | 308 ns  |
| 0.24         | 39 ns            | 273 ns  |

The ADC can be used in either single or continuous conversion modes.

There is a status bit that can be polled to determine if the ADC is busy. An interrupt can also be configured to avoid consuming processor cycles polling the status bit.

Averaging can improve the accuracy of the SAR ADC conversions as compared to single shot measurements.

#### Table 17. RECOMMENDED GAIN SETTINGS

| Function                                                           | Bits    | Default | Туре | Description                                                                                                                       |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------|---------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| SAR ADC Control Register: 0x4001_5000<br>SAR ADC control register. |         |         |      |                                                                                                                                   |  |  |  |  |  |  |  |  |
| Reference channel select                                           | [14:12] | 0x0     | R/W  | 000 – A[0]<br>001 – A[1]<br>010 – A[2]<br>011 – A[3]<br>110 – Internal temperature sensor<br>111 – Internal supply voltage sensor |  |  |  |  |  |  |  |  |

## Table 17. RECOMMENDED GAIN SETTINGS

| Function                                                               | Bits            | Default          | Туре                                                                         | Description                                                                                                                                     |  |  |  |  |  |
|------------------------------------------------------------------------|-----------------|------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Measurement channel select                                             | [10:8]          | 0x0              | R/W                                                                          | 000 – A[0]<br>001 – A[1]<br>010 – A[2]<br>011 – A[3]<br>110 – Internal temperature sensor<br>111 – Internal supply voltage sensor               |  |  |  |  |  |
| Measurement type select                                                | [3]             | 0x0              | R/W                                                                          | 0 – Relative<br>1 – Absolute                                                                                                                    |  |  |  |  |  |
| Measurement abort                                                      | [2]             | 0x0              | R/W                                                                          | 0 – No effect<br>1 – Aborts the continuous conversion                                                                                           |  |  |  |  |  |
| Measurement start                                                      | [1]             | 0x0              | R/W                                                                          | 0 – No effect<br>1 – Start a conversion                                                                                                         |  |  |  |  |  |
| Measurement mode                                                       | [0]             | 0x0              | R/W                                                                          | 0 – Single sample<br>1 – Continuous sampling                                                                                                    |  |  |  |  |  |
| Function                                                               | Bits            | Default          | Туре                                                                         | Description                                                                                                                                     |  |  |  |  |  |
| SAR ADC Delay Settings Register                                        | _               |                  |                                                                              |                                                                                                                                                 |  |  |  |  |  |
| SAR ADC delay settings register. A                                     | Allows fine tun | ing of warm up p | eriods. Typic                                                                | cally this is left at the default settings.                                                                                                     |  |  |  |  |  |
| Sample delay                                                           | [31:24]         | 0x1A             | R/W                                                                          | Number of ADC clock cycles that the controller dwells in the measurement state.                                                                 |  |  |  |  |  |
|                                                                        |                 |                  |                                                                              | The minimum value of this delay is decimal 20.                                                                                                  |  |  |  |  |  |
| Warm up delay                                                          | [23:16]         | 0x05             | 0x05 R/W Number of ADC clock cycles the the warm up state (before converted) |                                                                                                                                                 |  |  |  |  |  |
| Sample period                                                          | [15:0]          | 0x0034           | R/W                                                                          | The number of ADC clock cycles between measure-<br>ments when in continuous mode.                                                               |  |  |  |  |  |
|                                                                        |                 |                  |                                                                              | Set this value to 0 for maximum throughput.                                                                                                     |  |  |  |  |  |
|                                                                        |                 |                  |                                                                              | Values greater than 0 but less than 2 plus the sum of<br>the sample delay plus the warm-up delay are not<br>allowed in absolute mode.           |  |  |  |  |  |
|                                                                        |                 |                  |                                                                              | Values greater than 0 but less than 4 plus the sum of 2 times the sample delay plus 2 times the warm-up delay are not allowed in relative mode. |  |  |  |  |  |
| Function                                                               | Bits            | Default          | Туре                                                                         | Description                                                                                                                                     |  |  |  |  |  |
| SAR ADC Result Register: 0x400                                         | 1_5008          | •                |                                                                              |                                                                                                                                                 |  |  |  |  |  |
| SAR ADC measurement result regis                                       | ster.           |                  |                                                                              |                                                                                                                                                 |  |  |  |  |  |
| SAR ADC measurement result                                             | [9:0]           | 0x0              | RO                                                                           | Measurement result from ADC conversion. This val-<br>ue is updated 42 FCLK cycles after the end of the<br>programmed sample delay.              |  |  |  |  |  |
| Function                                                               | Bits            | Default          | Туре                                                                         | Description                                                                                                                                     |  |  |  |  |  |
| SAR ADC Interrupt Register: 0x40<br>SAR ADC interrupt configuration re | -               |                  |                                                                              |                                                                                                                                                 |  |  |  |  |  |
| SAR ADC interrupt control                                              | [0]             | 0x0              | R/W                                                                          | 0 – Interrupt disabled<br>1 – Interrupt enabled                                                                                                 |  |  |  |  |  |
| Function                                                               | Bits            | Default          | Туре                                                                         | Description                                                                                                                                     |  |  |  |  |  |
| SAR ADC Clock Prescaler Regist                                         | _               | 010              |                                                                              |                                                                                                                                                 |  |  |  |  |  |
| SAR ADC clock divider prescaler re                                     |                 |                  | 1                                                                            |                                                                                                                                                 |  |  |  |  |  |
| SAR ADC clock divider prescaler re                                     | [8]             | 0x0              | R/W                                                                          | 0 – ADC clock disabled<br>1 – ADC clock enabled                                                                                                 |  |  |  |  |  |

#### Table 17. RECOMMENDED GAIN SETTINGS

| Function                                                                                   | Bits | Default | Туре | Description                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------|------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| SAR ADC Clock Prescaler Register: 0x4001_5014<br>SAR ADC clock divider prescaler register. |      |         |      |                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| SAR ADC conversion status                                                                  | [0]  | 0x0     | RO   | When the Interrupt Enable bit in the Interrupt Regis-<br>ter is asserted, this output is asserted on the same<br>clock cycle as valid data is presented to the Data<br>Register. It remains high until it is cleared by clear-<br>ing the Interrupt Enable bit or by a reset. |  |  |  |  |  |  |  |  |

125 kHz.

The system clock is typically 32 MHz giving the lower

The crossbar can be used to connect the PWM to a DIO.

PWM frequency of 7.8125 kHz or the upper frequency of

#### PWM

#### Description

The PWM peripheral generates a programmable duty cycle digital output signal. The duty cycle can be programmed from 0% to 100% with 8 bit resolution.

The PWM frequency can be either the system clock divided by 256 or the system clock divided by 4096.

Table 18. REGISTERS

Function Bits Default Туре Description PWM Duty Cycle Register: 0x4001 B000 Value in this register corresponds to the desired duty cycle to be output by the PWM hardware. Writes to this location configure the duty cycle for the PWM duty cycle value [7:0] 0x0 WO PWM output. 0x00 - Always off 0x80 - 50% duty cycle 0xFF - Always on Reads from this location return the duty cycle value. Bits Function Default Туре Description PWM Enable Register: 0x4001\_B004 Write any non-zero value to enable the PWM. WO **PWM** enable 0x0 Write anything non-zero to enable [31:0] Function Bits Default Type Description PWM Disable Register: 0x4001 B008 Write any non-zero value to disable the PWM. PWM enable [31:0] 0x0 WO Write anything non-zero to enable Function Default Bits Туре Description PWM Prescale Enable Register: 0x4001 B00C Write any non-zero value to enable the PWM prescaler. WO Prescaler is PCLK/4096 PWM prescale enable [31:0] 0x0 Function Bits Default Description Туре PWM Prescale Disable Register: 0x4001 B010 Write any non-zero value to disable the PWM prescaler. WO Prescaler is PCLK/256 PWM prescale disable [31:0] 0x0 Function Bits Default Type Description

#### Table 18. REGISTERS

| Function                                                                                           | Bits  | Default | Description |                                                                        |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------|-------|---------|-------------|------------------------------------------------------------------------|--|--|--|--|--|--|--|
| PWM Read Status and Control Register: 0x4001_B010<br>Read PWM current status and control settings. |       |         |             |                                                                        |  |  |  |  |  |  |  |
| Current state of PWM output                                                                        | [10]  | 0x0     | RO          |                                                                        |  |  |  |  |  |  |  |
| Current state of PWM enable                                                                        | [9]   | 0x0     | RO          | 1 – PWM enabled<br>0 – PWM disabled                                    |  |  |  |  |  |  |  |
| Current state of PWM prescaler                                                                     | [8]   | 0x0     | RO          | 1 – PWM prescaler enabled<br>0 – PWM prescaler disabled                |  |  |  |  |  |  |  |
| Current duty cycle value                                                                           | [7:0] | 0x0     | RO          | 0x00 – Always off<br><br>0x80 – 50% duty cycle<br><br>0xFF – Always on |  |  |  |  |  |  |  |

#### IEEE 802.15.4 MAC

#### Description

The NCS36510 MAC hardware peripheral is designed to automate the low-level transmit and receive functions needed to support the IEEE 802.15.4–2006 Low-Rate Wireless Personal Area Network (LR-WPAN) standard. The system is designed so that time-critical sequences, such as frame timing, are performed by the MAC hardware peripheral, leaving only event-driven actions, such as packet origination, to be performed in software.

In transmit mode the peripheral constructs the packet to be transmitted, including the PHY synchronization and frame headers, the MAC frame header, and the CRC footer, and performs portions of the IEEE 802.15.4–2006 CSMA–CA algorithm. In addition, it can require the reception of a correct ACK before reporting a successful transmission.

In receive mode, the peripheral can be configured to test the correctness of the CRC value in a received frame, correlate the received address against an address stored in memory, and construct and transmit an acknowledgement, all without the services of the host MCU. More specifically, an outgoing ACK will be generated if the frame just received requested an ACK, and an incoming ACK must be received if the frame just transmitted requested an ACK. In the latter case, the received ACK will be validated (meaning that the received sequence number must match the transmitted sequence number). A transmitted ACK will contain the sequence number of the just–received frame.

In normal operation, only frames whose addresses match the device address are received. The entire frame, from the frame length field to the last byte of MAC payload, is written to the RX packet buffer register, for use by the MCU. (Only the CRC is not written.) During a frame transmission, the MAC hardware uses data from a TX packet buffer register to build a packet. The frame's CRC will be generated as the data is transmitted and the completed CRC will be sent at the end of frame.

Operation of the MAC peripheral is designed around a "command – interrupt" model, in which the MCU submits a sequence command to the peripheral by writing to the

MAC sequencer register and, upon completion of the command, an IRQ is generated and sent to the interrupt controller. At that time, the sequence status can be read from the 0x4001\_4010 MAC Status Register. There are maskable interrupts for the start and completion of events, the start of frame reception, valid data received, frame reception failure, PAN ID conflicts, and the matching of frame source addresses against a lookup table. While not necessary, it is possible for the MCU to be halted with its clocks gated off during operation of the MAC peripheral.

| SOURCE MATCHING<br>RAM |
|------------------------|
|                        |
|                        |
| RX RAM                 |
|                        |
|                        |
|                        |
| ТХ ВАМ                 |
|                        |
|                        |
|                        |



#### **Memory Map**

The following figure depicts the memory map of the MAC peripheral.

The MAC hardware has a single memory buffer, divided into partitions for transmit, receive and source address matching. The RAM consists of three 128–byte regions: one for a TX buffer containing data to be transmitted, one for an RX buffer for storing incoming frame data and payload, and one to contain a lookup table (LUT) of source addresses against which the MAC will compare the source address received from the incoming frame.

The memory from address 0 (0 hex) to 127 (7f hex) is used to store the data to be transmitted. The MAC hardware will start transmitting with the byte at address 0 and increment the address for subsequent bytes. Each byte is sent MSB first. The MAC RAM appears on the AHB bus and can be accessed by byte, half word, or word. While any data can be programmed in the MAC RAM to be transmitted, it is expected that a valid IEEE 802.15.4–2006 frame is written to this area. The value programmed in the *txlength* field of the 0x4001\_408C MAC Tx Length register determines how much of the data will be transmitted and also determines when the hardware stops updating the CRC calculation (and then starts transmitting the resulting calculated CRC value).

During a receive operation, each byte of the received frame is written to the MAC memory buffer. It does this with an offset of 128 bytes (32 words) from the transmit partition.

In addition, the byte stream is written offset by one byte relative to the transmitted data. This is to make room for the received frame length field, which is the first byte written. (The frame length is received as part of the PHY header, and otherwise would not be present at the MAC layer.) While the received data is always written to the MAC memory buffer, the MAC hardware will not generate the event–complete IRQ with status "Success" unless the incoming address field and CRC validate (address matches, and good CRC) – unless these requirements are waived by setting the Promiscuous Mode Enable and/or Frame Check Override bits in the 0x4001\_4004 MAC Sequencer Options register.

When the MAC is performing source address matching, it uses the lookup table (LUT) located in the memory from location 256 (100 hex) to 383 (17F hex). These locations have dedicated connections to the MAC hardware to allow simultaneous parallel matching on all locations. Each 32–bit location in the LUT can have one of two possible configurations:

| B-<br>i-<br>t | 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 23     | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9      | 1<br>8        | 1<br>7        | 1<br>6          | 1<br>5          | 1<br>4         | 1<br>3        | 1<br>2      | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-------------|---------------|---------------|-----------------|-----------------|----------------|---------------|-------------|--------|--------|---|---|---|---|---|---|---|---|---|---|
|               | PAN ID |        |        |        |        |        |        |        |        |        |        |        |             |               |               | Sho             | ort A           | ddr            | ess           |             |        |        |   |   |   |   |   |   |   |   |   |   |
| B-<br>i-<br>t | 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9<br>L | 1<br>8<br>ong | 1<br>7<br>Add | 1<br>6<br>Iress | 1<br>5<br>; (HI | 1<br>4<br>or L | 1<br>3<br>_OW | 1<br>2<br>) | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

#### Registers

Mac Sequencer

#### Table 19. RECOMMENDED GAIN SETTINGS

| Function                                                                                                                                                                                                                                                 | Bits  | Default | Туре | Description                                                                                                                                                                         |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| MAC Sequencer Register: 0x4001_4000<br>MAC sequencer register to initiate MAC operations. Sequencer options registers and other radio registers should be updated before<br>initiating the selected sequence. Event completion is flagged by interrupts. |       |         |      |                                                                                                                                                                                     |  |  |  |  |  |  |  |
| MAC sequence                                                                                                                                                                                                                                             | [2:0] | 0x00    | RW   | Initiate selected sequence according to pre-pro-<br>grammed options<br>0x00 – No Op<br>0x03 – Receive<br>0x04 – Transmit<br>0x05 – Energy Detect<br>0x06 – Clear Channel Assessment |  |  |  |  |  |  |  |

#### MAC Sequencer Options

The MAC sequencer options register sets options that change the behavior of the MAC sequencer operations.

If the Auto Receiver bit is set, when the first valid frame is successfully received, a data-arrived IRQ will be generated. (The IRQ status will remain "Not Complete" until the sequence is terminated, most conveniently via use of the stop timer). When a valid frame is successfully received, the receiver will turn off and remain off for *rxautodelay* (0x4000\_4098: *mac\_rx\_ack\_delay*) bit durations, and then restart, so there will be a period during which frames cannot be received (*rxautodelay* includes both the off time and the warm-up time). If the Auto Receiver bit is cleared, when the first valid frame is successfully received the event-complete IRQ status will change from "Not Complete" to "Success" (0x4000\_4010: *mac\_status*) and the receiver will turn off, completing the sequence.

If the Auto Receiver bit is set, the ACK Disable bit must also be set. Operation with the Auto Receiver bit set and the ACK Disable bit cleared, is undefined. (This is to prevent attempts at simultaneous transmission and reception.) If the incoming frame is requesting an ACK, but the ACK Disable bit is set, the MAC receiver will ignore the request and just restart the receiver operation. Regardless of the state of the Auto Receiver bit setting, if an invalid frame is received (wrong address, CRC fails, etc.), the receiver will restart and continue without issuing an IRQ of any type. The IRQ status will remain "Not Complete".

Upon reception of a frame, if the Promiscuous Mode bit is set (promiscuous mode enabled) an ACK will not be sent, regardless of the value of the Acknowledgement Request subfield in the Frame Control field of the received frame, and regardless of the value of the ACK Disable bit.

Upon transmission of a frame, if the Promiscuous Mode bit is set (promiscuous mode enabled) the event-complete IRQ status will change from "Not Complete" to "Success" (0x4000\_4010: *mac\_status*) whether or not a requested ACK was received, or the value of the ACK Disable bit. However, if the Promiscuous Mode bit is cleared (promiscuous mode disabled), a status of "No ACK" will be returned if the requested ACK is not received. For this reason, in normal operation it is recommended that the Promiscuous Mode bit be cleared for transmission.

| Function                                        | Bits           | Default           | Туре          | Description                                                                                                                                                                                                    |
|-------------------------------------------------|----------------|-------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC Sequencer Options Registe                   | r: 0x4001_40   | 04                | 1             |                                                                                                                                                                                                                |
| MAC sequencer options register to               | initiate MAC o | operations. Selec | t desired opt | ions before triggering the MAC sequencer register.                                                                                                                                                             |
| Frame filter – ACK Frames                       | [20]           | 0x1               | RW            | Allows reception of ACK frames                                                                                                                                                                                 |
| Frame filter – Beacon Frames                    | [19]           | 0x1               | RW            | Allows reception of Beacon frames                                                                                                                                                                              |
| Frame filter – Command Frames                   | [18]           | 0x1               | RW            | Allows reception of command frames                                                                                                                                                                             |
| Frame filter – Data Frames                      | [17]           | 0x1               | RW            | Allows reception of data frames                                                                                                                                                                                |
| Frame filter – Reserved Frame<br>Types          | [16]           | 0x1               | RW            | Allows reception of reserved frame types                                                                                                                                                                       |
| Load Slot Timer with Rx Slot Off-<br>set (rstr) | [15]           | 0                 | RW            | 1 – Slot timer is loaded with the Rx slot offset stored in register $0x4000\_0064$ when the first bit of the frame length field is received $0 - No$ slot timer loaded                                         |
| Load Slot Timer with Tx Slot Off-<br>set (rstt) | [14]           | 0                 | RW            | 1 – Slot timer is loaded with the TX slot offset stored in register $0x4000\_0064$ when the first bit of the frame length field is transmitted $0 - No$ slot timer loaded                                      |
| PAN Coordinator Set                             | [13]           | 0                 | RW            | 1 – Device is the PAN coordinator<br>0 – Device is not the PAN coordinator                                                                                                                                     |
| Frame Check Sequence Over-<br>ride              | [12]           | 0                 | RW            | <ol> <li>Return a valid received frame regardless of<br/>frame check sequence (FCS)</li> <li>Require a valid FCS to return a received frame</li> </ol>                                                         |
| Promiscuous Mode                                | [11]           | 0                 | RW            | <ul> <li>1 – Return valid received frame if CRC test passes<br/>(no packet filtering), no ACKs generated</li> <li>0 – Only return a valid received frame if CRC and<br/>packet filtering tests pass</li> </ul> |
| Unused                                          | [10]           | 0                 | RW            | Reserved.                                                                                                                                                                                                      |
| Start Sequence Control                          | [9]            | 0                 | RW            | 1 – Start sequence/event immediately<br>0 – Use MAC timer to start event (setup the MAC<br>timer first)                                                                                                        |
| Unused                                          | [8]            | 0                 | RW            | Reserved                                                                                                                                                                                                       |
| Auto Receiver Enable                            | [7]            | 0                 | RW            | <ul> <li>1 – Automatically restart the receiver at the end of a valid received frame</li> <li>0 – Do not automatically restart the receiver at the end of a valid received frame</li> </ul>                    |
| Unused                                          | [6:4]          | 0                 | RW            | Reserved.                                                                                                                                                                                                      |
| Force Transmission                              | [3]            | 0                 | RW            | <ol> <li>Force transmission even if the channel is busy</li> <li>Require completion of CSMA-CA algorithm be-<br/>fore transmission (slotted and non-slotted modes<br/>only, ignored in normal mode)</li> </ol> |

### Table 20. RECOMMENDED GAIN SETTINGS

## Table 20. RECOMMENDED GAIN SETTINGS

| Function      | Bits  | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACK Disable   | [2]   | 0       | RW   | If set, disable automatic transmission and reception<br>of ACKs.<br>If cleared, perform automatic transmission and re-<br>ception of ACKs. (But see text below concerning the<br>effects of the <i>prm</i> bit on ACKs.)<br>1 – Automatic transmit and receive ACKs are dis-<br>abled<br>0 – Automatic transmit and receive ACKs are en-<br>abled (see note about promiscuous mode) |
| Transmit Mode | [1:0] | 00      | RW   | 0x0 – Normal mode transmit. No CSMA–CA CCA<br>performed and transmit starts immediately<br>0x1 – Non–slotted mode transmit. A single CSMA–<br>CA CCA measurement is done before transmit. No<br>time slot alignment.<br>0x2 – Slotted mode transmit. A double CSMA–CA<br>CCA measurement is done before transmit and is<br>slot aligned.                                            |

#### Table 21. MAC CONTROL

| Function                          | Bits | Default | Туре | Description |  |  |
|-----------------------------------|------|---------|------|-------------|--|--|
| NAC Control Devictory 0:4004 4000 |      |         |      |             |  |  |

#### MAC Control Register: 0x4001\_4008

A MAC Synchronous Reset request resets the values of the internal MAC state machine variables, but does not affect the memorymapped MAC register values. The MAC Synchronous Reset bit is not self-clearing and a "0" must be written to MAC Synchronous Reset to release the synchronous reset.

| MAC Clock Divider     | [2] | 0x0 | RW | <ul> <li>1 – Override the current clock divider values with 0 (use for synchronous reset)</li> <li>0 – Do not override the current clock divider values with 0</li> </ul> |
|-----------------------|-----|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC Clock Enable      | [1] | 0x0 | RW | 1 – MAC clock is on<br>0 – MAC clock is off                                                                                                                               |
| MAC Synchronous Reset | [0] | 0x0 | RW | 1 – Force an asynchronous reset of MAC peripheral<br>0 – No reset                                                                                                         |

### Table 22. MAC STATUS

| Function                                                                                                                                                                                                                                                         | Bits | Default | Туре | Description                                                                        |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|------|------------------------------------------------------------------------------------|--|--|
| MAC Status Register: 0x4001_4010                                                                                                                                                                                                                                 |      |         |      |                                                                                    |  |  |
| After a MAC sequence completes, an event complete IRQ is generated (0x4000_4038), and the event status can be read in the MAC Status register as shown below. If the status register is read during a sequence, the incomplete sequence status will be returned. |      |         |      |                                                                                    |  |  |
| MAC Status Timeout                                                                                                                                                                                                                                               | [15] |         | RO   | 1 – MAC Status timeout<br>0 – No timeout                                           |  |  |
| Channel Busy                                                                                                                                                                                                                                                     | [13] |         | RO   | 1 – Channel busy as determined by RSSI > RSSI<br>Threshold<br>0 – Channel not busy |  |  |

## Table 22. MAC STATUS

| Function              | Bits  | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|-------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC Status Over Range | [12]  |         | RO   | 1 – MAC sequence started without DMA Rx pointer<br>setup<br>0 – MAC sequence started with DMA Rx pointer set-<br>up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| MAC Event Code        | [3:0] |         | RO   | 0x0 – MAC Sequence completed successfully         0x1 – MAC timer expired         0x2 – Channel busy         0x3 – CRC Failure (only returned if MAC Sequence         Options Frame Check Sequence Enable is set)         0x5 – No ACK         0x6 – PLL unlocked         0x7 – Bad start (timed event requested but start time is in the past)         0x8 – ACK frame pending Rx (ACK frame received with pending bit set)         0x9 – ACK frame pending Tx (ACK frame was sent with pending bit set)         0xA – Failed packet filtering         0xB – PAN ID conflict         0xF – Incomplete sequence |

#### Table 23. MAC OPTIONS

| Function                                                                                                                                                                                               | Bits | Default | Туре | Description                                                                                                                                                                                                                |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MAC Options Register: 0x4001_4014<br>The MAC Options register controls how the transmitted data packet is built. It contains general purpose options that in normal opera-<br>tion will never be used. |      |         |      |                                                                                                                                                                                                                            |  |  |  |
| Tx Frame Pending Bit Override<br>(tfpo)                                                                                                                                                                | [5]  | 0       | RW   | TX Frame Pending Bit override (signals an override<br>of the Frame Pending Bit value in the Frame Control<br>field of ACKs sent in response to a data request<br>command.)                                                 |  |  |  |
| Set Sampling Phase Relative to<br>Bit Clock (ssp)                                                                                                                                                      | [4]  | 0       | RW   | Set sampling phase of received bit stream relative to<br>the bit clock.<br>1 – Sampling is done near the negative–going edge<br>of the bit clock<br>0 – Sampling is done near the positive–going edge of<br>the bit clock. |  |  |  |
| Shift Direction of Bits (sdb)                                                                                                                                                                          | [3]  | 0       | RW   | Shift direction (bits)<br>1 – Reverses the bit order in each 4-bit symbol<br>0 – Does nothing.                                                                                                                             |  |  |  |
| Invert Chips (Ic)                                                                                                                                                                                      | [2]  | 0       | RW   | Invert chips<br>1 – Inverts chips (1→0, 01).<br>0 – Does nothing                                                                                                                                                           |  |  |  |
| Shift Direction of Chips (sdc)                                                                                                                                                                         | [1]  | 0       | RW   | Shift direction (chips)<br>1 – Reverses the transmission order of the 32–bit<br>chip sequence.<br>0 – Does nothing                                                                                                         |  |  |  |
| Tx Frame Pending Bit (tfp)                                                                                                                                                                             | [0]  | 0       | RW   | TX Frame Pending Bit (Frame Pending Bit value set<br>by SW in the Frame Control field of ACKs sent in<br>response to a data request command). Use with Tx<br>Frame Pending Bit Override (tfpo).                            |  |  |  |

#### Table 24. MAC PAN ID

| Function                                                       | Bits   | Default | Туре | Description                     |  |
|----------------------------------------------------------------|--------|---------|------|---------------------------------|--|
| MAC PAN ID Register: 0x4001_4018 The MAC PAN ID of the device. |        |         |      |                                 |  |
| Device PAN ID                                                  | [15:0] | 0xFFFF  | RW   | The 16 bit PAN ID of the device |  |

#### Table 25. MAC SHORT ADDRESS

| Function                                                                        | Bits   | Default | Туре | Description                            |  |  |
|---------------------------------------------------------------------------------|--------|---------|------|----------------------------------------|--|--|
| MAC Short Address Register: 0x4001_401C<br>The MAC short address of the device. |        |         |      |                                        |  |  |
| Device Short Address                                                            | [15:0] | 0x0000  | RW   | The 16 bit short address of the device |  |  |

# Table 26. MAC LONG ADDRESS HIGH

| Function                                                                                       | Bits   | Default    | Туре | Description                                                                   |  |
|------------------------------------------------------------------------------------------------|--------|------------|------|-------------------------------------------------------------------------------|--|
| MAC Long Address MSW Register: 0x4001_4020<br>The upper word of the device's long MAC address. |        |            |      |                                                                               |  |
| MSW Device Long Address                                                                        | [31:0] | 0x00000000 | RW   | The most significant word, or upper 32 bits, of the device's MAC long address |  |

## Table 27. MAC LONG ADDRESS LOW

| Function                                                                                       | Bits   | Default    | Туре | Description                                                                    |  |  |
|------------------------------------------------------------------------------------------------|--------|------------|------|--------------------------------------------------------------------------------|--|--|
| MAC Long Address LSW Register: 0x4001_4024<br>The lower word of the device's long MAC address. |        |            |      |                                                                                |  |  |
| LSW Device Long Address                                                                        | [31:0] | 0x00000000 | RW   | The least significant word, or lower 32 bits, of the device's MAC long address |  |  |

## Table 28. MAC DIVIDER

| Function                                                                                                                                                                              | Bits    | Default | Туре | Description                                                                                                                                                                                                                                         |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MAC Divider Register: 0x4001_4028                                                                                                                                                     |         |         |      |                                                                                                                                                                                                                                                     |  |  |  |
| MAC clock divider control register provides the time base for the protocol timer and sets the transmit data rate, all based on the micro-<br>processor clock frequency, FCLK, in MHz. |         |         |      |                                                                                                                                                                                                                                                     |  |  |  |
| Chip Clock Divider                                                                                                                                                                    | [23:16] | 0x0F    | RW   | The chip clock divider value is (FCLK/ 2) - 1                                                                                                                                                                                                       |  |  |  |
| System Clock Divider                                                                                                                                                                  | [15:8]  | 0x1F    | RW   | The system clock divider value is FCLK- 1                                                                                                                                                                                                           |  |  |  |
| Bit Clock Divider                                                                                                                                                                     | [7:0]   | 0x7F    | RW   | The bit clock divider value is $(4 * FCLK) - 1$ . The bit clock sets not only the transmitted bit rate, but also serves as the time base for the protocol timer. The bit clock divider value should produce a bit clock with a period of 4 $\mu$ s. |  |  |  |

#### Table 29. MAC RX/TX WARMUPS

| Function                                                                                                                     | Bits    | Default | Туре | Description |  |  |
|------------------------------------------------------------------------------------------------------------------------------|---------|---------|------|-------------|--|--|
| MAC Rx/Tx Warmups Register: 0x4001_402C                                                                                      |         |         |      |             |  |  |
| The MAC Rx/Tx Warmups register sets the warmup time duration for the transmitter and receiver, in units of bits (4 $\mu$ s). |         |         |      |             |  |  |
| Transmit Warmup                                                                                                              | [27:16] | 0x017   | RW   |             |  |  |
| Receive Warmup                                                                                                               | [11:0]  | 0x017   | RW   |             |  |  |

# Table 30. MAC CLEAR INTERRUPTS

| Function                                                                                                                                 | Bits | Default | Туре | Description                        |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------|------|---------|------|------------------------------------|--|--|
| MAC Clear Interrupts Register: 0x4001_4030<br>Clear selected MAC interrupts (all at once or individually). These bits are self-clearing. |      |         |      |                                    |  |  |
| PAN ID conflict IRQ                                                                                                                      | [6]  | 0x0     | RO   | 1 – Clear the PAN ID conflict IRQ  |  |  |
| Frame-match-done IRQ                                                                                                                     | [5]  | 0x0     | RO   | 1 - Clear the frame-match-done IRQ |  |  |

# Table 30. MAC CLEAR INTERRUPTS

| Function           | Bits | Default | Туре | Description                      |
|--------------------|------|---------|------|----------------------------------|
| Failed-packet IRQ  | [4]  | 0x0     | RO   | 1 – Clear the failed-packet IRQ  |
| Frame-started IRQ  | [3]  | 0x0     | RO   | 1 – Clear the frame-started IRQ  |
| Data-arrived IRQ   | [2]  | 0x0     | RO   | 1 – Clear the data-arrived IRQ   |
| Event-started IRQ  | [1]  | 0x0     | RO   | 1 – Clear the event-started IRQ  |
| Event-complete IRQ | [0]  | 0x0     | RO   | 1 – Clear the event-complete IRQ |

## Table 31. MAC INTERRUPT MASK

| Function                                  | Bits            | Default | Туре | Description                                                              |  |  |
|-------------------------------------------|-----------------|---------|------|--------------------------------------------------------------------------|--|--|
| MAC Interrupts Mask Register: 0x4001_4034 |                 |         |      |                                                                          |  |  |
| Setup MAC interrupt mask (all at o        | nce or individu | ally).  |      |                                                                          |  |  |
| PAN ID conflict IRQ                       | [6]             | 0x0     | RW   | 1 – Enable the PAN ID conflict IRQ<br>0 – Mask the PAN ID conflict IRQ   |  |  |
| Frame-match-done IRQ                      | [5]             | 0x0     | RW   | 1 – Enable the frame-match-done IRQ<br>0 – Mask the frame-match-done IRQ |  |  |
| Failed-packet IRQ                         | [4]             | 0x0     | RW   | 1 – Enable the failed-packet IRQ<br>0 – Mask the failed-packet IRQ       |  |  |
| Frame-started IRQ                         | [3]             | 0x0     | RW   | 1 – Enable the frame-started IRQ<br>0 – Mask the frame-started IRQ       |  |  |
| Data-arrived IRQ                          | [2]             | 0x0     | RW   | 1 – Enable the data-arrived IRQ<br>0 – Mask the data-arrived IRQ         |  |  |
| Event-started IRQ                         | [1]             | 0x0     | RW   | 1 – Enable the event-started IRQ<br>0 – Mask the event-started IRQ       |  |  |
| Event-complete IRQ                        | [0]             | 0x0     | RW   | 1 – Enable the event-complete IRQ<br>0 – Mask the event-complete IRQ     |  |  |

# Table 32. MAC INTERRUPT STATUS

| Function                       | Bits        | Default | Туре | Description                                                                 |
|--------------------------------|-------------|---------|------|-----------------------------------------------------------------------------|
| MAC Interrupts Status Register | 0x4001_4038 | •       |      |                                                                             |
| MAC interrupt status.          |             |         |      |                                                                             |
| PAN ID conflict IRQ            | [6]         | 0x0     | RW   | 1 – PAN ID conflict IRQ occurred<br>0 – PAN ID conflict IRQ did not occur   |
| Frame-match-done IRQ           | [5]         | 0x0     | RW   | 1 – Frame-match-done IRQ occurred<br>0 – Frame-match-done IRQ did not occur |
| Failed-packet IRQ              | [4]         | 0x0     | RW   | 1 – Failed-packet IRQ occurred<br>0 – Failed-packet IRQ did not occur       |
| Frame-started IRQ              | [3]         | 0x0     | RW   | 1 – Frame-started IRQ occurred<br>0 – Frame-started IRQ did not occur       |
| Data-arrived IRQ               | [2]         | 0x0     | RW   | 1 – Data-arrived IRQ occurred<br>0 – Data-arrived IRQ did not occur         |
| Event-started IRQ              | [1]         | 0x0     | RW   | 1 – Event-started IRQ occurred<br>0 – Event-started IRQ did not occur       |
| Event-complete IRQ             | [0]         | 0x0     | RW   | 1 – Event-complete IRQ occurred<br>0 – Event-complete IRQ did not occur     |

### Table 33. MAC TIMER ENABLE

| Function                                                    | Bits | Default | Туре | Description                |  |
|-------------------------------------------------------------|------|---------|------|----------------------------|--|
| MAC Timer Enable Register: 0x4001_4040<br>Enable MAC Timer. |      |         |      |                            |  |
| Stop Timer Enable                                           | [1]  | 0x0     | RW   | 1 – Enable the stop timer  |  |
| Start Timer Enable                                          | [0]  | 0x0     | RW   | 1 – Enable the start timer |  |

#### Table 34. MAC TIMER ENABLE

| Function                                                     | Bits | Default | Туре | Description                 |  |
|--------------------------------------------------------------|------|---------|------|-----------------------------|--|
| MAC Timer Enable Register: 0x4001_4044<br>Disable MAC Timer. |      |         |      |                             |  |
| Stop Timer Enable                                            | [1]  | 0x0     | RW   | 1 – Disable the stop timer  |  |
| Start Timer Enable                                           | [0]  | 0x0     | RW   | 1 – Disable the start timer |  |

## Table 35. MAC TIMER LOAD

| Function                                                         | Bits   | Default    | Туре | Description                                                                                 |  |
|------------------------------------------------------------------|--------|------------|------|---------------------------------------------------------------------------------------------|--|
| MAC Timer Load Register: 0x4001_4048<br>Write a MAC timer value. |        |            |      |                                                                                             |  |
| MAC Timer Value                                                  | [31:0] | 0x00000000 | RW   | Load value for the MAC protocol timer. Time base is the bit clock (0x4000_4028 MAC divider) |  |

## Table 36. MAC START TIME

| Function                                                                        | Bits   | Default   | Туре | Description                                                                                                                                                                                                                      |  |
|---------------------------------------------------------------------------------|--------|-----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MAC Start Time Register: 0x4001_404C<br>Start time when using timed MAC events. |        |           |      |                                                                                                                                                                                                                                  |  |
| MAC Start Time                                                                  | [31:0] | 0x0000000 | RW   | The time an event is started when timed start is<br>used. This value is compared to the value in the pro-<br>tocol timer and offset by the higher of the Transmit<br>and Receive Warmup times (0x4000_402C MAC<br>Rx/Tx Warmups) |  |

## Table 37. MAC TIMER STATUS

| Function                                                                 | Bits | Default | Туре | Description       |  |
|--------------------------------------------------------------------------|------|---------|------|-------------------|--|
| MAC Timer Status Register: 0x4001_4054<br>Show status of the stop timer. |      |         |      |                   |  |
| Stop Timer Status                                                        | [1]  |         | RO   | 1 – On<br>0 – Off |  |
| Start Timer Status                                                       | [0]  |         | RO   | 1 – On<br>0 – Off |  |

# Table 38. MAC PROTOCOL TIMER

| Function                                                                                   | Bits   | Default | Туре | Description                                                                                                |  |
|--------------------------------------------------------------------------------------------|--------|---------|------|------------------------------------------------------------------------------------------------------------|--|
| MAC Protocol Timer Register: 0x4001_4058<br>Show the current status of the protocol timer. |        |         |      |                                                                                                            |  |
| Protocol Timer Status                                                                      | [31:0] |         | RO   | Current state of the protocol timer. The time base of the timer is the bit clock (0x4000_4028 MAC divider) |  |

## Table 39. MAC FINISH TIME

| Function                                                                                                                         | Bits | Default | Туре | Description |  |
|----------------------------------------------------------------------------------------------------------------------------------|------|---------|------|-------------|--|
| MAC Finish Time Register: 0x4001_4060<br>Returns the value of the protocol timer when the last event complete IRQ was generated. |      |         |      |             |  |
| MAC Finish Time     [31:0]     RO     Value of the protocol timer when the last event complete IRQ was generated                 |      |         |      |             |  |

#### Table 40. MAC SLOT OFFSET

| Function                              | Bits                                  | Default          | Туре         | Description                                                                                                                                                                                                                                                |  |  |  |
|---------------------------------------|---------------------------------------|------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MAC Slot Offset Register: 0x4001      | MAC Slot Offset Register: 0x4001_4064 |                  |              |                                                                                                                                                                                                                                                            |  |  |  |
| Returns the value of the protocol tir | ner when the I                        | ast event comple | te IRQ was g | enerated.                                                                                                                                                                                                                                                  |  |  |  |
| Rx Slot Offset                        | [27:16]                               | 0x007            | RW           | If the reset slot offset function is enabled $(0x4000\_4004$ MAC Sequencer Options, rstr), this value is loaded into the slot timer as the first bit of the frame length field of the packet being received. The time unit is 1 bit (4 $\mu$ s)            |  |  |  |
| Tx Slot Offset                        | [11:0]                                | 0x008            | RW           | If the reset slot offset function is enabled $(0x4000\_4004 \text{ MAC}$ Sequencer Options, rstt), this value is loaded into the slot timer as the first bit of the frame length field of the packet being transmitted. The time unit is 1 bit (4 $\mu$ s) |  |  |  |





## Table 41. MAC TIME STAMP

| Function                                                                                                                                        | Bits   | Default | Туре | Description                                                                                |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|------|--------------------------------------------------------------------------------------------|--|
| MAC Time Stamp Register: 0x4001_4068<br>Returns the value of the protocol timer when the frame length field of the received packet is received. |        |         |      |                                                                                            |  |
| MAC Time Stamp                                                                                                                                  | [31:0] |         | RO   | Value of the protocol timer when the frame length field of the received packet is received |  |

#### Table 42. MAC COORDINATOR SHORT ADDRESS

| Function                                                                                                                                                                                                                                                                                            | Bits          | Default           | Туре | Description |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------------|------|-------------|--|--|--|
| MAC Coordinator Short Address Register: 0x4001_4070                                                                                                                                                                                                                                                 |               |                   |      |             |  |  |  |
| Control and values related to the M                                                                                                                                                                                                                                                                 | AC coordinato | or short address. |      |             |  |  |  |
| If bit [30] is set, the contents of this register contain a valid short address for the PAN coordinator. If the bit is equal to 0, the address is not valid. This allows the PAN Coordinator address to have a value of 16'h0000 without it appearing that the register was not written.            |               |                   |      |             |  |  |  |
| PAN Coordinator Short Address       [31]       0x0       RW       Indicates whether the address in bits [15:0] is for the PAN coordinator.         Indicator       1 – The short address is for the PAN coordinator of the PAN coordinator.       1 – The short address is for the PAN coordinator. |               |                   |      |             |  |  |  |

## Table 42. MAC COORDINATOR SHORT ADDRESS

| Function                                  | Bits   | Default | Туре | Description                                                                                                                                                                                                                                          |
|-------------------------------------------|--------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PAN Coordinator Long Address<br>Indicator | [30]   | 0x0     | RW   | Indicates whether the long address in registers<br>0x4000_4074 and 0x4000_4078 is for the PAN coor-<br>dinator.<br>1 – The long address is for the PAN coordinator<br>0 – There is no valid long address in registers<br>0x4000_4074 and 0x4000_4078 |
| Device Associated Indicator               | [29]   | 0x0     | RW   | Indicates whether this device is an associated de-<br>vice.<br>1 – The device is associated<br>0 – The device is not associated                                                                                                                      |
| PAN Coordinator 16 bit short ad-<br>dress | [15:0] | 0x0000  | RW   | Stores the 16-bit short address of the PAN Coordi-<br>nator                                                                                                                                                                                          |

## Table 43. MAC COORDINATOR LONG ADDRESS HIGH

| Function                                                                                                                                                                                                                                                                                                                                                                                                    | Bits            | Default          | Туре | Description |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------|------|-------------|--|--|--|
| MAC Coordinator Long Address High Register: 0x4001_4074                                                                                                                                                                                                                                                                                                                                                     |                 |                  |      |             |  |  |  |
| MSW of the unique 64 bit extende                                                                                                                                                                                                                                                                                                                                                                            | d address of th | e PAN coordinato | or.  |             |  |  |  |
| If bit [30] of register 0x4000_4070 is set, the contents of this register concatenated with the contents of register 0x4000_4078 contain a valid address for the PAN coordinator. If the bit is equal to 0, the concatenated contents of the two registers are not valid. This allows the PAN Coordinator address to have a value of 64'h00000000 without it appearing that the registers were not written. |                 |                  |      |             |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                             |                 |                  |      |             |  |  |  |

#### Table 44. MAC COORDINATOR LONG ADDRESS LOW

| Function                                                                                                                    | Bits   | Default | Туре                                                                     | Description |  |  |
|-----------------------------------------------------------------------------------------------------------------------------|--------|---------|--------------------------------------------------------------------------|-------------|--|--|
| MAC Coordinator Long Address Low Register: 0x4001_4078<br>LSW of the unique 64 bit extended address of the PAN coordinator. |        |         |                                                                          |             |  |  |
| LSW PAN Coordinator Long Ad-<br>dress                                                                                       | [31:0] | RW      | Least significant word of the PAN coordinator unique 64 bit long address |             |  |  |

### Table 45. MAC RX LENGTH

| Function                                                                                                                           | Bits | Default | Туре | Description |  |  |
|------------------------------------------------------------------------------------------------------------------------------------|------|---------|------|-------------|--|--|
| MAC Rx Length Register: 0x4001_4088<br>Value is the number of bytes received by the PSDU of the MAC. This includes the PHY header. |      |         |      |             |  |  |
| Number of Received Bytes     [7:0]     0x00     RO     Number of bytes received by the PSDU of the MAC including the PHR           |      |         |      |             |  |  |

#### Table 46. MAC TX LENGTH

| Function                              | Bits        | Default          | Туре         | Description                                                           |  |  |
|---------------------------------------|-------------|------------------|--------------|-----------------------------------------------------------------------|--|--|
| MAC Tx Length Register: 0x4001_408C   |             |                  |              |                                                                       |  |  |
| Number of bytes transmitted by the    | PSDU of the | MAC including th | e PHY header | r. Number of warmup chips specified here also.                        |  |  |
| Number of Warmup Chips to<br>Transmit | [11:8]      | 0x00             | RW           | Number of chips to transmit before the start of the transmitted frame |  |  |
| Number of Transmitted Bytes           | [6:0]       | 0x00             | RW           | Number of bytes transmitted by the PSDU of the MAC including the PHR  |  |  |

## Table 47. MAC TX SEQUENCE NUMBER

| Function                                                                  | Bits  | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|---------------------------------------------------------------------------|-------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Tx Sequence Number Register: 0x4001_4090<br>Transmit sequence number. |       |         |      |                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| MAC Tx Sequence Number                                                    | [7:0] | 0x00    | RW   | MAC Tx sequence number is a unique number that<br>is a property of the transmitted packet. When an<br>ACK of the transmitted packet is expected, the se-<br>quence number should be written to this register for<br>comparison to the sequence number received in the<br>ACK frame. This register therefore contains a copy of<br>the sequence number of the transmitted frame. |  |  |

## Table 48. MAC TX ACK DELAY

| Function                                                                                                                                                                                                                                                           | Bits     | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Tx ACK Delay Register: 0x4                                                                                                                                                                                                                                     | 001_4094 |         |      |                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| When Tx auto ACK is enabled (0x4000_4004 MAC Sequencer Options), this delay defines the time from the end of a received frame to the start of an automatically transmitted ACK (including the Tx warmup time). Time is measured in bit time which is 4 µs per bit. |          |         |      |                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| MAC Tx Sequence Number                                                                                                                                                                                                                                             | [11:0]   | 0x22    | RW   | MAC Tx sequence number is a unique number that<br>is a property of the transmitted packet. When an<br>ACK of the transmitted packet is expected, the se-<br>quence number should be written to this register for<br>comparison to the sequence number received in the<br>ACK frame. This register therefore contains a copy of<br>the sequence number of the transmitted frame. |  |  |





#### Table 49. MAC RX ACK DELAY

| Function                                                                                                                                                                                                                       | Bits     | Default | Туре | Description                                                                                                                                                          |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MAC Rx ACK Delay Register: 0x4                                                                                                                                                                                                 | 001_4098 |         |      |                                                                                                                                                                      |  |
| When Rx auto restart is enabled (0x4001_0004 MAC Sequencer Options) this delay is the delay from the end of the previous receive event to the start of a new receive event. The time is measured in bit time, or 4 µs per bit. |          |         |      |                                                                                                                                                                      |  |
| Rx Auto Delay                                                                                                                                                                                                                  | [27:16]  | 0x30    | RW   | When Rx auto restart is enabled this delay is the delay from the end of the previous receive event to the start of a new event in bit time units of $4\mu$ s per bit |  |
| Rx ACK Delay                                                                                                                                                                                                                   | [11:0]   | 0x4     | RW   | The delay from the end of the transmitted frame to the start of the receiver for an ACK in bit time units of 4 $\mu s$ per bit                                       |  |



\*\*NOTE: mac\_ack\_stop (Reg. 0a4) is different depending on whether you are in slot mode or not.

| MODE     | mac_ack_stop  |
|----------|---------------|
| Slot     | rxslotted_end |
| Non-slot | rxack_end     |

Figure 7.

#### Table 50. MAC TX FLUSH

| Function                                                                                                                        | Bits | Default | Туре | Description |  |  |
|---------------------------------------------------------------------------------------------------------------------------------|------|---------|------|-------------|--|--|
| MAC Tx Flush Register: 0x4001_409C<br>How long the transmitter stays on after the frame is transmitted.                         |      |         |      |             |  |  |
| Tx Flush Time     [11:0]     0x4     RW     The time the transmitter stays on after transmitting frame in units of 4 µs per bit |      |         |      |             |  |  |

#### Table 51. MAC CCA DELAY

| Function                           | Bits           | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|------------------------------------|----------------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Tx Flush Register: 0x4001_40A0 |                |         |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Clear channel assessment (CCA) p   | parameter cont | trol.   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| CCA Duration (cca_length)          | [27:16]        | 0x03    | RW   | Time allocated for CCA or ED measurement as determined by the operation mode (0x4000_4004 MAC<br>Sequencer Options). Time is measured in units of<br>4 μs.Slotted mode – The value of CCA duration is just the<br>measurement period and does not include the<br>warmup timeNon–Slotted mode – The value of CCA duration is<br>just the measurement period and does not include<br>the warmup timeNon–Slotted mode – The value of CCA duration is<br>just the measurement period and does not include<br>the warmup timeNormal mode – The value of CCA duration includes<br>the warmup time |  |  |
| CCA Delay (cca_delay)              | [11:0]         | 0x1F    | RW   | The time between CCA measurements in a slotted system measured in units of 4 $\mu s$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |

## Table 52. MAC ACK STOP

| Function                                                                                                                                                                                                               | Bits    | Default | Туре | Description                                                                                                                                                                                                      |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MAC Tx Flush Register: 0x4001_4                                                                                                                                                                                        | 10A4    |         |      |                                                                                                                                                                                                                  |  |
| After a transmit sequence the MAC can be programmed to switch to receive mode to wait for an ACK. The timeout time is set using this register. The value depends on if slotted or non-slotted operation is being used. |         |         |      |                                                                                                                                                                                                                  |  |
| Rx Slotted Stop Time                                                                                                                                                                                                   | [27:16] | 0x170   | RW   | Time period after a transmit sequence for which the receiver remains on waiting for an ACK in a slotted system. This value must be greater than the Receive Warmup time in register 0x4000_402C.                 |  |
| Rx Non-Slotted Stop Time                                                                                                                                                                                               | [11:0]  | 0x170   | RW   | Time period after a transmit event for which the re-<br>ceiver remains on waiting for an ACK in a non-slot-<br>ted system. This value must be greater than the Re-<br>ceive Warmup time in register 0x4000_402C. |  |

## Table 53. MAC TX CCA

| Function                                                                      | Bits   | Default | Туре | Description                                                                                                                    |  |
|-------------------------------------------------------------------------------|--------|---------|------|--------------------------------------------------------------------------------------------------------------------------------|--|
| MAC Tx CCA Register: 0x4001_40A8                                              |        |         |      |                                                                                                                                |  |
| Time delay between completion of CCA and the start of the frame transmission. |        |         |      |                                                                                                                                |  |
| Transmit CCA Delay                                                            | [11:0] | 0x30    | RW   | Time from the end of a successful CCA measurement to the frame transmission start. Time measured in units of 4 $\mu s$ per bit |  |

## Table 54. MAC LONG ADDRESS POINTER

| Function                                                                                                                                                                                                 | Bits                                           | Default | Туре | Description                                                                                                                                                                                              |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Long Address Pointer Regis                                                                                                                                                                           | MAC Long Address Pointer Register: 0x4001_40A8 |         |      |                                                                                                                                                                                                          |  |  |
| Shows which addresses in the matching lookup table (LUT) contain long (64 bit) addresses. Each bit points to the corresponding location pair in the LUT. Example: 0x001 points to LUT locations 0 and 1. |                                                |         |      |                                                                                                                                                                                                          |  |  |
| Long Address Pointer                                                                                                                                                                                     | [11:0]                                         | 0x000   | RW   | Shows which addresses in the matching lookup table (LUT) contain long (64 bit) addresses. Each bit points to the corresponding location pair in the LUT. Example: 0x001 points to LUT locations 0 and 1. |  |  |

## Table 55. MAC SHORT ADDRESS POINTER

| Function                                                                                                                                                        | Bits   | Default  | Туре | Description                                                                                                                                                     |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MAC Short Address Pointer Register: 0x4001_40B0                                                                                                                 |        |          |      |                                                                                                                                                                 |  |
| Shows which addresses in the matching lookup table (LUT) contain short (32-bit) address/PAN ID pairs. Each bit points to the corresponding location in the LUT. |        |          |      |                                                                                                                                                                 |  |
| Short Address Pointer                                                                                                                                           | [23:0] | 0x000000 | RW   | Shows which addresses in the matching lookup table (LUT) contain short (32-bit) address/PAN ID pairs. Each bit points to the corresponding location in the LUT. |  |

## Table 56. MAC FRAME MATCH RESULT

| Function                                                                                    | Bits  | Default | Туре | Description                                                                                                      |  |  |
|---------------------------------------------------------------------------------------------|-------|---------|------|------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Frame Match Result Register: 0x4001_40B4<br>Result vector for frame matching operation. |       |         |      |                                                                                                                  |  |  |
| Frame Match Result – Short or<br>Long Address                                               | [5]   |         | RO   | 1 – Extended long address<br>0 – Short address                                                                   |  |  |
| Frame Match Result                                                                          | [4:0] |         | RO   | The bit index of the least significant 1 in either regis-<br>ters 0x4000_40B8 or 0x4000_40BC.<br>0x3F – No match |  |  |

## Table 57. MAC FRAME MATCH LONG ADDRESS POINTER

| Function                                                                                                                                                                                | Bits                                                       | Default | Туре | Description                                                                                                                                                                                        |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Frame Match Long Address                                                                                                                                                            | MAC Frame Match Long Address Pointer Register: 0x4001_40B8 |         |      |                                                                                                                                                                                                    |  |  |
| Returns which long addresses in the matching look up table (LUT) matched the incoming long (64 bit) source address. Each bit corresponds to the corresponding location pair in the LUT. |                                                            |         |      |                                                                                                                                                                                                    |  |  |
| Frame Match Long Address<br>Pointer                                                                                                                                                     | [11:0]                                                     |         | RO   | Returns which long addresses in the matching look<br>up table (LUT) matched the incoming long (64 bit)<br>source address. Each bit corresponds to the cor-<br>responding location pair in the LUT. |  |  |

## Table 58. MAC FRAME MATCH SHORT ADDRESS POINTER

| Function                                                                                                                                                                                                           | Bits                                                        | Default | Туре | Description                                                                                                                                                                                                                      |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                                                                                                                                                                    | MAC Frame Match Short Address Pointer Register: 0x4001_40BC |         |      |                                                                                                                                                                                                                                  |  |  |
| Returns which short PAN ID/addresses in the matching look up table (LUT) matched the incoming short (16 bit) source address and 16 bit PAN ID. Each bit corresponds to the corresponding location pair in the LUT. |                                                             |         |      |                                                                                                                                                                                                                                  |  |  |
| Frame Match Short Address<br>Pointer                                                                                                                                                                               | [11:0]                                                      |         | RO   | Returns which short PAN ID/addresses in the match-<br>ing look up table (LUT) matched the incoming short<br>(16 bit) source address and 16 bit PAN ID. Each bit<br>corresponds to the corresponding location pair in the<br>LUT. |  |  |

# Table 59. MAC AGC CONTROL

| Function                            | Bits             | Default           | Туре   | Description                                                                                                                                                                                                                     |
|-------------------------------------|------------------|-------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC AGC Control Register: 0x4       | 001_40C0         |                   |        |                                                                                                                                                                                                                                 |
| Control settings for the receiver a | utomatic gain co | ontrol (AGC) fund | ction. |                                                                                                                                                                                                                                 |
| Gain Start Value                    | [31:28]          | 0x0               | RW     | <ul> <li>1 – The AGC algorithm starts with the gain value in this register</li> <li>0 – The AGC gain setting is held at the value in this register</li> </ul>                                                                   |
| Freeze Gain After Preamble          | [2]              | 0x0               | RW     | <ul> <li>1 – Freeze AGC gain value when preamble is detected</li> <li>0 – AGC gain can be frozen if the start of frame delimiter is found</li> <li>Both options are disabled if the register Allow Freeze AGC is low</li> </ul> |
| Allow Freeze AGC                    | [1]              | 0x1               | RW     | <ul> <li>1 – Allows AGC setting to be frozen in response to a preamble detection or start of frame delimiter detection</li> <li>0 – AGC operates continuously</li> </ul>                                                        |
| Allow AGC                           | [0]              | 0x1               | RW     | 1 – AGC active<br>0 – AGC gain held at Gain Start Value above                                                                                                                                                                   |

## Table 60. MAC AGC SETTINGS

| Function                                                                                  | Bits    | Default | Туре | Description                                                                                                                    |  |
|-------------------------------------------------------------------------------------------|---------|---------|------|--------------------------------------------------------------------------------------------------------------------------------|--|
| MAC AGC Settings Register: 0x4001_40C4<br>Receiver automatic gain control (AGC) settings. |         |         |      |                                                                                                                                |  |
| AGC Low Threshold                                                                         | [31:28] | 0x1     | RW   | Value of the low AGC threshold. Gain values are<br>relative to the AGC high threshold below.<br>0x0000: -9 dB<br>0x0001: -7 dB |  |

#### Table 60. MAC AGC SETTINGS

| Function              | Bits    | Default | Туре | Description                                                                                                                                                                                  |
|-----------------------|---------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AGC High Threshold    | [27:24] | 0x2     | RW   | Value of the high AGC threshold. Gain values are<br>relative to the full scale value of the receiver path<br>ADC.<br>0x0000: 0dB<br>0x0001: -1dB<br>0x0010: -3 dB<br>0x0011: -5 dB           |
| AGC Clock Divider     | [23:16] | 0x01    | RW   | Clock divider for AGC. AGC Clock = FCLK/(divider + 1). FCLK is the MCU clock.                                                                                                                |
| AGC Measurement Delay | [15:8]  | 0x017   | RW   | The number of clock cycles over which the input sig-<br>nal is sampled for each AGC step adjustment. This<br>value is offset by 1 (a setting of 0 is actually 1)                             |
| AGC Settle Delay      | [7:0]   | 0x07    | RW   | The number of clock cycles of delay after an AGC<br>step adjustment and before the beginning of the next<br>AGC measure cycle. This value is offset by 1 (a set-<br>ting of 0 is actually 1) |

## Table 61. MAC AGC STATUS

| Function                                                       | Bits            | Default            | Туре           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------|-----------------|--------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC AGC Settings Register: 0x4                                 | 001_40C8        |                    | •              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Receiver automatic gain control (A end of ED/CCA measurements. | .GC) status reg | ister. The value o | of each regist | er is captured at the end of packet reception or at the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| AGC State                                                      | [11:8]          |                    | RO             | <ul> <li>AGC state machine state. Allowed values are 0 – 11 (decimal). A value of 0 indicates the min gain, and 11 is the max gain.</li> <li>Each state value maps to the corresponding gain registers in 0x4001_40CC and 0x4001_40D4 (MAC AGC gain tables).</li> <li>0x0 - Value specified in gain state 0 0x1 - Value specified in gain state 1 0x2 - Value specified in gain state 2 0x3 - Value specified in gain state 3 0x4 - Value specified in gain state 5 0x6 - Value specified in gain state 6 0x7 - Value specified in gain state 7 0x8 - Value specified in gain state 8 0x9 - Value specified in gain state 9 0xA - Value specified in gain state 10 0x7 - Value specified in gain state 10 0x7 - Value specified in gain state 10 0x8 - Value specified in gain state 10 0x8 - Value specified in gain state 11</li> </ul> |
| Gain of 3 <sup>rd</sup> IF Amplifier                           | [6]             |                    | RO             | 0 – 0 dB<br>1 – 18 dB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Gain of 2 <sup>nd</sup> IF Amplifier                           | [5:3]           |                    | RO             | 000 – 0 dB<br>001 – 6 dB<br>010 – 12 dB<br>011 – 18 dB<br>1xx – 24 dB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Gain of 1 <sup>st</sup> IF Amplifier                           | [2:0]           |                    | RO             | 000 – 0 dB<br>001 – 6 dB<br>010 – 12 dB<br>011 – 18 dB<br>1xx – 24 dB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## Table 62. MAC AGC GAIN TABLE 0

| Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bits                                       | Default | Туре | Description                                |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|---------|------|--------------------------------------------|--|--|--|
| MAC AGC Gain Table 0 Register:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | MAC AGC Gain Table 0 Register: 0x4001_40CC |         |      |                                            |  |  |  |
| Receiver automatic gain control (AGC) gain table 0 register. The MAC AGC control manipulates 3 variable gain stages in the IF amplifier chain in the receiver. Settings cover 12 distinct gain states. Because there are multiple gain settings of the IF amplifiers that can result in the same gain, it is necessary to define a unique set of gain settings for each state. The settings are stored in registers 0x4001_40CC, 0x4001_40D0, 0x4001_40D4, and 0x4001_40D8. Because the AGC control mechanism defines only 12 states (0 to 11), 0x4001_40D8 (states 12–15) is effectively unused. |                                            |         |      |                                            |  |  |  |
| IF Amplifier Gain Settings for<br>AGC state 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [30:24]                                    | 0x00    | RW   | IF amplifier gain settings for AGC state 0 |  |  |  |
| IF Amplifier Gain Settings for<br>AGC state 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [22:16]                                    | 0x08    | RW   | IF amplifier gain settings for AGC state 1 |  |  |  |
| IF Amplifier Gain Settings for<br>AGC state 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [14:8]                                     | 0x10    | RW   | IF amplifier gain settings for AGC state 2 |  |  |  |
| IF Amplifier Gain Settings for<br>AGC state 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [6:0]                                      | 0x40    | RW   | IF amplifier gain settings for AGC state 3 |  |  |  |

#### Table 63. MAC AGC GAIN TABLE 1

| Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bits    | Default | Туре | Description                                |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|------|--------------------------------------------|--|--|
| MAC AGC Gain Table 1 Register: 0x4001_40D0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |         |      |                                            |  |  |
| Receiver automatic gain control (AGC) gain table 1 register. The MAC AGC control manipulates 3 variable gain stages in the IF amplifier chain in the receiver. Settings cover 12 distinct gain states. Because there are multiple gain settings of the IF amplifiers that can result in the same gain, it is necessary to define a unique set of gain settings for each state. The settings are stored in registers 0x4001_40DC, 0x4001_40D0, 0x4001_40D4, and 0x4001_40D8. Because the AGC control mechanism defines only 12 states (0 to 11), 0x4001_40D8 (states 12–15) is effectively unused. |         |         |      |                                            |  |  |
| IF Amplifier Gain Settings for<br>AGC state 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [30:24] | 0x48    | RW   | IF amplifier gain settings for AGC state 4 |  |  |
| IF Amplifier Gain Settings for AGC state 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | [22:16] | 0x50    | RW   | IF amplifier gain settings for AGC state 5 |  |  |
| IF Amplifier Gain Settings for<br>AGC state 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [14:8]  | 0x58    | RW   | IF amplifier gain settings for AGC state 6 |  |  |
| IF Amplifier Gain Settings for AGC state 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | [6:0]   | 0x60    | RW   | IF amplifier gain settings for AGC state 7 |  |  |

# Table 64. MAC AGC GAIN TABLE 2

| Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bits    | Default | Туре | Description                                 |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|------|---------------------------------------------|--|--|--|
| MAC AGC Gain Table 2 Register: 0x4001_40D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |         |      |                                             |  |  |  |
| Receiver automatic gain control (AGC) gain table 2 register. The MAC AGC control manipulates 3 variable gain stages in the IF amplifier chain in the receiver. Settings cover 12 distinct gain states. Because there are multiple gain settings of the IF amplifiers that can result in the same gain, it is necessary to define a unique set of gain settings for each state. The settings are stored in registers 0x4001_40DC, 0x4001_40D0, 0x4001_40D4, and 0x4001_40D8. Because the AGC control mechanism defines only 12 states (0 to 11), 0x4001_40D8 (states 12–15) is effectively unused. |         |         |      |                                             |  |  |  |
| IF Amplifier Gain Settings for AGC state 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | [30:24] | 0x61    | RW   | IF amplifier gain settings for AGC state 8  |  |  |  |
| IF Amplifier Gain Settings for AGC state 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | [22:16] | 0x62    | RW   | IF amplifier gain settings for AGC state 9  |  |  |  |
| IF Amplifier Gain Settings for AGC state 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | [14:8]  | 0x63    | RW   | IF amplifier gain settings for AGC state 10 |  |  |  |
| IF Amplifier Gain Settings for AGC state 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | [6:0]   | 0x64    | RW   | IF amplifier gain settings for AGC state 11 |  |  |  |

## Table 65. MAC AGC GAIN TABLE 3

| Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bits    | Default | Туре | Description                                 |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|------|---------------------------------------------|--|--|--|
| MAC AGC Gain Table 3 Register: 0x4001_40D8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |         |      |                                             |  |  |  |
| Receiver automatic gain control (AGC) gain table 2 register. The MAC AGC control manipulates 3 variable gain stages in the IF amplifier chain in the receiver. Settings cover 12 distinct gain states. Because there are multiple gain settings of the IF amplifiers that can result in the same gain, it is necessary to define a unique set of gain settings for each state. The settings are stored in registers 0x4001_40CC, 0x4001_40D0, 0x4001_40D4, and 0x4001_40D8. Because the AGC control mechanism defines only 12 states (0 to 11), 0x4001_40D8 (states 12–15) is effectively unused. |         |         |      |                                             |  |  |  |
| IF Amplifier Gain Settings for AGC state 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | [30:24] | 0x00    | RW   | IF amplifier gain settings for AGC state 12 |  |  |  |
| IF Amplifier Gain Settings for AGC state 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | [22:16] | 0x00    | RW   | IF amplifier gain settings for AGC state 13 |  |  |  |
| IF Amplifier Gain Settings for AGC state 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | [14:8]  | 0x00    | RW   | IF amplifier gain settings for AGC state 13 |  |  |  |
| IF Amplifier Gain Settings for<br>AGC state 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | [6:0]   | 0x00    | RW   | IF amplifier gain settings for AGC state 14 |  |  |  |

#### Table 66. MAC DEMODULATOR CONTROL 0

| Function                                                       | Bits           | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------|----------------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC Demodulator Control 0 Reg<br>Various demodulator settings. | jister: 0x4001 | 4100    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Frequency Offset Range (dfr)                                   | [30:16]        | 0x7FFF  | RW   | <ul> <li>Selectively enables individual frequency offsets used during preamble search. Each of the 15 bits in this field correspond to 15 different frequency offsets.</li> <li>Bits set include the particular frequency offset from the search. Bits cleared exclude the particular frequency offset form the search.</li> <li>[16] – Frequency offset index 0 (-7 * 31.25 kHz)</li> <li>[30] – Frequency offset index 14 (+7 * 31.25 kHz)</li> <li>[30] – Frequency offset index 14 (+7 * 31.25 kHz)</li> <li>The default value is for all bits in the field to have value 1, resulting in a search range of +/- 7.5*31.25 kHz (+/- 94.5 ppm at 2.48 GHz). If the TX or RX is known to have high stability, or if the frequency offset is known from previous packet reception results, a smaller range of offsets can be used. The term "frequency offset" refers to the adjustment applied by the demodulator. For example, if frequency offset index 0 is enabled, the demodulator will frequency-shift the signal down by 7*31.25 kHz prior to correlation.</li> </ul> |
| RSSI and Digital Gain Control time decay constant (dtc)        | [6]            | 0x1     | RW   | <ul> <li>1 – Time constant set to 1/4<sup>th</sup> of a symbol period.<br/>This produces a faster response with slightly more variance in the RSSI calculation. Recommended for most cases.</li> <li>0 – Time constant set to one symbol period. This produces a slower response time but more stable RSSI values. Not recommended for use with antenna diversity.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Antenna Selection (as)                                         | [5]            | 0x0     | RW   | 1 – Antenna 1<br>0 – Antenna 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Antenna Selection Mode (asm)                                   | [4]            | 0x0     | RW   | 1 – Automatic antenna selection<br>0 – Manual antenna selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## Table 66. MAC DEMODULATOR CONTROL 0

| Function                         | Bits | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------|------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Preamble Mode (pm)               | [3]  | 0x0     | RW   | <ul> <li>1 – Mode 1 (low false detection) – Preamble detection is based on a span of 4 consecutive symbol periods. Each symbol period produces a time index and frequency index corresponding to the largest correlation peak. If all four symbol periods produce time/frequency index values that meet a set of similarity criteria, then preamble detection is declared. This mode enforces a more strict detection rule and therefore offers lower rate of false preamble detection at the expense of higher missed detection.</li> <li>0 – Mode 0 (high sensitivity) – Preamble detection is based on observation of a regular pattern of correlation peaks over a span of 5 consecutive symbol periods. Each symbol period produces a time index and frequency index values that meet a set of similarity criteria, then preamble detection rate by tolerating one corrupt correlation result in the span of 5 symbol periods. However, the relaxed detection rule allows a higher rate of false preamble detection us a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a higher rate of false preamble detection rule allows a</li> </ul> |
| Low IF Frequency Selection (lif) | [2]  | 0x1     | RW   | 1 – Demodulator performs up-conversion from -1.23<br>MHz to baseband<br>0 – Demodulator performs down-conversion from<br>+1.23 MHz to baseband                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Swap I/Q Data                    | [1]  | 0x0     | RW   | 1 – Swap In–Phase (I) and Quadrature (Q) compo-<br>nents<br>0 – Normal, no swapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## Table 67. MAC DEMODULATOR CONTROL 1

| Function                                        | Bits    | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|-------------------------------------------------|---------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Demodulator Control 1 Register: 0x4001_4104 |         |         |      |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Various demodulator settings.                   |         |         |      |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Demodulator Correlator<br>Threshold (dct)       | [27:24] | 0x8     | RW   | In order for preamble detection to be declared, the correlation peaks must exceed a threshold. The threshold is computed dynamically and includes a programmable scale factor:<br>1 + bit[27]/2 + bit[26]/4 + bit[25]/8 + bit[24]/16<br>The default value of 1.5 is recommended for manual-antenna selection, while a value of 1.75 is recommended for automatic antenna selection. |  |  |
| Preamble Frequency Span (dpf)                   | [19:16] | 0x1     | RW   | The similarity criteria used for preamble detection<br>includes a rule that all frequency index values must<br>occupy a span equal to or less than this value. The<br>default span of 0001 means that the difference be-<br>tween largest frequency index and smallest frequen-<br>cy index must be less than or equal to 1.                                                        |  |  |

## Table 67. MAC DEMODULATOR CONTROL 1

| Function                 | Bits   | Default | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------|--------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Preamble Time Span (dpt) | [13:8] | 0x03    | RW   | The similarity criteria used for preamble detection includes a rule that all time index values must occupy a span equal to or less than this value. The default span of 0011 means that the correlation peaks must span a range of 3Ts, where Ts is the sample period = $0.25 \mu$ s. This value is recommended for typical multipath conditions. Very long-range applications may benefit from a higher value.                                  |
| SFD Timeout (dst)        | [3:0]  | 0x8     | RW   | This value specifies the SFD search period in sym-<br>bols. After preamble detection, the demodulator be-<br>gins symbol recovery and searches for the start-of-<br>frame delimiter (SFD). If the SFD is not found within<br>the number of symbols specified, the preamble de-<br>tection flag is cleared and a new preamble search is<br>initiated. The default value of 8 symbols should be<br>sufficient for 802.15.4 compliant applications. |

## Table 68. MAC DEMODULATOR CONTROL 2

| Function                                                                         | Bits   | Default | Туре | Description                                                                                                                                                       |  |  |
|----------------------------------------------------------------------------------|--------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Demodulator Control 2 Register: 0x4001_4108<br>Various demodulator settings. |        |         |      |                                                                                                                                                                   |  |  |
| RSSI Calibration Value                                                           | [13:8] | 0x00    | RW   | Calibration constant added to the RSSI calculation.<br>The 6-bit field is treated as a signed value in two's<br>complement format with values from -32 to +31 dB. |  |  |
| RSSI Threshold                                                                   | [7:0]  | 0xFF    | RW   | Threshold value used to determine clear channel assessment (CCA) result. The channel is declared busy if RSSI > threshold.                                        |  |  |

## Table 69. MAC DEMODULATOR STATUS

| Function                                     | Bits    | Default | Туре | Description                                                                                                                                                                                                                                                                                                                    |  |  |
|----------------------------------------------|---------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MAC Demodulator Status Register: 0x4001_410C |         |         |      |                                                                                                                                                                                                                                                                                                                                |  |  |
| Demodulator status register.                 |         |         |      |                                                                                                                                                                                                                                                                                                                                |  |  |
| Baseband RSSI Component                      | [19:16] |         | RO   | Magnitude of the baseband digital signal (units are<br>relative to ADC saturation). The value is updated<br>until the AGC is frozen. The value is captured at the<br>end of packet reception or at the end of ED/CCA<br>measurements.<br>0000: below -42 dB<br>0001: -39 to -42 dB<br><br>1110: 0 to -3 dB<br>1111: above 0 dB |  |  |
| Receive Antenna                              | [12]    |         | RO   | 1 – Antenna 1<br>0 – Antenna 0                                                                                                                                                                                                                                                                                                 |  |  |

#### Table 69. MAC DEMODULATOR STATUS

| Function         | Bits   | Default | Туре | Description                                                                                                                                                                                                                                                      |
|------------------|--------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Frequency Offset | [11:8] |         | RO   | Frequency correction applied to the received packet.<br>The value is captured at the end of packet reception<br>or at the end of the ED/CCA measurements.<br>0000: -7 * 31.25 kHz<br>0001: -6 * 31.25 kHz<br><br>0111: 0 * 31.25 kHz<br><br>1110: +7 * 31.25 kHz |
| RSSI Value       | [7:0]  |         | RO   | The value is captured at the end of packet reception<br>or at the end of ED/CCA measurements and is inter-<br>preted in dBm as follows.<br>00000000: -127 dBm (or below)<br>00000001: -126 dBm<br><br>01111111: 0 dBm (or above)<br>1xxxxxxxx: Not used          |

#### **RADIO FREQUENCY (RF) CONTROL**

#### Description

Most of the RF control settings are determined by ON Semiconductor and shall not normally be changed by the user. However, there are some values that the programmer needs access to and are documented here. For determining the RF transmit and receive fractional–N PLL integer and fractional words use the following formulas:

Divider Value = 
$$\frac{RF_{carrier frequency}}{F_{crystal frequency}}$$
 (eq. 1)

Integer Byte = round (Divider Value) (eq. 2)

An example follows...

Divider Value = 
$$\frac{\text{RF}_{\text{carrier frequency}}}{\text{F}_{\text{crystal frequency}}} = \frac{2.401 \text{ GHz}}{32 \text{ MHz}} = 75.03125$$
 (eq. 7)

Typically the ON Semiconductor software will handle calculating these values, but the programmer may want to implement a CW test mode and as such will need to be able to set these values. See the test mode control section for details on how to enable CW mode.

## Table 70. REGISTERS

| Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Bits                                                                                                                                                                                                     | Default                                                                                                                                                        | Туре                                                                                                                          | Description                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RF Tx Frequency Control Registe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | er: 0x4001_90                                                                                                                                                                                            | 00                                                                                                                                                             | -                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                          |                                                                                                                                                                |                                                                                                                               | or the fractional-N frequency synthesizer used to gener-<br>n. See notes in description for how to calculate.                                                                                                                                                                                                                                                   |
| Integer divide portion of transmit<br>frequency for fractional–N PLL<br>used to generate carrier<br>frequency                                                                                                                                                                                                                                                                                                                                                                                                                 | [31:24]                                                                                                                                                                                                  | 0x0                                                                                                                                                            | R/W                                                                                                                           | See notes in description section for how to calculate                                                                                                                                                                                                                                                                                                           |
| Fractional divide portion of<br>transmit frequency for frac-<br>tional–N PLL used to generate<br>carrier frequency                                                                                                                                                                                                                                                                                                                                                                                                            | [23:0]                                                                                                                                                                                                   | 0x0                                                                                                                                                            | R/W                                                                                                                           | See notes in description section for how to calculate                                                                                                                                                                                                                                                                                                           |
| Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Bits                                                                                                                                                                                                     | Default                                                                                                                                                        | Туре                                                                                                                          | Description                                                                                                                                                                                                                                                                                                                                                     |
| RF Rx Frequency Control Registe<br>RF receive frequency control regist<br>ate the RF carrier frequency. See n<br>Integer divide portion of receive                                                                                                                                                                                                                                                                                                                                                                            | er setting the f<br>otes in descrip                                                                                                                                                                      | fractional and inte                                                                                                                                            | eger words fo<br>alculate.<br>R/W                                                                                             | r the fractional-N frequency synthesizer used to gener-                                                                                                                                                                                                                                                                                                         |
| frequency for fractional–N PLL<br>used to generate carrier fre-<br>quency                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [31:24]                                                                                                                                                                                                  | 0.00                                                                                                                                                           | П/¥¥                                                                                                                          | See notes in description section for how to calculate                                                                                                                                                                                                                                                                                                           |
| Fractional divide portion of re-<br>ceive frequency for fractional–N<br>PLL used to generate carrier fre-<br>quency                                                                                                                                                                                                                                                                                                                                                                                                           | [23:0]                                                                                                                                                                                                   | 0x0                                                                                                                                                            | R/W                                                                                                                           | See notes in description section for how to calculate                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                          |                                                                                                                                                                |                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                 |
| Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Bits                                                                                                                                                                                                     | Default                                                                                                                                                        | Туре                                                                                                                          | Description                                                                                                                                                                                                                                                                                                                                                     |
| RF Rx Control Register: 0x4001_9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | l<br>900C<br>er setting the f                                                                                                                                                                            | fractional and inte                                                                                                                                            | eger words fo                                                                                                                 | r the fractional–N frequency synthesizer used to gener-<br>0 – Normal gain mode<br>1 – High gain mode (enabled to reach datasheet<br>sensitivity limits with combined Tx/Rx match circuit,                                                                                                                                                                      |
| RF Rx Control Register: 0x4001_<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode                                                                                                                                                                                                                                                                                                                                                                                                | er setting the f<br>notes in descri                                                                                                                                                                      | fractional and interption for how to o                                                                                                                         | eger words fo<br>calculate.                                                                                                   | r the fractional–N frequency synthesizer used to gener-<br>0 – Normal gain mode<br>1 – High gain mode (enabled to reach datasheet<br>sensitivity limits with combined Tx/Rx match circuit,<br>cost is about 600uA)                                                                                                                                              |
| RF Rx Control Register: 0x4001_9<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode<br>Function                                                                                                                                                                                                                                                                                                                                                                                   | er setting the f<br>notes in descri<br>[0]<br>Bits                                                                                                                                                       | fractional and interption for how to o<br>0x0<br><b>Default</b>                                                                                                | eger words fo<br>calculate.                                                                                                   | r the fractional–N frequency synthesizer used to gener-<br>0 – Normal gain mode<br>1 – High gain mode (enabled to reach datasheet<br>sensitivity limits with combined Tx/Rx match circuit,                                                                                                                                                                      |
| RF Rx Control Register: 0x4001_<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode<br>Function<br>RF Tx Output Power Control Reg                                                                                                                                                                                                                                                                                                                                                  | er setting the f<br>notes in descri<br>[0]<br>Bits                                                                                                                                                       | fractional and interption for how to o<br>0x0<br><b>Default</b>                                                                                                | eger words fo<br>calculate.                                                                                                   | r the fractional–N frequency synthesizer used to gener-<br>0 – Normal gain mode<br>1 – High gain mode (enabled to reach datasheet<br>sensitivity limits with combined Tx/Rx match circuit,<br>cost is about 600uA)                                                                                                                                              |
| RF Rx Control Register: 0x4001_<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode<br>Function<br>RF Tx Output Power Control Reg<br>Transmitter output power control.                                                                                                                                                                                                                                                                                                             | 900C<br>er setting the f<br>notes in descri<br>[0]<br>Bits<br>ister: 0x4001                                                                                                                              | fractional and interption for how to o<br>0x0<br><b>Default</b>                                                                                                | eger words fo<br>calculate.<br>R/W<br>Type                                                                                    | r the fractional–N frequency synthesizer used to gener-<br>0 – Normal gain mode<br>1 – High gain mode (enabled to reach datasheet<br>sensitivity limits with combined Tx/Rx match circuit,<br>cost is about 600uA)                                                                                                                                              |
| RF Rx Control Register: 0x4001_9<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode<br>Function<br>RF Tx Output Power Control Reg                                                                                                                                                                                                                                                                                                                                                 | er setting the f<br>notes in descri<br>[0]<br>Bits                                                                                                                                                       | fractional and interption for how to o Ox0 Default _9010                                                                                                       | eger words fo<br>calculate.                                                                                                   | r the fractional–N frequency synthesizer used to gener-<br>0 – Normal gain mode<br>1 – High gain mode (enabled to reach datasheet<br>sensitivity limits with combined Tx/Rx match circuit,<br>cost is about 600uA)<br>Description                                                                                                                               |
| RF Rx Control Register: 0x4001_<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode<br>Function<br>RF Tx Output Power Control Reg<br>Transmitter output power control.                                                                                                                                                                                                                                                                                                             | 900C<br>er setting the f<br>notes in descri<br>[0]<br>Bits<br>ister: 0x4001                                                                                                                              | fractional and interption for how to o Ox0 Default _9010                                                                                                       | eger words fo<br>calculate.<br>R/W<br>Type                                                                                    | r the fractional–N frequency synthesizer used to gener-<br>0 – Normal gain mode<br>1 – High gain mode (enabled to reach datasheet<br>sensitivity limits with combined Tx/Rx match circuit,<br>cost is about 600uA)<br>Description<br>0x00 – Minimum transmitter power<br>                                                                                       |
| RF Rx Control Register: 0x4001_1<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode<br>Function<br>RF Tx Output Power Control Reg<br>Transmitter output power control.<br>Tx output power control<br>Function                                                                                                                                                                                                                                                                     | 900C<br>er setting the f<br>notes in descri<br>[0]<br>Bits<br>ister: 0x4001<br>[7:0]<br>Bits                                                                                                             | fractional and interption for how to o Ox0 Default _9010 0x0                                                                                                   | eger words fo<br>calculate.<br>R/W<br>Type<br>R/W                                                                             | <ul> <li>r the fractional–N frequency synthesizer used to gener-</li> <li>0 – Normal gain mode</li> <li>1 – High gain mode (enabled to reach datasheet sensitivity limits with combined Tx/Rx match circuit, cost is about 600uA)</li> <li>Description</li> <li>0x00 – Minimum transmitter power</li> <li></li> <li>0x14 – Maximum transmitter power</li> </ul> |
| RF Rx Control Register: 0x4001_9<br>RF receive frequency control regist<br>ate the RF carrier frequency. See r<br>LNA gain mode<br>Function<br>RF Tx Output Power Control Reg<br>Transmitter output power control.<br>Tx output power control<br>Tx output power control<br>Function<br>RF Tx Trim Register: 0x4001_909<br>Transmitter trim parameter. This pa<br>used for all boards of a given desig<br>This trim adjusts the capacitance or<br>parasitic capacitance from gate to o<br>may want to adjust this trim during | 900C<br>er setting the f<br>hotes in descri<br>[0]<br>Bits<br>ister: 0x4001_<br>[7:0]<br>Bits<br>4<br>rameter is boa<br>n.<br>f an internal L0<br>frain of this PA<br>RF matching tr<br>igner will adjus | fractional and interption for how to o Ox0 Default 9010 Ox0 Default ard sensitive and C tank circuit that A transistor, this v o fully optimize the RF match o | eger words fo<br>calculate.<br>R/W<br>Type<br>R/W<br>Type<br>will vary from<br>resonates th<br>alue is influer<br>the design. | <ul> <li>r the fractional–N frequency synthesizer used to gener-</li> <li>0 – Normal gain mode</li> <li>1 – High gain mode (enabled to reach datasheet sensitivity limits with combined Tx/Rx match circuit, cost is about 600uA)</li> <li>Description</li> <li>0x00 – Minimum transmitter power</li> <li></li> <li>0x14 – Maximum transmitter power</li> </ul> |

## **TEST MODE CONTROL**

#### Description

The NCS36510 contains a number of test modes that are only used by ON Semiconductor. However there are a few test modes that must be exposed to enable the engineer to design and characterize their system.

As mentioned in the DBG\_TEST\_EN section the DBG\_TEST\_EN pin must be driven high as a first prerequisite to get into test mode. The next step involves unlocking a test register and then setting the proper bits to enable and turn on the RF transmitter in CW mode.

After the test registers are unlocked there are two registers that must be set to enable a particular function. This locking and double redundant enable scheme is provided to help prevent rogue software from crashing the system.

There are two main functions that the designer may want to use in test mode: 1) The transmitter CW mode, and 2) Oscillator test mode (for clock trimming/measurement).

| Function                                                                                                         | Bits            | Default             | Туре             | Description                                                                                             |
|------------------------------------------------------------------------------------------------------------------|-----------------|---------------------|------------------|---------------------------------------------------------------------------------------------------------|
| Test Mode Unlock Register: 0x40                                                                                  | _               |                     |                  |                                                                                                         |
| If the DBG_TEST_EN in is high, ar                                                                                | nd the unlock o | ode is written to t | this register, t | then the remaining test mode registers can be written.                                                  |
| Unlock register                                                                                                  | [31:0]          | 0xA1313F21          | R/W              | Write a value of 0x5ECECODE to unlock, any other value is ignored and the test registers remain locked. |
|                                                                                                                  |                 |                     |                  | The DBG_TEST_EN pin must be high before the unlock code is written or else the unlock code is ignored.  |
| Function                                                                                                         | Bits            | Default             | Туре             | Description                                                                                             |
| Test Mode Override Enable Regist<br>If the DBG_TEST_EN in is high, ar<br>pre-enable a particular test mode       | nd the unlock o | ode is already wr   | ritten (the tes  | t mode is unlocked), then setting the bits in this register                                             |
| Receiver chain pre-enable                                                                                        | [10]            | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Frequency synthesizer power management pre-enable                                                                | [8]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Transmitter power amplifier pre-<br>enable                                                                       | [7]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Transmitter frequency synthe-<br>sizer pre-enable                                                                | [6]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Receiver frequency synthesizer pre-enable                                                                        | [5]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Pre-enable external 32.768 kHz<br>crystal oscillator                                                             | [3]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Pre-enable internal 32.768 kHz<br>oscillator                                                                     | [2]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Pre-enable external 32 MHz<br>crystal oscillator                                                                 | [1]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Pre-enable internal 32 MHz os-<br>cillator                                                                       | [0]             | 0x0                 | R/W              | 1 – Pre-enabled<br>0 – Disabled                                                                         |
| Function                                                                                                         | Bits            | Default             | Туре             | Description                                                                                             |
| Test Mode Override Values Register<br>If the DBG_TEST_EN in is high, th<br>are already set, then setting the bit | e unlock code   | is already written  |                  | de is unlocked), the corresponding override enable bits<br>le function as listed.                       |
| Receiver chain enable                                                                                            | [10]            | 0x0                 | R/W              | 1 – Enabled<br>0 – Disabled                                                                             |
| Frequency synthesizer power management enable                                                                    | [8]             | 0x0                 | R/W              | 1 – Enabled<br>0 – Disabled                                                                             |

| Function                                                                                                                                            | Bits                              | Default                              | Туре            | Description                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------|
| Transmitter power amplifier en-<br>able                                                                                                             | [7]                               | 0x0                                  | R/W             | 1 – Enabled<br>0 – Disabled                                                                                          |
| Transmitter frequency synthe-<br>sizer enable                                                                                                       | [6]                               | 0x0                                  | R/W             | 1 – Enabled<br>0 – Disabled                                                                                          |
| Receiver frequency synthesizer enable                                                                                                               | [5]                               | 0x0                                  | R/W             | 1 – Enabled<br>0 – Disabled                                                                                          |
| Enable external 32.768 kHz<br>crystal oscillator                                                                                                    | [3]                               | 0x0                                  | R/W             | 1 – Enabled<br>0 – Disabled                                                                                          |
| Enable internal 32.768 kHz os-<br>cillator                                                                                                          | [2]                               | 0x0                                  | R/W             | 1 – Enabled<br>0 – Disabled                                                                                          |
| Enable external 32 MHz crystal oscillator                                                                                                           | [1]                               | 0x0                                  | R/W             | 1 – Enabled<br>0 – Disabled                                                                                          |
| Enable internal 32 MHz oscilla-<br>tor                                                                                                              | [0]                               | 0x0                                  | R/W             | 1 – Enabled<br>0 – Disabled                                                                                          |
| Function                                                                                                                                            | Bits                              | Default                              | Туре            | Description                                                                                                          |
| Test Mode Digital Test Mux Register<br>If the DBG_TEST_EN in is high an<br>ternal signals through to DIO pads                                       | d the unlock co                   |                                      | itten (the test | mode is unlocked) then it's possible to route some in-                                                               |
| DIO[9] test signal mux                                                                                                                              | [27:24]                           | 0x0                                  | R/W             | 0011 – Internal 32.768 kHz oscillator clock                                                                          |
| DIO[8] test signal mux                                                                                                                              | [23:20]                           | 0x0                                  | R/W             | 0010 – External 32 MHz crystal oscillator clock                                                                      |
| DIO[7] test signal mux                                                                                                                              | [19:16]                           | 0x0                                  | R/W             | 0010 – Internal 32 MHz oscillator clock                                                                              |
| DIO[6] test signal mux                                                                                                                              | [15:12]                           | 0x0                                  | R/W             | 0010 – External 32.768 kHz crystal oscillator clock                                                                  |
| Function                                                                                                                                            | Bits                              | Default                              | Туре            | Description                                                                                                          |
| Test Mode DIO Re-router Register<br>If the DBG_TEST_EN in is high an<br>internal signals through to other DI<br>the original DIO despite being also | d the unlock co<br>O pads which i | ode is already wr<br>may be more cor | itten (the test | t mode is unlocked) then it's possible to re-route some<br>esting. Please note that the signal continues to come out |
| DIO[9] re-route                                                                                                                                     | [17:15]                           | 0x0                                  | R/W             | 000 - No re-route<br>001 - DIO[4]<br>010 - DIO[5]<br>011 - DIO[6]<br>100 - DIO[7]<br>101 - DIO[8]<br>110 - DIO[10]   |
| DIO[8] re-route                                                                                                                                     | [14:12]                           | 0x0                                  | R/W             | 000 - No re-route<br>001 - DIO[4]<br>010 - DIO[5]<br>011 - DIO[6]<br>100 - DIO[7]<br>101 - DIO[9]<br>110 - DIO[10]   |

| Function        | Bits   | Default | Туре | Description                                                                                                        |
|-----------------|--------|---------|------|--------------------------------------------------------------------------------------------------------------------|
| DIO[7] re-route | [11:9] | 0x0     | R/W  | 000 - No re-route<br>001 - DIO[4]<br>010 - DIO[5]<br>011 - DIO[6]<br>100 - DIO[8]<br>101 - DIO[9]<br>110 - DIO[10] |
| DIO[6] re-route | [8:6]  | 0x0     | R/W  | 000 - No re-route<br>001 - DIO[4]<br>010 - DIO[5]<br>011 - DIO[7]<br>100 - DIO[8]<br>101 - DIO[9]<br>110 - DIO[10] |

Example of how to enable CW mode

- 1. Drive DBG TEST EN pin high
- 2. Write unlock code in test mode unlock register
- 3. Write the pre-enable bits in the test mode override pre-enable register for bits 8, 7, 6, and 1. This will pre-enable the synthesizer power management unit (bit 8), pre-enable the transmitter power amplifier (bit 7), pre-enable the transmitter frequency synthesizer (bit 6), and pre-enable the external 32 MHz crystal oscillator (bit 1).
- 4. Write the enable bits in the test mode override values register for bits 8, 7, 6, and 1. This will enable the synthesizer power management unit (bit 8), enable the transmitter power amplifier (bit 7), enable the transmitter frequency synthesizer (bit 6), and enable the external 32 MHz crystal oscillator (bit 1).

The CW frequency will be 500 kHz lower than expected because the transmitter is effectively transmitting all zeros. So to compensate for this simply add 500 kHz to the frequency before calculating the integer and fractional words for the synthesizer.

To change CW mode frequencies, clear the bits in the test mode override enable register, update the integer and fractional words for the transmit synthesizer, and then set the bits in the test mode override enable register again to reactivate the transmitter in CW mode. Alternatively you can clear and set the override values register instead.

To set or change the CW frequency or the output power level, refer to the RF control register section.

# Example of how to bring out the 32 MHz crystal oscillator clock

To allow measuring the 32 MHz crystal oscillator frequency test mode access is provided. While in the test mode the normal clock trim registers mentioned elsewhere in this document are used to make adjustments. The following example is how the programmer would make the 32 MHz crystal oscillator clock signal visible outside of the NCS36510 chip.

- 1. Drive DBG\_TEST\_EN pin high
- 2. Write unlock code in test mode unlock register
- 3. Write the pre-enable bits in the test mode override pre-enable register for bit 1. This will pre-enable the external 32 MHz crystal oscillator (bit 1).
- 4. Write the enable bits in the test mode override values register for bit 1. This will enable the external 32 MHz crystal oscillator (bit 1).
- 5. Write 0x0010 to the digital test mux register to drive the clock signal to DIO[8]
- 6. If desired, the clock signal can also be made available on other pins by using the DIO re-router documented above

Note that the same procedure with appropriate modifications can be used to pin out the other three oscillator signals including the internal 32.768 kHz, internal 32 MHz, and the external 32.768 kHz clocks.

# POWER MANAGEMENT

# Power Modes

There are four operational modes with varying power consumption. These modes can be used by application software to minimize power consumption of both dynamic and static power. Reduced functionality and retention occurs with each consecutive level of lower power mode selected.

NCS36510 will default to the highest power mode (run mode) upon startup. The lower power modes are all entered through software (WFI/WFE) commands. The software needs to configure which mode will be entered upon these commands. See Power Management Unit section.

# Run Mode

In Run mode all digital systems are powered and running including external and/or internal oscillators. The processor is executing code. Various options exist to reduce power within this mode. Individual peripheral clocks can be gated based on configuration. You can also reduce the clock frequency of the system clock for power reduction. See the clock control section.

# Sleep Mode

In Sleep Mode the processor clock (HCLK) is gated and no code is executing. The FLASH and RAMs are still powered. The processor waits for an interrupt from either the WIC or the NVIC. Once the interrupt is received, the processor goes back to Run Mode and code execution starts from the last known location.

# Deep Sleep Mode

Deep Sleep Mode is the same as Sleep Mode except the FLASH is also powered down.

## Coma Mode

In Coma Mode almost the entire digital system is powered down. Both the internal and external 32 MHz oscillators are powered down and the system is clocked by the 32.768 kHz derivative (either internal or external). All the Cortex–M3, peripheral, and trim registers will retain their values in Coma Mode. To get out of Coma Mode, the system waits for an interrupt from the WIC which can come from MAC symbol clock timer, the RTC, or a DIO. After an interrupt occurs the system will go to Run Mode and code execution will restart at the last known location before the Coma Mode was entered.

| Power Mode | Digital | FLASH | Retention RAM A | Retention RAM B | 32 MHz Clock |
|------------|---------|-------|-----------------|-----------------|--------------|
| Run        | ON      | ON    | ON              | ON              | ON           |
| Sleep      | ON      | ON    | ON              | ON              | ON           |
| Deep Sleep | ON      | OFF   | ON              | ON              | ON           |
| Coma       | OFF     | OFF   | Programmable    | Programmable    | OFF          |

# Table 72. POWER MODE TABLE

# Power Management Unit (PMU)

Description

NCS36510 has an advanced PMU supporting two voltage supply modes: 3 V and 1 V, and four operating modes: Run, Sleep, Deep Sleep, and Coma.

# Pre-Regulator

In 3 V mode the V3V voltage is pre – regulated to a voltage of about 1.1 V. The default voltage regulator is the linear regulator. The application software is responsible for controlling the switching regulator, including monitoring the V3V voltage with the internal voltage sensor. The switching regulator is only allowed if V3V > 2.6 V.

In 1 V mode, the pre – regulator is disabled. Connecting the V3V and V1VO/I pins to 1 V will automatically generate an internal logic signal and the system will be configured in 1 V mode.

Application diagrams of 1 V and 3 V modes are provided in the NCS36510 datasheet.

The internal voltage sensor can be used to monitor the power supply voltage. Another resource that can be used is the Under Voltage Indicator (UVI). In 3 V mode, this information can be used to decide to use the switching or the linear regulator as this decision is not automatic in hardware.

# Under Voltage Indicator (UVI)

The under-voltage indicator tests for the condition where either the V1V switching regulator (3V mode) or the FVDDH switching regulator (1V mode) cannot supply sufficient current to support its load. It operates by counting over a 1 us interval the number of cycles of the 32 MHz system clock for which the comparator output in the selected regulator circuit is high (indicating a low instantaneous voltage). If the count exceeds the programmed threshold value, a low–voltage indicator is generated.

The low–voltage indicator is updated at 1 us intervals. The recommended threshold setting is 25 (decimal).

# System of linear regulators

The pre-regulator voltage (V1V) is the input voltage (V1VI) for an array of internal linear regulators that are automatically enabled and disabled in the appropriate modes to minimize power consumption. These internal regulators supply the internal analog and digital blocks.

# Embedded flash power supplies

To support the embedded FLASH two internal power supplies are implemented. One is the FVDDH, which is 1.8 V, and the other is FVDDL, which is 1.2 V.

In 3 V mode, the FVDDH is generated by a linear regulator powered by V3V.

In 1 V mode, a voltage multiplier is used to boost the V3V input voltage to the required level. The FVDDH voltage is split into two pins, FVDDHO (FVDDH Output), and FVDDHI (FVDDHI Input). Between these pins a power supply filter must be put on the application board to suppress the voltage multiplier noise. Throughout this document this voltage may be referred to as simply FVDDH. The user has the responsibility to filter this voltage as specified to obtain the published performance specifications.

| Function                                                              | Bits | Default             | Туре        | Description                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------|------|---------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PMU Control Register: 0x4001_D<br>Control register for the Power Mana |      | (PMU).              |             |                                                                                                                                                                                                                                                                  |
| UVI reset                                                             | [11] | 0x1                 | R/W         | 0 – Not reset<br>1 – Reset                                                                                                                                                                                                                                       |
|                                                                       |      |                     |             | Synchronous reset that should be applied after the UVI circuit is enabled and before the UVI results are used in the system                                                                                                                                      |
| UVI input                                                             | [10] | 0x0                 | R/W         | 0 – V1V supply<br>1 – FVDDH supply                                                                                                                                                                                                                               |
| UVI control                                                           | [9]  | 0x0                 | R/W         | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                      |
| PMU behavior while debugging                                          | [8]  | 0x0                 | R/W         | 0 – Normal power behavior when debugging<br>1 – When debugger connected, NCS36510 can only<br>enter Deep Sleep mode and FLASH always remains<br>powered up. And the 32 MHz oscillator derivative<br>cannot be powered down.                                      |
| V1V regulator selection – run,<br>sleep, or deep sleep modes          | [7]  | 0x0                 | R/W         | 0 – Linear regulator (LDO)<br>1 – Switching regulator                                                                                                                                                                                                            |
| V1V regulator in coma mode                                            | [6]  | 0x0                 | R/W         | 0 – Linear regulator (LDO)<br>1 – Switching regulator                                                                                                                                                                                                            |
| Internal 32 MHz oscillator dis-<br>able                               | [5]  | 0x0                 | R/W         | 0 – Enabled<br>1 – Disabled                                                                                                                                                                                                                                      |
|                                                                       |      |                     |             | This bit will automatically get cleared when exiting<br>Coma, or Deep Sleep modes of operation. This bit<br>should be set by software after switching over to the<br>external 32 MHz oscillator using the Oscillator Selec<br>bit in the Clock Control register. |
| Internal 32.768 kHz oscillator<br>disable                             | [4]  | 0x0                 | R/W         | 0 – Enabled<br>1 – Disabled                                                                                                                                                                                                                                      |
|                                                                       |      |                     |             | Hardware guarantees that this oscillator <u>cannot</u> be powered down if the external 32.768 kHz external crystal oscillator is already powered down.                                                                                                           |
| External 32.768 kHz crystal os-<br>cillator disable                   | [3]  | 0x1                 | R/W         | 0 – Enabled<br>1 – Disabled                                                                                                                                                                                                                                      |
|                                                                       |      |                     |             | Hardware guarantees that this oscillator <u>cannot</u> be powered down if the internal 32.768 kHz oscillator is already powered down.                                                                                                                            |
| RAM B coma mode retention enable                                      | [2]  | 0x1                 | R/W         | 0 – Retention in coma mode enabled<br>1 – No retention in coma mode                                                                                                                                                                                              |
| RAM A coma mode retention enable                                      | [1]  | 0x1                 | R/W         | 0 – Retention in coma mode enabled<br>1 – No retention in coma mode                                                                                                                                                                                              |
| Power mode to go to after WFI instruction                             | [0]  | 0x0                 | R/W         | 0 – Sleep or Deep Sleep Mode depending on system<br>control register<br>1 – Coma Mode                                                                                                                                                                            |
| Function                                                              | Bits | Default             | Туре        | Description                                                                                                                                                                                                                                                      |
| PMU Status Register: 0x4001_D0<br>PMU status register, contains the L |      | vell as the battery | detect bit. |                                                                                                                                                                                                                                                                  |
| UVI result                                                            | [1]  | 0x0                 | RO          | 0 – Battery can support current power consumption<br>1 – Battery cannot support current power consump-<br>tion                                                                                                                                                   |
| Voltage mode detect (battery de-<br>tect)                             | [0]  | 0x0                 | RO          | 0 – 1V mode/battery detected<br>1 – 3V mode/battery detected                                                                                                                                                                                                     |

| Function                                | Bits           | Default           | Туре        | Description                                                                                                                                                                                                                                            |  |  |
|-----------------------------------------|----------------|-------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Function                                | Bits           | Default           | Туре        | Description                                                                                                                                                                                                                                            |  |  |
| PMU UVI Time Base Register: 0x4001_D018 |                |                   |             |                                                                                                                                                                                                                                                        |  |  |
| Time base and threshold for UVI cir     | cuit. A thresh | old of decimal 25 | is recommer | nded.                                                                                                                                                                                                                                                  |  |  |
| UVI value                               | [13:8]         | 0x0               | RO          | Number of cycles over the previous 1 us interval<br>where the UVI comparator was high, indicating a low<br>voltage. This value is updated every 1 us.                                                                                                  |  |  |
| UVI threshold                           | [5:0]          | 0x0               | R/W         | Threshold value is compared to the UVI value to de-<br>termine if an overvoltage condition exists. If the UVI<br>value is greater than or equal to the threshold, then<br>an under voltage condition exists. The recommended<br>setting is decimal 25. |  |  |

# **EXTERNAL COMMUNICATION INTERFACES**

# Universal Asynchronous Receiver Transmitter (UART1 and UART2)

Description

NCS36510 implements two UART devices, UART 1 and UART 2.

UART 1 is a complete implementation of a 16550 UART. By configuring the crossbar UART1 can be set up as a complete 16550 UART, with all control wires.

UART 2 is a reduced functionality version of UART1. Specifically the crossbar can be setup to support transmit and receive along with clear to send and request to send. UART 1 can also be configured the same way if desired.

The UART baud rate generator produces timing strobes at the baud rate (for the transmitter) and at 16 times the selected baud rate (for the receiver). The receiver examines the incoming data and uses the first edge of the start bit to determine the bit timing. Bits can be received with up to half a bit time error and still be captured properly. Transmit and receive paths can be configured to use a single register for data or to use FIFOs.

The UART 1 and UART 2 FIFO buffers are 16 by 8 bits.

Interrupts are identified by an interrupt pending flag with more detailed interrupt status registers that can be read. The statuses include (in descending priority order): receiver line status, received data available, character timeout, transmitter holding register empty, and modem status.

### **Baud rate generation**

The baud rate generator can be configured to generate a wide range of baud rates, depending on the system clock frequency and the divisor latch. The divisor latch and the system clock frequency are related to the baud rate by the following expression:

For example, to configure the UART for a baud rate of 9600 with a system clock frequency of 32 MHz, the Divisor Latch would need to be decimal 208 (0x00D0), so the most significant byte of the divisor latch would be programmed 0x00 and the least significant byte of the divisor latch would be programmed 0xD0. To access the divisor latch, the Divisor Latch Access Bit (DLAB) must be set in the LCR.

The divisor latch can be programmed values ranging 0x0001 to 0xFFFF.

The receiver samples data at 16 times the baud rate.

| Function                                                                                              | Bits  | Default | Туре | Description                                           |
|-------------------------------------------------------------------------------------------------------|-------|---------|------|-------------------------------------------------------|
| UART 1 Data Buffer Register: 0x4<br>UART 2 Data Buffer Register: 0x4<br>Data buffer for UART.         | -     |         |      |                                                       |
| Receive/Transmit buffer                                                                               | [7:0] | 0x0     | R/W  | Read for received data<br>Write for transmitting data |
| Function                                                                                              | Bits  | Default | Туре | Description                                           |
| UART 1 Interrupt Enable Register<br>UART 2 Interrupt Enable Register<br>UART interrupt configuration. | -     |         |      |                                                       |
| Power down interrupt                                                                                  | [5]   | 0x0     | R/W  | 1 – Interrupt enabled<br>0 – Interrupt disabled       |
| Modem status interrupt                                                                                | [3]   | 0x0     | R/W  | 1 – Interrupt enabled<br>0 – Interrupt disabled       |

|                                                                                                                                                                                                                  | Bits                                                                                                                        | Default                                           | Туре                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Receiver line status interrupt                                                                                                                                                                                   | [2]                                                                                                                         | 0x0                                               | R/W                                 | 1 – Interrupt enabled<br>0 – Interrupt disabled                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Transmitter holding interrupt                                                                                                                                                                                    | [1]                                                                                                                         | 0x0                                               | R/W                                 | 1 – Interrupt enabled<br>0 – Interrupt disabled                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Received data interrupt                                                                                                                                                                                          | [0]                                                                                                                         | 0x0                                               | R/W                                 | 1 – Interrupt enabled<br>0 – Interrupt disabled                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Function                                                                                                                                                                                                         | Bits                                                                                                                        | Default                                           | Туре                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| UART 1 Interrupt Identification<br>UART 2 Interrupt Identification<br>Dual purpose register. When rea<br>control.                                                                                                | and FIFO Cont                                                                                                               | rol Register: 0x4                                 | _<br>4001_8008                      | and FIFO enabled status. When written allows FIFO                                                                                                                                                                                                                                                                                                                                                                                                                      |
| FIFOs                                                                                                                                                                                                            | [7:6]                                                                                                                       | 0x0                                               | RO                                  | 00 – FIFOs disabled<br>11 – FIFOs enabled                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Interrupt identification                                                                                                                                                                                         | [3:1]                                                                                                                       | 0x0                                               | RO                                  | 011 – Receive line status (highest priority)<br>010 – Receive data available (2 <sup>nd</sup> priority)<br>110 – Character timeout (2 <sup>nd</sup> priority)<br>001 – Transmitter holding register empty (3 <sup>rd</sup> priority)<br>000 – Modem status (4 <sup>th</sup> priority)                                                                                                                                                                                  |
| Interrupt pending                                                                                                                                                                                                | [0]                                                                                                                         | 0x0                                               | RO                                  | 1 – Interrupt pending<br>0 – No interrupt pending                                                                                                                                                                                                                                                                                                                                                                                                                      |
| FIFO trigger level                                                                                                                                                                                               | [7:6]                                                                                                                       | n/a                                               | WO                                  | 00 – 1 byte<br>01 – 4 bytes<br>10 – 8 bytes<br>11 – 14 bytes                                                                                                                                                                                                                                                                                                                                                                                                           |
| Reset transmit FIFO                                                                                                                                                                                              | [2]                                                                                                                         | n/a                                               | WO                                  | Writing a 1 triggers a one cycle reset pulse                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Reset receive FIFO                                                                                                                                                                                               | [1]                                                                                                                         | n/a                                               | WO                                  | Writing a 1 triggers a one cycle reset pulse                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                  |                                                                                                                             |                                                   |                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| FIFO enable                                                                                                                                                                                                      | [0]                                                                                                                         | n/a                                               | WO                                  | 1 – FIFO enabled<br>0 – FIFO disabled                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Function                                                                                                                                                                                                         | Bits                                                                                                                        | n/a<br>Default                                    | WO<br>Type                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                  | Bits<br>0x4001_500C<br>0x4001_800C                                                                                          | Default                                           | Туре                                | 0 – FIFO disabled Description 1 – Enable access to the divisor latch register at ad-                                                                                                                                                                                                                                                                                                                                                                                   |
| Function<br>UART 1 Line Control Register:<br>UART 2 Line Control Register:<br>Control register to manage diviso                                                                                                  | Bits<br>0x4001_500C<br>0x4001_800C<br>or latch, parity, st                                                                  | Default                                           | Type                                | 0 – FIFO disabled Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Function<br>UART 1 Line Control Register:<br>UART 2 Line Control Register:<br>Control register to manage diviso                                                                                                  | Bits<br>0x4001_500C<br>0x4001_800C<br>or latch, parity, st                                                                  | Default                                           | Type                                | 0 – FIFO disabled<br>Description<br>1 – Enable access to the divisor latch register at ad-<br>dress 0x4400_0000<br>0 – Return register access to transmit and receive                                                                                                                                                                                                                                                                                                  |
| Function<br>UART 1 Line Control Register:<br>UART 2 Line Control Register:<br>Control register to manage diviso<br>Address pointer type select                                                                   | Bits<br>0x4001_500C<br>0x4001_800C<br>or latch, parity, st<br>[7]                                                           | Default<br>op bits, characte<br>0x0               | r length, etc.                      | 0 – FIFO disabled<br>Description<br>1 – Enable access to the divisor latch register at ad-<br>dress 0x4400_0000<br>0 – Return register access to transmit and receive<br>buffers at address 0x4400_0000<br>1 – Force SOUT line to 0                                                                                                                                                                                                                                    |
| Function<br>UART 1 Line Control Register:<br>UART 2 Line Control Register:<br>Control register to manage diviso<br>Address pointer type select<br>SOUT force low                                                 | Bits           0x4001_500C           0x4001_800C           or latch, parity, st           [7]           [6]                 | Default<br>op bits, characte<br>0x0<br>0x0        | r length, etc.<br>R/W<br>R/W        | 0 – FIFO disabled<br>Description<br>1 – Enable access to the divisor latch register at ad-<br>dress 0x4400_0000<br>0 – Return register access to transmit and receive<br>buffers at address 0x4400_0000<br>1 – Force SOUT line to 0<br>0 – Normal operation<br>xx0 – Parity disabled<br>001 – Odd parity<br>011 – Even parity<br>101 – Stick parity, checked as 1                                                                                                      |
| Function         UART 1 Line Control Register:         UART 2 Line Control Register:         Control register to manage diviso         Address pointer type select         SOUT force low         Parity control | Bits           0x4001_500C           0x4001_800C           or latch, parity, st           [7]           [6]           [5:3] | Default<br>op bits, characte<br>0x0<br>0x0<br>0x0 | r length, etc.<br>R/W<br>R/W<br>R/W | 0 - FIFO disabled         Description         1 - Enable access to the divisor latch register at address 0x4400_0000         0 - Return register access to transmit and receive buffers at address 0x4400_0000         1 - Force SOUT line to 0         0 - Normal operation         xx0 - Parity disabled         001 - Odd parity         011 - Even parity         101 - Stick parity, checked as 1         111 - Stick parity, checked as 0         0 - 1 stop bit |

| Function                                                                                      | Bits | Default | Туре | Description                                                                          |
|-----------------------------------------------------------------------------------------------|------|---------|------|--------------------------------------------------------------------------------------|
| Power down                                                                                    | [7]  | 0x0     | R/W  | 1 – Enable power down<br>0 – Disable power down                                      |
| Loopback mode                                                                                 | [4]  | 0x0     | R/W  | 1 – Loopback mode selected<br>0 – Normal mode                                        |
| Request to send – RTS                                                                         | [1]  | 0x0     | R/W  | 1 – RTSn = 0<br>0 – RTSn = 1                                                         |
| Data terminal ready – DTR                                                                     | [0]  | 0x0     | R/W  | 1 – DTRn = 0<br>0 – DTRn = 1                                                         |
| Function                                                                                      | Bits | Default | Туре | Description                                                                          |
| UART 1 Line Status Register: 0x4<br>UART 2 Line Status Register: 0x4<br>Line status register. | -    |         |      |                                                                                      |
| Receive FIFO error                                                                            | [7]  | 0x0     | RO   | 1 – Receive FIFO error<br>0 – No error                                               |
| Transmitter empty                                                                             | [6]  | 0x0     | RO   | 1 – Transmitter empty<br>0 – Transmitter not empty                                   |
| Transmitter holding register empty                                                            | [5]  | 0x0     | RO   | 1 – Transmitter holding register empty<br>0 – Transmitter holding register not empty |
| Break interrupt                                                                               | [4]  | 0x0     | RO   | 1 – Break interrupt<br>0 – No break interrupt                                        |
| Framing error                                                                                 | [3]  | 0x0     | RO   | 1 – Framing error<br>0 – No framing error                                            |
| Parity error                                                                                  | [2]  | 0x0     | RO   | 1 – Parity error<br>0 – No parity error                                              |
| Overrun error                                                                                 | [1]  | 0x0     | RO   | 1 – Overrun error<br>0 – No overrun error                                            |
| Received data ready                                                                           | [0]  | 0x0     | RO   | 1 – Received data ready<br>0 – No received data                                      |
| Function                                                                                      | Bits | Default | Туре | Description                                                                          |
| UART 1 Modem Status Register:<br>UART 2 Modem Status Register:<br>Modem status register.      | _    |         |      |                                                                                      |
| DCDn input state                                                                              | [7]  | 0x0     | RO   | 1 – High<br>0 – Low                                                                  |
| RIn input state                                                                               | [6]  | 0x0     | RO   | 1 – High<br>0 – Low                                                                  |
| DSRn input state                                                                              | [5]  | 0x0     | RO   | 1 – High<br>0 – Low                                                                  |
| CTSn input state                                                                              | [4]  | 0x0     | RO   | 1 – High<br>0 – Low                                                                  |
| DCDn has changed since last read of the status register                                       | [3]  | 0x0     | RO   | 1 – Yes<br>0 – No                                                                    |
| RIn has changed since last read of the status register                                        | [2]  | 0x0     | RO   | 1 – Yes<br>0 – No                                                                    |
| DSRn has changed since last read of status register                                           | [1]  | 0x0     | RO   | 1 – Yes<br>0 – No                                                                    |
| CTSn has changed since last read of status register                                           | [0]  | 0x0     | RO   | 1 – Yes<br>0 – No                                                                    |
| Function                                                                                      | Bits | Default | Туре | Description                                                                          |

| Function                                                | Bits         | Default | Туре | Description                                                           |
|---------------------------------------------------------|--------------|---------|------|-----------------------------------------------------------------------|
| UART 1 Scratch Register: 0x4001                         | _501C        |         |      | •                                                                     |
| UART 2 Scratch Register: 0x4001                         | _801C        |         |      |                                                                       |
| Modem scratch register.                                 |              |         |      |                                                                       |
| Scratch register for temporary data                     | [7:0]        | 0x0     | R/W  |                                                                       |
| Function                                                | Bits         | Default | Туре | Description                                                           |
| LSB for baud rate generator.<br>Divisor latch value LSB |              |         |      | 8 bit value used to generate baud rate, 0x0001 to<br>0xFFFF are valid |
| Function                                                | Bits         | Default | Туре | Description                                                           |
| UART 1 Divisor Latch MSB Regis                          | ter: 0x4001_ | 5024    |      | •                                                                     |
| UART 2 Divisor Latch MSB Regis                          | ter: 0x4001_ | 8024    |      |                                                                       |
| MSB for baud rate generator.                            |              |         |      |                                                                       |
| Divisor latch value MSB                                 |              |         |      | 8 bit value used to generate baud rate, 0x0001 to 0xFFFF are valid    |

# Master/Slave SPI Controller (SPI)

Description

NCS36510 implements two SPI Bus controllers, SPI1 and SPI2. SPI1 supports up to 4 slave selects. SPI2 supports 1.

The SPI bus controller can be configured under software control to be a master or slave device. The data is transmitted synchronously with the MOSI relative to the SCLK generated by the master device. The master also receives data on the MISO signal in a full duplex fashion. When the core is configured as a slave, the MISO signal is tri – stated to allow for multiple slaves to transmit data to the master when the slave's slave select control is enabled.

The SPI can operate in 8, 16, or 32 bit mode. The SPI FIFO is  $16 \times 32$  bits.

SCLK is a divided version of the APB clock based on the MCU HCLK. The divider is programmable from 0x00 to 0xFF. The resulting SPI master clock is given by:

$$SCLK_{frequency} = \frac{PCLK_{frequency}}{2 \cdot (divider \ value \ + \ 1)}$$
(eq. 10)

In slave mode, the SPI master clock divider can only be as low as a factor of 8 due to several clock cycles of delay in internal clock domain crossing synchronizers.

Interrupts are generated for the following conditions: receive (RX) FIFO full, RX FIFO half full, RX FIFO not empty, transmit (TX) FIFO not full, TX FIFO half empty, TX FIFO empty, transfer error, and slave select synchronized to

APB clock.

SPI2 implements one slave select and is selected by the 0 bit in the slave select register.

| SPI 1 Transmit Data Register: 0x4001_6                                                    | 000      |          |             |
|-------------------------------------------------------------------------------------------|----------|----------|-------------|
| SPI 2 Transmit Data Register: 0x4001_9                                                    |          |          |             |
| Transmit data buffer.                                                                     |          |          |             |
| SPI transmit data buffer, pad [3:<br>with leading zeros if using 8 or<br>16 bit transfers | 1:0] Ox( | 0 WO     |             |
| Function B                                                                                | its Defa | ult Type | Description |

| Function                                                                                        | Bits   | Default | Туре | Description                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------|--------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI receive data buffer, padded<br>with leading zeros if using 8 or<br>16 bit transfers         | [31:0] | 0x0     | RO   |                                                                                                                                                                                                 |
| Function                                                                                        | Bits   | Default | Туре | Description                                                                                                                                                                                     |
| SPI 1 SCLK Divider Value Registe<br>SPI 2 SCLK Divider Value Registe<br>Divider value for SCLK. |        |         |      |                                                                                                                                                                                                 |
| SCLK divider value                                                                              | [7:0]  | 0x0     | R/W  | 0x00 to 0xFF                                                                                                                                                                                    |
| Function                                                                                        | Bits   | Default | Туре | Description                                                                                                                                                                                     |
| SPI 1 Control Register: 0x4001_6<br>SPI 2 Control Register: 0x4001_9<br>SPI control register.   |        |         |      |                                                                                                                                                                                                 |
| SPI transaction word length                                                                     | [7:6]  | 0x00    | R/W  | 00 – 8 bits<br>01 – 16 bits<br>10 – 32 bits                                                                                                                                                     |
| SPI master mode enable                                                                          | [5]    | 0x0     | R/W  | 0 – Slave mode<br>1 – Master mode                                                                                                                                                               |
| CPOL – SCLK polarity                                                                            | [4]    | 0x0     | R/W  | 0 – SCLK low when idle (active high)<br>1 – SCLK high when idle (active low)                                                                                                                    |
| CPHA – SCLK phase                                                                               | [3]    | 0x0     | R/W  | 0 – First transmit occurs before first edge of SCLK<br>1 – First transmit is on the first edge of SCLK                                                                                          |
| Word endianness                                                                                 | [2]    | 0x0     | R/W  | 0 – Little endian (LSB first)<br>1 – Big endian (MSB first)                                                                                                                                     |
| Direction of SCLK for data sam-<br>pling                                                        | [1]    | 0x0     | R/W  | <ul> <li>0 – Sample incoming data on opposite edge of SCLk from when outgoing data is driven</li> <li>1 – Sample incoming data on the same edge of SCLK when outgoing data is driven</li> </ul> |
| SPI enable                                                                                      | [0]    | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                                                                                                     |
| Function                                                                                        | Bits   | Default | Туре | Description                                                                                                                                                                                     |
| SPI 1 Status Register: 0x4001_60<br>SPI 2 Status Register: 0x4001_90<br>SPI status register.    |        |         |      |                                                                                                                                                                                                 |
| Receive FIFO full                                                                               | [7]    | 0x0     | RO   | 0 – Not full<br>1 – Full                                                                                                                                                                        |
| Receive FIFO watermark full                                                                     | [6]    | 0x0     | RO   | 0 – Watermark not yet reached<br>1 – Watermark reached                                                                                                                                          |
| Receive FIFO empty                                                                              | [5]    | 0x0     | RO   | 0 – Not empty<br>1 – Empty                                                                                                                                                                      |
| Transmit FIFO full                                                                              | [4]    | 0x0     | RO   | 0 – Not full<br>1 – Full                                                                                                                                                                        |
| Transmit FIFO watermark full                                                                    | [3]    | 0x0     | RO   | 0 – Watermark not yet reached<br>1 – Watermark reached                                                                                                                                          |
| Transmit FIFO empty                                                                             | [2]    | 0x0     | RO   | 0 – Not empty<br>1 – Empty                                                                                                                                                                      |
| Transfer error                                                                                  | [1]    | 0x0     | RO   | 0 – No error<br>1 – Error                                                                                                                                                                       |
| Transfer in progress                                                                            | [0]    | 0x0     | RO   | 0 – No transfer in progress                                                                                                                                                                     |

| Function                                                                                                          | Bits                     | Default | Туре | Description                                                                                                               |
|-------------------------------------------------------------------------------------------------------------------|--------------------------|---------|------|---------------------------------------------------------------------------------------------------------------------------|
| SPI 1 Slave Select Register: 0x40<br>SPI 2 Slave Select Register: 0x40                                            | 01_6014<br>01_9014       |         |      |                                                                                                                           |
| SPI slave select control register.                                                                                |                          | •       | 1    | 1                                                                                                                         |
| Burst mode                                                                                                        | [4]                      | 0x0     | R/W  | 0 – Normal behavior<br>1 – Maintain SSN active between transfers as long<br>as transmit FIFO is not empty                 |
| Slave select signals                                                                                              | [3:0]                    | 0x00    | R/W  | 1000 – SSN[3]<br>0100 – SSN[2]<br>0010 – SSN[1]<br>0001 – SSN[0]                                                          |
| Function                                                                                                          | Bits                     | Default | Туре | Description                                                                                                               |
| SPI 1 Slave Select Polarity Regis<br>SPI 2 Slave Select Polarity Regist                                           | er: 0x4001_9             |         |      |                                                                                                                           |
| SPI slave select polarity control reg                                                                             | ister.                   |         |      |                                                                                                                           |
| Polarity control of SSN, bit<br>aligned with slave select in slave<br>select register [3:0]                       | [3:0]                    | 0x00    | R/W  | In <b>master</b> mode<br>0 – Slave select active low<br>1 – Slave select active high                                      |
|                                                                                                                   |                          |         |      | In <b>slave</b> mode<br>0 – SSN is interpreted as an active low signal<br>1 – SSN is interpreted as an active high signal |
| Function                                                                                                          | Bits                     | Default | Туре | Description                                                                                                               |
| SPI 1 Interrupt Enable Register: 0<br>SPI 2 Interrupt Enable Register: 0<br>SPI interrupt configuration register. | x4001_901C               |         |      | 0 Dischlad                                                                                                                |
| Enable receive FIFO full inter-<br>rupt                                                                           | [7]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Enable receive FIFO watermark<br>hit interrupt                                                                    | [6]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Enable receive FIFO empty in-<br>terrupt                                                                          | [5]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Enable transmit FIFO full inter-<br>rupt                                                                          | [4]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Enable transmit FIFO watermark<br>hit interrupt                                                                   | [3]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Enable transmit FIFO empty in-<br>terrupt                                                                         | [2]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Enable transfer error interrupt                                                                                   | [1]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Enable slave select conditionally<br>inverted and synchronized to<br>PCLK interrupt                               | [0]                      | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                               |
| Function                                                                                                          | Bits                     | Default | Туре | Description                                                                                                               |
| SPI 1 Interrupt Status Register: 0<br>SPI 2 Interrupt Status Register: 0                                          | x4001_6020<br>x4001_9020 |         |      |                                                                                                                           |
| SPI interrupt status register.                                                                                    |                          |         |      |                                                                                                                           |
| Receive FIFO full interrupt                                                                                       | [7]                      | 0x0     | RO   | 0 – No interrupt<br>1 – Interrupt active                                                                                  |
| Receive FIFO watermark hit in-<br>terrupt                                                                         | [6]                      | 0x0     | RO   | 0 – No interrupt<br>1 – Interrupt active                                                                                  |

| Description |
|-------------|
| ve          |
| Description |
|             |
|             |
|             |
|             |
|             |
|             |
|             |
|             |
|             |
| Description |
|             |
|             |
| Description |
|             |
|             |
| Description |
|             |

| Function                                                                                                                                                  | Bits  | Default | Туре | Description |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|------|-------------|--|--|
| Transmit FIFO fill value                                                                                                                                  | [4:0] | 0x0     | R/W  |             |  |  |
| Function                                                                                                                                                  | Bits  | Default | Туре | Description |  |  |
| SPI 1 Receive FIFO Fill Level Register: 0x4001_6034<br>SPI 2 Receive FIFO Fill Level Register: 0x4001_9034<br>SPI receive FIFO fill level value register. |       |         |      |             |  |  |
| Receive FIFO fill value                                                                                                                                   | [4:0] | 0x0     | R/W  |             |  |  |

## **I2C Controller**

Description

NCS36510 implements two I2C bus master interfaces, I2C1 and I2C2. Both are identical.

The I2C bus is an industry – standard two – wire (clock and data) serial communication bus. The I2C bus is a single master, multiple slave bus that uses a two–wire interface including a bidirectional clock line (SCL) and bidirectional data line (SDA). I2C specifies that the I2C master will initiate all read and write transactions, and that the I2C slave will respond to these requests. The I2C command FIFO is 32 x 8 bits and the read FIFO is 16 x 8 bits.

SCL is derived from the internal APB PCLK as follows:

The I2C internal clock is always a factor of 4 faster than PCLK to allow for proper internal clock phasing and synchronization. This is where the factor of 4 in the denominator comes from.

Interrupts are generated when the read and/or command FIFOs are not empty and upon errors.

| Function                                                                                    | Bits  | Default | Туре | Description                                                                                                                                            |
|---------------------------------------------------------------------------------------------|-------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| I2C1 Status Register: 0x4000_                                                               |       |         |      |                                                                                                                                                        |
| I2C2 Status Register: 0x4000_                                                               | D000  |         |      |                                                                                                                                                        |
| I2C status register.                                                                        |       | T       | 1    |                                                                                                                                                        |
| Command FIFO full                                                                           | [5]   | 0x0     | RO   | 0 – Command FIFO not full<br>1 – Command FIFO full                                                                                                     |
| Command FIFO overflow                                                                       | [4]   | 0x0     | RO   | 0 – Command FIFO not overflowed<br>1 – Command FIFO overflowed                                                                                         |
| Read data FIFO underflow                                                                    | [3]   | 0x0     | RO   | 0 – Read data FIFO not underflowed<br>1 – Read data FIFO overflowed                                                                                    |
| I2C bus error                                                                               | [2]   | 0x0     | RO   | 0 – No bus error<br>1 – I2C bus error occurred                                                                                                         |
|                                                                                             |       |         |      | An I2C bus error is when the I2C master expects an ACK (NACK) but receives a NACK (ACK) condition on the I2C bus from the addressed I2C Slave instead. |
|                                                                                             |       |         |      | Clear on read                                                                                                                                          |
| Read data ready                                                                             | [1]   | 0x0     | RO   | 0 – Read data not ready<br>1 – Read data ready                                                                                                         |
| Command FIFO empty                                                                          | [0]   | 0x0     | RO   | 0 – Command FIFO not empty<br>1 – Command FIFO empty                                                                                                   |
| Function                                                                                    | Bits  | Default | Туре | Description                                                                                                                                            |
| I2C1 Read Data Register: 0x400<br>I2C2 Read Data Register: 0x400<br>I2C read data register. |       | •       |      |                                                                                                                                                        |
| Read data register                                                                          | [7:0] | 0x0     | RO   | Data read from I2C bus                                                                                                                                 |
| Function                                                                                    | Bits  | Default | Туре | Description                                                                                                                                            |
| I2C1 Command Register: 0x400<br>I2C2 Command Register: 0x400<br>I2C command register.       |       |         |      |                                                                                                                                                        |

| Function                                                                                                            | Bits                 | Default | Туре | Description                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------------------------------------------------------|----------------------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Command sequence                                                                                                    | [7:0]                | 0x0     | wo   | 0x00 - No-op<br>0x10 - Transmit one bit of logic '0'<br>0x11 - Transmit one bit of logic '1'<br>0x12 - Transmit one byte of data<br>0x13 - Receive one byte of data<br>0x14 - Transmit Stop command<br>0x15 - Transmit Start command<br>0x16 - Verify received ACK<br>0x17 - Verify received NACK |
| Function                                                                                                            | Bits                 | Default | Туре | Description                                                                                                                                                                                                                                                                                       |
| I2C1 Interrupt Enable Register: 0x4<br>I2C2 Interrupt Enable Register: 0x4<br>I2C interrupt enable configuration re | 000 D00C             | ·       | ·    |                                                                                                                                                                                                                                                                                                   |
| I2C interrupt enable                                                                                                | [2]                  | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                                                       |
| Read data FIFO not empty inter-<br>rupt enable                                                                      | [1]                  | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                                                       |
| Command FIFO empty interrupt enable                                                                                 | [0]                  | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                                                       |
| Function                                                                                                            | Bits                 | Default | Туре | Description                                                                                                                                                                                                                                                                                       |
| I2C1 Control Register: 0x4000_701<br>I2C2 Control Register: 0x4000_D01<br>I2C control register.                     | 0<br>10              | ·       |      |                                                                                                                                                                                                                                                                                                   |
| I2C enable                                                                                                          | [7]                  | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                                                       |
| I2C clock divider enable                                                                                            | [5]                  | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                                                                                                                                                                                                                                                       |
| I2C APB PCLK clock divider val-<br>ue, bottom 5 bits                                                                | [4:0]                | 0x0     | R/W  | SCL frequency is 1/4 the divided I2C system clock, see description section.                                                                                                                                                                                                                       |
| Function                                                                                                            | Bits                 | Default | Туре | Description                                                                                                                                                                                                                                                                                       |
| I2C1 Prescaler Value Register: 0x4<br>I2C2 Prescaler Value Register: 0x4<br>I2C prescaler value register.           | 000_7014<br>000_D014 | ·       |      |                                                                                                                                                                                                                                                                                                   |
| I2C APB PCLK clock divider val-<br>ue, upper 8 bits                                                                 | [7:0]                | 0x0     | R/W  | SCL frequency is 1/4 the divided I2C system clock, see description section.                                                                                                                                                                                                                       |

# SECURITY FUNCTIONS

# **True Random Number Generator (TRNG)**

Description

The True Random Number Generator (TRNG) is able to produce true 32-bit random numbers. The TRNG uses on-chip sources to generate a string of random bits. This is in contrast to pseudo-random number generators often used, which only look random but are in fact generated by a deterministic algorithm.

There are two sources of random numbers in the TRNG block. There is a MSL source and a White noise source. A seed value can be set in the TRNG value register.

# Table 77. TRUE RANDOM NUMBER GENERATOR (TRNG) REGISTERS

| Function                                                                                                                   | Bits   | Default | Туре | Description                                                                                                                 |  |  |
|----------------------------------------------------------------------------------------------------------------------------|--------|---------|------|-----------------------------------------------------------------------------------------------------------------------------|--|--|
| TRNG Value Register: 0x4001_1000                                                                                           |        |         |      |                                                                                                                             |  |  |
| TRNG value register. Returns a 32 bit random number when read. Software can program a seed value by writing this register. |        |         |      |                                                                                                                             |  |  |
| TRNG value                                                                                                                 | [31:0] | 0x0     | R/W  | Write 32 bit seed or read a 32 bit random number<br>which is updated according to mode bits in the<br>TRNG control register |  |  |

# Table 77. TRUE RANDOM NUMBER GENERATOR (TRNG) REGISTERS

| Function                                                             | Bits    | Default | Туре | Description                                                             |
|----------------------------------------------------------------------|---------|---------|------|-------------------------------------------------------------------------|
| TRNG Control Register: 0x4001_                                       | 1004    |         |      |                                                                         |
| TRNG control register.                                               |         |         |      |                                                                         |
| Metastable latch (MSL) TRNG enable                                   | [4]     | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                             |
| White noise TRNG enable                                              | [3]     | 0x0     | R/W  | 0 – Disabled<br>1 – Enabled                                             |
| MSL speed control                                                    | [2]     | 0x0     | R/W  | 0 – Fast mode<br>1 – Slow mode                                          |
| Byte swap control                                                    | [1]     | 0x0     | R/W  | 0 – 32-bit byte swap<br>1 – 64-bit byte swap                            |
| Mode register                                                        | [0]     | 0x0     | R/W  | 0 – Updated on every rising edge of PCLK<br>1 – Updated on a read event |
| Function                                                             | Bits    | Default | Туре | Description                                                             |
| TRNG Write Buffer LSW Register<br>TRNG least significant word byte s |         |         |      |                                                                         |
| Byte 3                                                               | [31:24] | 0x0     | R/W  |                                                                         |
| Byte 2                                                               | [23:16] | 0x0     | R/W  |                                                                         |
| Byte 1                                                               | [15:8]  | 0x0     | R/W  |                                                                         |
| Byte 0                                                               | [7:0]   | 0x0     | R/W  |                                                                         |
| Function                                                             | Bits    | Default | Туре | Description                                                             |
| TRNG Write Buffer MSW Registe<br>TRNG most significant word byte s   | _       |         |      |                                                                         |
| Byte 7                                                               | [31:24] | 0x0     | R/W  |                                                                         |
| Byte 6                                                               | [23:16] | 0x0     | R/W  |                                                                         |
| Byte 5                                                               | [15:8]  | 0x0     | R/W  |                                                                         |
| Byte 4                                                               | [7:0]   | 0x0     | R/W  |                                                                         |
| Function                                                             | Bits    | Default | Туре | Description                                                             |
| TRNG Read Buffer LSW Register<br>TRNG least significant word byte s  | _       |         |      |                                                                         |
| Byte 4 or 0                                                          | [31:24] | 0x0     | RO   | If Byte Swap Control, returns byte 4. Else returns byte 0.              |
| Byte 5 or 1                                                          | [23:16] | 0x0     | RO   | If Byte Swap Control, returns byte 5. Else returns byte 1.              |
| Byte 6 or 2                                                          | [15:8]  | 0x0     | RO   | If Byte Swap Control, returns byte 6. Else returns byte 2.              |
| Byte 7 or 3                                                          | [7:0]   | 0x0     | RO   | If Byte Swap Control, returns byte 7. Else returns byte 3.              |
| Function                                                             | Bits    | Default | Туре | Description                                                             |
| TRNG Read Buffer MSW Registe<br>TRNG most significant word byte s    |         |         |      |                                                                         |
| Byte 0                                                               | [31:24] | 0x0     | RO   |                                                                         |
| Byte 1                                                               | [23:16] | 0x0     | RO   |                                                                         |
|                                                                      |         |         |      |                                                                         |

| Byte 3                                                                              | [7:0]  | 0x0     | RO   |             |  |  |
|-------------------------------------------------------------------------------------|--------|---------|------|-------------|--|--|
| Function                                                                            | Bits   | Default | Туре | Description |  |  |
| TRNG MSL Value Register: 0x4001_1018<br>TRNG metastable latch (MSL) value register. |        |         |      |             |  |  |
| MSL TRNG value                                                                      | [31:0] | 0x0     | RO   |             |  |  |
| Function                                                                            | Bits   | Default | Туре | Description |  |  |
| TRNG White Noise Value Register: 0x4001_101C<br>TRNG white noise value register.    |        |         |      |             |  |  |
| White noise value                                                                   | [31:0] | 0x0     | RO   |             |  |  |

#### Table 77. TRUE RANDOM NUMBER GENERATOR (TRNG) REGISTERS

#### **AES Accelerator**

#### Descritpion

The AES accelerator provides hardware support for the encryption and decryption operations used in 802.15.4. To support security in 802.15.4, the use of Counter with CBC–MAC (CCM) is required. CCM is a combination of counter mode (CTR) and cipher block chaining (CBC). It can perform a "Counter" (CTR) or a Cipher Block Chaining (CBC) encryption in 12 clocks for 128 bit encryption, or 16 clocks for 256 bit encryption. The definition of CCM mode encryption is documented in the NIST publication SP800–38C. Details of the implementation of the AES module can be found in federal information processing standard fips197.

In CTR mode, a software counter function creates a nonce and counter input to the encryption engine which is encrypted using the key programmed into the key register. The encrypted counter is then exored with the plaintext payload from the data registers. While AES is a block cipher, the use of an encrypted counter converts it to a stream cipher. The initial value of the counter and the nonce are sent un–encrypted as plaintext to initialize the counter and nonce on the receiving end. If the receiving end has the same key as the transmitting end, the plaintext payload can be recovered. This mode is used to provide privacy, but will not prove that the message has arrived unmodified.





#### Figure 8.

In CBC mode (cipher block chaining), feedback is established in the encryption engine. A 128 bit payload block is exored with the previous AES engine output. This value is the plaintext input to the AES engine. The MAC initial value register allows a non-zero value to be supplied for the initial XOR with the payload, rather than all 0s, as would occur after clearing the CBC result register. The

MAC Initial Value is used only once after it is written. The final encrypted result is an accumulation of all the previous results and is the MAC (message authentication code). Only a device that has knowledge of the key can reproduce the MAC value and authenticate that the message has not been modified. This mode will provide proof that the message has arrived unmodified, but does not provide privacy.





The security of the system only depends on the secrecy of the key. To further this requirement, the key register is a write only register. A read of this register will return all "0's". It is not possible for a secondary process running on the processor to read the key value.

| Function                                                                                                                                                                                                                                                                                                                                                  | Bits                               | Default           | Туре       | Description                       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-------------------|------------|-----------------------------------|
| AES Key Register(s):<br>LSW = Least Significant Word, N:<br>AES Key 0 - LSW: 0x4001_6000<br>AES Key 1 - NSW: 0x4001_6004<br>AES Key 2 - NSW: 0x4001_6008<br>AES Key 3 - NSW: 0x4001_6010<br>AES Key 4 - NSW: 0x4001_6010<br>AES Key 5 - NSW: 0x4001_6014<br>AES Key 6 - NSW: 0x4001_6018<br>AES Key 7 - MSW: 0x4001_601C<br>Write only AES key registers. | SW = Next Sig                      | gnificant Word, I | MSW = Most | Significant Word                  |
| Key 0 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [31:0]                   |
| Key 1 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [63:32]                  |
| Key 2 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [95:64]                  |
| Key 3 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [127:96]                 |
| Key 4 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [159:128]                |
| Key 5 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [191:160]                |
| Key 6 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [223:192]                |
| Key 7 value                                                                                                                                                                                                                                                                                                                                               | [31:0]                             | 0x0               | RO         | Key bits [255:224]                |
| Function                                                                                                                                                                                                                                                                                                                                                  | Bits                               | Default           | Туре       | Description                       |
| AES Counter Mode Counter Value<br>LSW = Least Significant Word, N<br>AES Counter 0 - LSW: 0x4001_60<br>AES Counter 1 - NSW: 0x4001_60<br>AES Counter 2 - NSW: 0x4001_60<br>AES Counter 3 - NSW: 0x4001_60<br>Counter mode counter values.                                                                                                                 | SW = Next Sig<br>020<br>024<br>028 |                   | MSW = Most | Significant Word                  |
| Counter 0 counter mode value                                                                                                                                                                                                                                                                                                                              | [31:0]                             | 0x0               | R/W        | Counter mode counter bits [31:0]  |
| Counter 1 counter mode value                                                                                                                                                                                                                                                                                                                              | [31:0]                             | 0x0               | R/W        | Counter mode counter bits [63:32] |
| Counter 2 counter mode value                                                                                                                                                                                                                                                                                                                              | [31:0]                             | 0x0               | R/W        | Counter mode counter bits [95:64] |

| Function                                                                                                                                                                                                                                                                          | Bits                                                                                                                                                                                                                   | Default                                    | Туре                             | Description                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Counter 3 counter mode value                                                                                                                                                                                                                                                      | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter mode counter bits [127:96]                                                                                                                                                                                                                                                                              |
| AES Counter Result Register(s)<br>LSW = Least Significant Word,<br>AES Counter 0 - LSW: 0x4001_<br>AES Counter 1 - NSW: 0x4001_<br>AES Counter 2 - NSW: 0x4001_<br>AES Counter 3 - NSW: 0x4001_                                                                                   | NSW = Next Si<br>6030<br>6034<br>6038                                                                                                                                                                                  | gnificant Word, I                          | MSW = Most                       | Significant Word                                                                                                                                                                                                                                                                                                |
| Counter values.                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                        |                                            |                                  |                                                                                                                                                                                                                                                                                                                 |
| Counter 0 value                                                                                                                                                                                                                                                                   | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter bits [31:0]                                                                                                                                                                                                                                                                                             |
| Counter 1 value                                                                                                                                                                                                                                                                   | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter bits [63:32]                                                                                                                                                                                                                                                                                            |
| Counter 2 value                                                                                                                                                                                                                                                                   | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter bits [95:64]                                                                                                                                                                                                                                                                                            |
| Counter 3 value                                                                                                                                                                                                                                                                   | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter bits [127:96]                                                                                                                                                                                                                                                                                           |
| Function                                                                                                                                                                                                                                                                          | Bits                                                                                                                                                                                                                   | Default                                    | Туре                             | Description                                                                                                                                                                                                                                                                                                     |
| AES Counter 0 - LSW: 0x4001_<br>AES Counter 1 - NSW: 0x4001_<br>AES Counter 2 - NSW: 0x4001_<br>AES Counter 3 - NSW: 0x4001_<br>Counter CBC values.                                                                                                                               | 6034<br>6038                                                                                                                                                                                                           |                                            | I                                |                                                                                                                                                                                                                                                                                                                 |
| Counter 0 CBC value                                                                                                                                                                                                                                                               | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter CBC bits [31:0]                                                                                                                                                                                                                                                                                         |
| Counter 1 CBC value                                                                                                                                                                                                                                                               | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter CBC bits [63:32]                                                                                                                                                                                                                                                                                        |
| Counter 2 CBC value                                                                                                                                                                                                                                                               | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter CBC bits [95:64]                                                                                                                                                                                                                                                                                        |
| Counter 3 CBC value                                                                                                                                                                                                                                                               | [31:0]                                                                                                                                                                                                                 | 0x0                                        | R/W                              | Counter CBC bits [127:96]                                                                                                                                                                                                                                                                                       |
| AES Control Register: 0x4001_0                                                                                                                                                                                                                                                    | 6050                                                                                                                                                                                                                   |                                            |                                  |                                                                                                                                                                                                                                                                                                                 |
| Control register for AES hardware                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                        |                                            |                                  |                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                        | 0x0                                        | R/W                              | 0 – No effect<br>1 – Clear interrupt                                                                                                                                                                                                                                                                            |
| Control register for AES hardware                                                                                                                                                                                                                                                 | e accelerator.                                                                                                                                                                                                         | 0x0<br>0x0                                 | R/W<br>R/W                       |                                                                                                                                                                                                                                                                                                                 |
| Control register for AES hardware                                                                                                                                                                                                                                                 | e accelerator.<br>[2]                                                                                                                                                                                                  |                                            |                                  | 1 – Clear interrupt<br>0 – No effect                                                                                                                                                                                                                                                                            |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator                                                                                                                                                                                                     | 2 accelerator.                                                                                                                                                                                                         | 0x0                                        | R/W                              | 1 - Clear interrupt         0 - No effect         1 - Clear CBC accumulator         0 - No effect                                                                                                                                                                                                               |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator<br>Start encryption                                                                                                                                                                                 | e accelerator. [2] [1] [0] Bits 54                                                                                                                                                                                     | 0x0<br>0x0                                 | R/W<br>R/W                       | <ul> <li>1 - Clear interrupt</li> <li>0 - No effect</li> <li>1 - Clear CBC accumulator</li> <li>0 - No effect</li> <li>1 - Start encryption process</li> </ul>                                                                                                                                                  |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator<br>Start encryption<br>Function<br>AES Mode Register: 0x4001_60                                                                                                                                     | e accelerator. [2] [1] [0] Bits 54                                                                                                                                                                                     | 0x0<br>0x0                                 | R/W<br>R/W                       | <ul> <li>1 - Clear interrupt</li> <li>0 - No effect</li> <li>1 - Clear CBC accumulator</li> <li>0 - No effect</li> <li>1 - Start encryption process</li> </ul>                                                                                                                                                  |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator<br>Start encryption<br>Function<br>AES Mode Register: 0x4001_60<br>Mode register for AES hardware a                                                                                                 | e accelerator. [2] [1] [0] Bits 54 accelerator.                                                                                                                                                                        | 0x0<br>0x0<br>Default                      | R/W<br>R/W<br>Type               | 1 - Clear interrupt         0 - No effect         1 - Clear CBC accumulator         0 - No effect         1 - Start encryption process         Description         0 - 128 bits                                                                                                                                 |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator<br>Start encryption<br>Function<br>AES Mode Register: 0x4001_60<br>Mode register for AES hardware a<br>Encryption key length                                                                        | e accelerator. [2] [1] [0] Bits 54 accelerator. [3]                                                                                                                                                                    | 0x0<br>0x0<br>Default<br>0x0               | R/W<br>R/W<br>Type               | 1 - Clear interrupt         0 - No effect         1 - Clear CBC accumulator         0 - No effect         1 - Start encryption process         Description         0 - 128 bits         1 - 256 bits         0 - Interrupt disabled                                                                             |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator<br>Start encryption<br>Function<br>AES Mode Register: 0x4001_60<br>Mode register for AES hardware a<br>Encryption key length<br>Interrupt mask                                                      | accelerator. [2] [1] [0] Bits 54 accelerator. [3] [2]                                                                                                                                                                  | 0x0<br>0x0<br>Default<br>0x0<br>0x0        | R/W<br>R/W<br>Type<br>R/W<br>R/W | 1 - Clear interrupt         0 - No effect         1 - Clear CBC accumulator         0 - No effect         1 - Start encryption process         Description         0 - 128 bits         1 - 256 bits         0 - Interrupt disabled         1 - Interrupt enabled         0 - Counter mode                      |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator<br>Start encryption<br>Function<br>AES Mode Register: 0x4001_60<br>Mode register for AES hardware a<br>Encryption key length<br>Interrupt mask<br>Mode<br>Function<br>AES Status Register: 0x4001_6 | accelerator.         [2]         [1]         [0]         Bits         54         accelerator.         [3]         [2]         [0]         Bits         53         [3]         [2]         [0]         Bits         058 | 0x0<br>0x0<br>Default<br>0x0<br>0x0<br>0x0 | R/W<br>R/W<br>Type<br>R/W<br>R/W | 1 - Clear interrupt         0 - No effect         1 - Clear CBC accumulator         0 - No effect         1 - Start encryption process         Description         0 - 128 bits         1 - 256 bits         0 - Interrupt disabled         1 - Interrupt enabled         0 - Counter mode         1 - CBC mode |
| Control register for AES hardware<br>Interrupt clear<br>Clear CBC accumulator<br>Start encryption<br>Function<br>AES Mode Register: 0x4001_60<br>Mode register for AES hardware a<br>Encryption key length<br>Interrupt mask<br>Mode<br>Function                                  | accelerator.         [2]         [1]         [0]         Bits         54         accelerator.         [3]         [2]         [0]         Bits         53         [3]         [2]         [0]         Bits         058 | 0x0<br>0x0<br>Default<br>0x0<br>0x0<br>0x0 | R/W<br>R/W<br>Type<br>R/W<br>R/W | 1 - Clear interrupt         0 - No effect         1 - Clear CBC accumulator         0 - No effect         1 - Start encryption process         Description         0 - 128 bits         1 - 256 bits         0 - Interrupt disabled         1 - Interrupt enabled         0 - Counter mode         1 - CBC mode |

#### Table 78. REGISTERS

| Function                                                                                                                                                                                                                                              | Bits                       | Default           | Туре       | Description                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-------------------|------------|--------------------------------|
| AES Initial Value Register(s):<br>LSW = Least Significant Word, N<br>AES Initial Value 0 – LSW: 0x400<br>AES Initial Value 1 – NSW: 0x400<br>AES Initial Value 2 – NSW: 0x400<br>AES Initial Value 3 – NSW: 0x400<br>Initial values for CBC counters. | I_605C<br>1_6060<br>1_6064 | gnificant Word, I | MSW = Most | t Significant Word             |
| Counter 0 CBC initial value                                                                                                                                                                                                                           | [31:0]                     | 0x0               | R/W        | Counter CBC bits [31:0]        |
| Counter 1 CBC initial value                                                                                                                                                                                                                           | [31:0]                     | 0x0               | R/W        | Counter CBC bits [63:32]       |
| Counter 2 CBC initial value                                                                                                                                                                                                                           | [31:0]                     | 0x0               | R/W        | Counter CBC bits [95:64]       |
| Counter 3 CBC initial value                                                                                                                                                                                                                           | [31:0]                     | 0x0               | R/W        | Counter CBC bits [127:96]      |
| Function                                                                                                                                                                                                                                              | Bits                       | Default           | Туре       | Description                    |
| AES Data Register(s):<br>LSW = Least Significant Word, N:<br>AES Data 0 – LSW: 0x4001_6070<br>AES Data 1 – NSW: 0x4001_6074<br>AES Data 2 – NSW: 0x4001_6076<br>AES Data 3 – NSW: 0x4001_6076<br>Data to be encrypted, 128 bits.                      |                            | gnificant Word, I | MSW = Most | t Significant Word             |
| Data 0 value                                                                                                                                                                                                                                          | [31:0]                     | 0x0               | R/W        | Data to encrypt, bits [31:0]   |
| Data 1 value                                                                                                                                                                                                                                          | [31:0]                     | 0x0               | R/W        | Data to encrypt, bits [63:32]  |
| Data 2 value                                                                                                                                                                                                                                          | [31:0]                     | 0x0               | R/W        | Data to encrypt, bits [95:64]  |
| Data 3 value                                                                                                                                                                                                                                          | [31:0]                     | 0x0               | R/W        | Data to encrypt, bits [127:96] |

#### Arm and Cortex are registered trademark of ECOS Consulting.

ON Semiconductor and are trademarks of Semiconductor Components Industries, LLC dba ON Semiconductor or its subsidiaries in the United States and/or other countries. ON Semiconductor owns the rights to a number of patents, trademarks, copyrights, trade secrets, and other intellectual property. A listing of ON Semiconductor's product/patent coverage may be accessed at www.onsemi.com/site/pdf/Patent-Marking.pdf. ON Semiconductor reserves the right to make changes without further notice to any products herein. ON Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does ON Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation special, consequential or incidental damages. Buyer is responsible for its products and applications using ON Semiconductor products, including compliance with all laws, regulations and safety requirements or standards, regardless of any support or applications information provided by ON Semiconductor "Typical" parameters which may be provided in ON Semiconductor dates sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. ON Semiconductor does not convey any license under its patent rights or others. ON Semiconductor products are not designed, intended, or authorized for use as a critical component in life support systems or any FDA Class 3 medical devices or medical devices with a same or similar classification in a foreign jurisdiction or any devices intended for implantation in the human body. Should Buyer purchase or use ON Semiconductor handles, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such uninte

Phone: 421 33 790 2910

#### PUBLICATION ORDERING INFORMATION

#### LITERATURE FULFILLMENT:

Literature Distribution Center for ON Semiconductor 19521 E. 32nd Pkwy, Aurora, Colorado 80011 USA Phone: 303–675–2175 or 800–344–3860 Toll Free USA/Canada Fax: 303–675–2176 or 800–344–3867 Toll Free USA/Canada Email: orderlit@onsemi.com N. American Technical Support: 800–282–9855 Toll Free USA/Canada Europe, Middle East and Africa Technical Support: ON Semiconductor Website: www.onsemi.com

Order Literature: http://www.onsemi.com/orderlit

For additional information, please contact your local Sales Representative