**Final** 

## **General Description**

The DA14531 is an ultra-low power SoC integrating a 2.4 GHz transceiver and an Arm® Cortex-M0+ microcontroller with a RAM of 48 kB and a One-Time Programmable (OTP) memory of 32 kB. It can be used as a standalone application processor or as a data pump in hosted systems.

The radio transceiver, the baseband processor, and the qualified Bluetooth® low energy stack are fully compliant with the Bluetooth® Low Energy 5.1 standard.

The DA14531 has dedicated hardware for the Link Layer implementation of Bluetooth® LE and interface controllers for enhanced connectivity capabilities.

The Bluetooth® LE firmware includes the L2CAP service layer protocols, Security Manager (SM), Attribute Protocol (ATT), the Generic Attribute Profile (GATT), and the Generic Access Profile (GAP). All profiles published by the Bluetooth® SIG as well as custom profiles are supported.

The DA14531-01 is optimized for peripheral only applications, provides around 25 % additional user RAM for a typical Bluetooth LE application compared to DA14531-00 and is pin-to-pin compatible.

The device is suitable for disposables, wireless sensor nodes, beacons, proximity tags, and trackers, smart HID devices (stylus, keyboards, mice, and trackpads), toys, and medical and industrial applications.

### **Key Features**

- Compatible with Bluetooth® v5.1, ETSI EN 300 328 and EN 300 440 Class 2 (Europe), FCC CFR47 Part 15 (US) and ARIB STD-T66 (Japan)
- Supports up to three Bluetooth® LE connections
- Typical cold boot to radio active 35 ms
- Processing power
  - □ 16 MHz 32-bit Arm<sup>®</sup> Cortex-M0+ with SWD interface
  - □ 18300 EEMBC IoTMark-BLE® score
  - Dedicated Link Layer and AES-128
     Encryption Processor
  - Software-based True Random Number Generator (TRNG)
- Memories
  - □ 32 kB One-Time-Programmable (OTP)
  - 48 kB Retainable System RAM
  - □ 144 kB ROM
- Power management
  - □ Integrated Buck/Boost DCDC converter
  - □ Buck:  $1.8 \text{ V} \leq \text{V}_{\text{BAT\_HIGH}} \leq 3.6 \text{ V}$
  - □ Boost:  $1.1 \text{ V} \leq \text{V}_{\text{BAT\_LOW}} \leq 1.65 \text{ V}$
  - □ Clock-less hibernation mode: Buck 270 nA, Boost 240 nA
  - □ Built-in temperature sensor for die temperature monitoring

#### Clocks

- 32 MHz crystal and 32 MHz RC osc.
- □ 32 kHz crystal and 32/512 kHz RC osc.
- □ 15 kHz RCX as crystal replacement
- Programmable Reset Circuitry
- 2× General purpose Timers with capture and PWM capabilities
- Digital interfaces
  - ☐ GPIOs: 6 (WLCSP17), 12 (FCGQFN24)
  - □ 2× UARTs (one with flow control)
  - □ SPI Master/Slave up to 32 MHz (Master)
  - □ I2C bus at 100 kHz and 400 kHz
  - □ 3-axis capable Quadrature Decoder
  - Keyboard controller
- Analog interfaces
  - □ 4-channel 10-bit ADC
- Radio transceiver
  - Fully integrated 2.4 GHz CMOS transceiver
  - □ Single wire antenna
  - □ TX: 3.5 mA, RX: 2.2 mA (system currents with DC-DC, V<sub>BAT\_HIGH</sub> = 3 V and 0 dBm)
  - Programmable transmit output power from -19.5 dBm to +2.5 dBm
  - □ -94 dBm receiver sensitivity

Datasheet Revision 3.6 26-Sep-2022



**Final** 

- Packages:
  - □ WLCSP 17 balls, 1.7 × 2.05, 0.5 mm pitch
  - □ FCGQFN 24 pins, 2.2 × 3, 0.4 mm pitch
- Variant:
  - □ 531-00: LE central and peripheral
  - □ 531-01: LE peripheral only

# **Applications**

- Medical applications
- Disposables
- Beacons
- Proximity tags and trackers
- Wireless sensor nodes
  - □ Fitness trackers
  - Consumer health
- Smartwatches
- Human interface devices (HID)
  - □ Stylus pens
  - □ Keyboards
  - Mouse devices
  - □ Trackpads
- Toys
- Industrial appliances

# **Key Benefits**

- Lowest power consumption
- Smallest system size
- Lowest system cost



Final

# **System Diagram**



Figure 1: System Diagram



**Final** 

## **Contents**

| Ge | neral l         | Descripti                | on                 |                                         | 1           |  |  |
|----|-----------------|--------------------------|--------------------|-----------------------------------------|-------------|--|--|
| Ke | y Feat          | ures                     |                    |                                         | 1           |  |  |
| Аp | plicati         | ons                      |                    |                                         | 2           |  |  |
| Ke | y Ben           | efits                    |                    |                                         | 2           |  |  |
| Sy | stem [          | Diagram .                |                    |                                         | 3           |  |  |
| •  |                 | •                        |                    |                                         |             |  |  |
|    |                 |                          |                    |                                         |             |  |  |
| _  |                 |                          |                    |                                         |             |  |  |
|    |                 |                          |                    |                                         |             |  |  |
| 1  |                 | •                        |                    |                                         |             |  |  |
| 2  |                 |                          |                    | ants                                    |             |  |  |
| 3  |                 | J                        |                    |                                         |             |  |  |
|    | 3.1<br>3.2      |                          |                    |                                         |             |  |  |
|    |                 |                          |                    |                                         |             |  |  |
| 4  | <b>Spec</b> 4.1 |                          |                    | Ratings                                 |             |  |  |
|    | 4.1             |                          |                    | rating Conditions                       |             |  |  |
|    | 4.3             |                          | •                  | aung Gonduons                           |             |  |  |
|    | 4.4             |                          |                    | DS                                      |             |  |  |
|    | 4.5             | •                        |                    |                                         |             |  |  |
|    | 4.6             | 4.6 XTAL32MHz Oscillator |                    |                                         |             |  |  |
|    | 4.7             | 4.7 XTAL32kHz Oscillator |                    |                                         |             |  |  |
|    | 4.8             |                          |                    |                                         |             |  |  |
|    | 4.9             |                          |                    |                                         |             |  |  |
|    | 4.10            |                          |                    | ristics                                 |             |  |  |
|    | 4.11<br>4.12    | U                        |                    | istics                                  |             |  |  |
|    | 4.12            |                          |                    |                                         |             |  |  |
|    | 4.14            |                          |                    |                                         |             |  |  |
|    |                 | •                        |                    |                                         |             |  |  |
| 5  |                 |                          |                    |                                         |             |  |  |
| •  | 5.1             |                          |                    |                                         |             |  |  |
|    | 5.2             |                          |                    | Unit                                    |             |  |  |
|    |                 | 5.2.1                    | Introduction       | ٦                                       | 48          |  |  |
|    |                 | 5.2.2                    | Architectur        | e                                       | 48          |  |  |
|    |                 |                          | 5.2.2.1            | Digital Power Domains                   |             |  |  |
|    |                 |                          | 5.2.2.2            | Power Modes                             |             |  |  |
|    |                 |                          | 5.2.2.3            | VDD Level in Hibernation                |             |  |  |
|    |                 | 500                      | 5.2.2.4            | Retainable Registers                    |             |  |  |
|    |                 | 5.2.3                    | •                  | ng                                      |             |  |  |
|    |                 |                          | 5.2.3.1<br>5.2.3.2 | Buck Configuration  Boost Configuration |             |  |  |
|    |                 |                          | 5.2.3.2            | Bypass Configuration                    |             |  |  |
|    | 5.3             | HW FSM                   |                    | , Wake-Up, and Go-to-Sleep)             |             |  |  |
| Da | tashee          |                          | ,                  | Revision 3.6                            | 26-Sep-2022 |  |  |



| Ul | tra Lo | ow Pow           | er Blueto   | oth 5.1 SoC                        | Fina |  |  |
|----|--------|------------------|-------------|------------------------------------|------|--|--|
|    |        | 5.3.1            | Power-Up/   | Wake-Up in Buck Configuration      | 58   |  |  |
|    |        | 5.3.2            | •           | Wake-Up in Boost Configuration     |      |  |  |
|    |        | 5.3.3            | •           | p and Refresh Bandgap              |      |  |  |
|    | 5.4    | OTP Me           |             | t                                  |      |  |  |
|    |        | 5.4.1            |             | er                                 |      |  |  |
|    |        | 5.4.2            | Configurati | on Script                          | 64   |  |  |
|    | 5.5    | BootRO           | M Sequence  |                                    | 65   |  |  |
| 6  | Rese   | t                |             |                                    | 69   |  |  |
|    | 6.1    | Introduc         | tion        |                                    | 69   |  |  |
|    | 6.2    | Architec         | ture        |                                    | 69   |  |  |
|    |        | 6.2.1            | POR, HW,    | and SW Reset                       | 69   |  |  |
|    |        | 6.2.2            | POR Funct   | tionality                          | 71   |  |  |
|    |        |                  | 6.2.2.1     | POR Timer Clock                    | 71   |  |  |
|    |        |                  | 6.2.2.2     | RST Pad                            | 71   |  |  |
|    |        |                  | 6.2.2.3     | POR from GPIO                      | 71   |  |  |
|    |        | 6.2.3            | POR Timin   | g Diagram                          | 71   |  |  |
|    |        | 6.2.4            | POR Cons    | iderations                         | 72   |  |  |
|    | 6.3    | Program          | nming       |                                    | 72   |  |  |
| 7  | Arm    | Cortex-M         | 10+         |                                    | 73   |  |  |
|    | 7.1    |                  |             |                                    |      |  |  |
|    | 7.2    | Architec         | ture        |                                    | 74   |  |  |
|    |        | 7.2.1            | Interrupts  |                                    | 74   |  |  |
|    |        | 7.2.2            | System Tin  | ner (systick)                      | 76   |  |  |
|    |        | 7.2.3            | Wake-Up I   | nterrupt Controller                | 76   |  |  |
|    | 7.3    | Program          | nming       |                                    | 76   |  |  |
| 8  | AMB    | MBA Bus          |             |                                    |      |  |  |
|    | 8.1    | Introduction     |             |                                    |      |  |  |
|    | 8.2    | Architecture     |             |                                    |      |  |  |
|    | 8.3    | Program          | nming       |                                    | 78   |  |  |
| 9  | Mem    | ory Map.         |             |                                    | 79   |  |  |
| 10 | Mem    | orv Cont         | roller      |                                    | 81   |  |  |
|    | 10.1   | -                |             |                                    |      |  |  |
|    | 10.2   |                  |             |                                    |      |  |  |
|    |        | 10.2.1           |             |                                    |      |  |  |
| 11 | Clock  | Clock Generation |             |                                    |      |  |  |
|    |        |                  |             |                                    |      |  |  |
|    |        | 11.1.1           |             | ock Constraints                    |      |  |  |
|    | 11.2   | Crvstal (        |             |                                    |      |  |  |
|    | –      | 11.2.1           |             | Control (32 MHz Crystal)           |      |  |  |
|    |        | 11.2.2           |             | Trimming and Settling Notification |      |  |  |
|    | 11.3   |                  |             |                                    |      |  |  |
|    |        | 11.3.1           |             | Calibration                        |      |  |  |
| 12 | ОТР    | Controlle        |             |                                    |      |  |  |
| -  | 12.1   |                  |             |                                    |      |  |  |
|    | . —    |                  |             |                                    |      |  |  |
|    |        |                  |             |                                    |      |  |  |

**Datasheet** 



| Uli | tra Lo           | ow Pow    | er Blueto  | ooth 5.1 SoC                         | Final       |
|-----|------------------|-----------|------------|--------------------------------------|-------------|
|     |                  | 12.2.1    | OTP Acce   | ssing Considerations                 | 91          |
|     | 12.3             | Progran   | nming      |                                      | 91          |
| 13  | DMA              | Controll  | er         |                                      | 92          |
|     | 13.1             |           |            |                                      |             |
|     | 13.2             | Architec  | ture       |                                      | 92          |
|     |                  | 13.2.1    | DMA Peri   | oherals                              | 92          |
|     |                  | 13.2.2    | Input/Outp | out Multiplexer                      | 93          |
|     |                  | 13.2.3    | DMA Chai   | nnel Operation                       | 93          |
|     |                  | 13.2.4    | DMA Arbit  | ration                               | 94          |
|     |                  | 13.2.5    | Freezing [ | DMA Channels                         | 95          |
|     | 13.3             | Progran   | nming      |                                      | 95          |
|     |                  | 13.3.1    | Memory to  | Memory Transfers                     | 95          |
|     |                  | 13.3.2    | Peripheral | to Memory Transfers                  | 95          |
| 14  | I2C Ir           | nterface. |            |                                      | 97          |
|     | 14.1             | Introduc  | tion       |                                      | 97          |
|     | 14.2             | Architec  | ture       |                                      | 97          |
|     |                  | 14.2.1    | I2C Bus T  | erms                                 | 98          |
|     |                  |           | 14.2.1.1   | Bus Transfer Terms                   | 99          |
|     |                  | 14.2.2    | I2C Behav  | /ior                                 | 99          |
|     |                  |           | 14.2.2.1   | START and STOP Generation            | 100         |
|     |                  |           | 14.2.2.2   | Combined Formats                     | 100         |
|     |                  | 14.2.3    | I2C Protoc | cols                                 | 100         |
|     |                  |           | 14.2.3.1   | START and STOP Conditions            | 100         |
|     |                  |           | 14.2.3.2   | Addressing Slave Protocol            | 101         |
|     |                  |           | 14.2.3.3   | Transmitting and Receiving Protocols | 102         |
|     |                  | 14.2.4    | Multiple M | aster Arbitration                    |             |
|     |                  | 14.2.5    | Clock Syn  | chronization                         | 104         |
|     | 14.3             | Progran   | nming      |                                      | 105         |
| 15  | UAR <sup>-</sup> | Т         | -          |                                      | 106         |
|     | 15.1             |           |            |                                      |             |
|     | 15.2             |           |            |                                      |             |
|     |                  | 15.2.1    |            | S232) Serial Protocol                |             |
|     |                  | 15.2.2    | `          | port                                 |             |
|     |                  | 15.2.3    | •          |                                      |             |
|     |                  | 15.2.4    | -          | nable THRE Interrupt                 |             |
|     |                  | 15.2.5    | _          | egisters                             |             |
|     |                  | 15.2.6    |            | t Mode                               |             |
|     | 15.3             | Progran   | nming      |                                      | 111         |
| 16  |                  | •         | -          |                                      |             |
|     | 16.1             |           |            |                                      |             |
|     | 16.2             |           |            |                                      |             |
|     |                  | 16.2.1    |            | g                                    |             |
|     | 16.3             |           |            | g                                    |             |
|     |                  | 16.3.1    | •          | ode                                  |             |
|     |                  | 16.3.2    |            | de                                   |             |
| 17  | Quad             |           |            |                                      |             |
|     | wuau<br>tashe    |           |            | Revision 3.6                         |             |
| UA  | IdSHP            | HE (      |            | REVISION 5 P                         | /n-3en-/U// |



| Uli       | tra Lo | ow Powe    | er Blueto    | oth 5.1 SoC             | Final |
|-----------|--------|------------|--------------|-------------------------|-------|
|           | 17.1   | Introduct  | ion          |                         | 117   |
|           | 17.2   | Architect  | ure          |                         | 117   |
|           | 17.3   | Program    | ming         |                         | 119   |
| 18        | Clock  | dess Wak   | ce-Up Cont   | roller                  | 120   |
|           | 18.1   |            | •            |                         | 120   |
|           | 18.2   | Architect  | ure          |                         | 120   |
|           | 18.3   | Program    | ming         |                         | 121   |
| 19        | Clock  | ked Wake   | -Up Contro   | oller                   | 122   |
|           | 19.1   |            | •            |                         | 122   |
|           | 19.2   | Architect  | ure          |                         | 122   |
|           | 19.3   | Program    | ming         |                         | 123   |
| 20        | Time   | r <b>0</b> |              |                         | 125   |
|           | 20.1   |            |              |                         | 125   |
|           | 20.2   | Architect  | ure          |                         | 125   |
|           | 20.3   | Program    | ming         |                         | 127   |
|           |        | 20.3.1     | Timer Fund   | ctionality              | 127   |
|           |        | 20.3.2     | PWM Gen      | eration                 | 128   |
| 21        | Time   | r 1        |              |                         | 128   |
|           | 21.1   | Introduct  | ion          |                         | 128   |
|           | 21.2   | Architect  | ure          |                         | 129   |
|           | 21.3   | Program    | ming         |                         | 129   |
|           |        | 21.3.1     | Timer Fund   | ctionality              | 129   |
|           |        | 21.3.2     | Capture Fu   | unctionality            | 130   |
|           |        | 21.3.3     | Frequency    | Measuring Functionality | 130   |
| 22        | Time   | r <b>2</b> |              |                         | 132   |
|           | 22.1   | Introduct  | ion          |                         | 132   |
|           | 22.2   | Architect  | ure          |                         | 133   |
|           | 22.3   | •          | 0            |                         | 133   |
|           |        | 22.3.1     |              |                         | 133   |
|           |        | 22.3.2     | Freeze Fu    | nctionality             | 134   |
| 23        | Watc   | hdog Tim   | er           |                         | 135   |
|           | 23.1   |            |              |                         | 135   |
|           | 23.2   |            |              |                         | 135   |
|           | 23.3   | Program    | ming         |                         | 136   |
| 24        | Temp   | erature S  | Sensor       |                         | 137   |
|           |        |            |              |                         | 137   |
|           | 24.2   |            |              |                         | 137   |
|           |        | 24.2.1     | _            | _                       |       |
|           |        |            | 24.2.1.1     | •                       |       |
|           |        |            | 24.2.1.2     | •                       | 139   |
| 25        | •      |            |              |                         | 140   |
|           | 25.1   |            |              |                         | 140   |
|           | 25.2   |            |              |                         | 140   |
|           |        | 25.2.1     | •            |                         | 140   |
|           |        | 25.2.2     | GPIO Inter   | rupt Generator          | 141   |
| Datasheet |        |            | Revision 3.6 | 26-Sep-2022             |       |



| Ul | tra Lo | ow Powe                  | er Blueto    | oth 5.1 SoC                           | Final       |  |  |
|----|--------|--------------------------|--------------|---------------------------------------|-------------|--|--|
|    | 25.3   | Program                  | ming         |                                       | 142         |  |  |
|    |        | 25.3.1                   | ū            | Scanner                               |             |  |  |
|    |        | 25.3.2                   | GPIO Inter   | rupts                                 | 142         |  |  |
| 26 | Input  | /Output P                | orts         |                                       | 143         |  |  |
|    | 26.1   | -                        |              |                                       |             |  |  |
|    | 26.2   | Architect                | ure          |                                       | 143         |  |  |
|    |        | 26.2.1                   | Programma    | able Pin Assignment                   | 143         |  |  |
|    |        |                          | 26.2.1.1     | Priority                              | 144         |  |  |
|    |        |                          | 26.2.1.2     | Direction Control                     | 144         |  |  |
|    |        | 26.2.2                   | General Pu   | rpose Port Registers                  | 144         |  |  |
|    |        |                          | 26.2.2.1     | Port Data Register                    | 144         |  |  |
|    |        |                          | 26.2.2.2     | Port Set Data Output Register         | 144         |  |  |
|    |        |                          | 26.2.2.3     | Port Reset Data Output Register       |             |  |  |
|    |        | 26.2.3                   |              | gnment Functionality                  |             |  |  |
|    |        | 26.2.4                   |              | PIO Pads                              |             |  |  |
|    |        | 26.2.5                   | Driving Stre | ength                                 | 146         |  |  |
| 27 | Gene   | ral Purpo                | se ADC       |                                       | 147         |  |  |
|    | 27.1   | Introduct                | ion          |                                       | 147         |  |  |
|    | 27.2   | Architect                |              |                                       |             |  |  |
|    |        | 27.2.1                   | •            | nels                                  |             |  |  |
|    |        | 27.2.2                   | Operating I  | Modes                                 |             |  |  |
|    |        |                          | 27.2.2.1     | Enabling the ADC                      |             |  |  |
|    |        |                          | 27.2.2.2     | Manual Mode                           |             |  |  |
|    |        |                          | 27.2.2.3     | Continuous Mode                       |             |  |  |
|    |        | 27.2.3                   |              | Modes                                 |             |  |  |
|    |        |                          | 27.2.3.1     | AD Conversion                         |             |  |  |
|    |        |                          | 27.2.3.2     | Averaging                             |             |  |  |
|    |        | 07.0.4                   | 27.2.3.3     | Chopper Mode                          |             |  |  |
|    |        | 27.2.4                   |              | Settings                              |             |  |  |
|    |        | 27.2.5                   |              | Effects                               |             |  |  |
|    |        | 27.2.6<br>27.2.7         |              | orationAdjustment                     |             |  |  |
|    |        | 27.2.7                   |              | Adjustment                            |             |  |  |
|    |        | 27.2.9                   |              | dance, Inductance, and Input Settling |             |  |  |
|    | 27 3   |                          |              | dance, muuttance, and input Setting   |             |  |  |
| 20 |        | •                        | •            |                                       |             |  |  |
| 20 | 28 1   |                          | ` '          |                                       |             |  |  |
|    | _0     |                          |              |                                       |             |  |  |
|    |        | Architecture Programming |              |                                       |             |  |  |
| ~~ |        | •                        | •            |                                       |             |  |  |
| 29 |        |                          |              |                                       |             |  |  |
|    |        | DCDC Converter           |              |                                       |             |  |  |
|    |        | 2 LDOS                   |              |                                       |             |  |  |
|    |        |                          |              |                                       |             |  |  |
| 30 |        |                          |              |                                       |             |  |  |
|    | 30.1   |                          |              | Momony                                |             |  |  |
|    |        | 30.1.1                   | ⊏xchange i   | Memory                                |             |  |  |
| Da | tashee | et                       |              | Revision 3.6                          | 26-Sep-2022 |  |  |



| Uli | lia LC | W POW      | er bluetot     | Jul 5.1 30C                                                 | ı ıııaı |
|-----|--------|------------|----------------|-------------------------------------------------------------|---------|
|     | 30.2   | Program    | ıming          |                                                             | 162     |
|     |        | 30.2.1     | •              | RQ                                                          |         |
|     |        | 30.2.2     | •              | Bluetooth® LE Active Mode to Bluetooth® LE Deep Sleep Mode. |         |
|     |        | 30.2.3     | Switch from    | Bluetooth® LE Deep Sleep Mode to Bluetooth® LE Active Mode. | 163     |
|     |        |            | 30.2.3.1       | Switching at an Anchor Point                                | 163     |
|     |        |            | 30.2.3.2       | Switching Due to an External Event                          | 165     |
| 31  | Radio  | )          |                |                                                             | 166     |
|     | 31.1   |            |                |                                                             |         |
|     | 31.2   | Architect  | ture           |                                                             | 166     |
|     |        | 31.2.1     | Receiver       |                                                             | 166     |
|     |        | 31.2.2     |                |                                                             |         |
|     |        | 31.2.3     | •              |                                                             |         |
|     |        | 31.2.4     | RFIO           |                                                             | 167     |
|     |        | 31.2.5     | Biasing        |                                                             | 167     |
|     |        | 31.2.6     | RF Monitor     | ing                                                         | 167     |
| 32  | Regis  | ters       |                |                                                             | 168     |
| _   | _      |            |                | s Registers                                                 |         |
|     |        | _          |                | Registers                                                   |         |
|     |        |            |                | d Reset Registers                                           |         |
|     | 32.4   |            |                | gisters                                                     |         |
|     | 32.5   |            |                | sters                                                       |         |
|     | 32.6   |            | _              | C Registers                                                 |         |
|     | 32.7   |            | •              | Registers                                                   |         |
|     | 32.8   |            | •              | gisters                                                     |         |
|     |        |            | •              | rs                                                          |         |
|     | 32.10  | Keyboar    | d Registers    |                                                             | 258     |
|     | 32.11  | Miscellar  | neous Regis    | ters                                                        | 262     |
|     | 32.12  | OTP Cor    | ntroller Regis | sters                                                       | 265     |
|     | 32.13  | Quadrati   | ure Decoder    | Registers                                                   | 271     |
|     | 32.14  | Real Tim   | ne Clock Reg   | isters                                                      | 274     |
|     | 32.15  | SPI Inter  | rface Registe  | rs                                                          | 280     |
|     | 32.16  | Timer an   | nd Triple PW   | M Registers                                                 | 285     |
|     | 32.17  | Timer1 F   | Registers      |                                                             | 289     |
|     | 32.18  | UART In    | terface Regi   | sters                                                       | 292     |
|     | 32.19  | Chip Ver   | rsion Registe  | rs                                                          | 346     |
|     | 32.20  | Wake-Up    | p Registers    |                                                             | 347     |
|     | 32.21  | Watchdo    | og Registers.  |                                                             | 350     |
| 33  | Orde   | ring Infor | mation         |                                                             | 351     |
| 34  | Packa  | age Infor  | mation         |                                                             | 352     |
|     | 34.1   | _          |                | evel (MSL)                                                  |         |
|     | 34.2   |            | -              |                                                             |         |
|     |        |            | _              | 1                                                           |         |
|     | 34.4   | Package    | Outlines       |                                                             | 352     |
| Re  | vision | History.   |                |                                                             | 355     |

9 of 358



Final

# **Figures**

| Figure 1: System Diagram                                                                 |         |
|------------------------------------------------------------------------------------------|---------|
| Figure 2: DA14531 Block Diagram                                                          |         |
| Figure 3: WLCSP17 Ball Assignment (Top View)                                             |         |
| Figure 4: FCGQFN24 Pin Assignment (Top View)                                             |         |
| Figure 5: Boost Configuration System Diagram                                             |         |
| Figure 6: Buck Configuration System Diagram                                              |         |
| Figure 7: Power Management Unit: Buck Configuration                                      |         |
| Figure 8: Power Management Unit: Boost Configuration                                     |         |
| Figure 9: Power Management Unit: Bypass Configuration                                    |         |
| Figure 10: Digital Power Domains                                                         |         |
| Figure 11: Power-Up/Wake-Up/Sleep FSM Diagram                                            |         |
| Figure 12: Power-Up (Buck)                                                               | 59      |
| Figure 13: Wake-Up from Hibernation (Buck)                                               |         |
| Figure 14: Wake-Up (Buck)                                                                |         |
| Figure 15: Power-Up (Boost)                                                              |         |
| Figure 16: Wake-Up from Hibernation (Boost)                                              |         |
| Figure 17: Wake-Up from Extended/Deep Sleep (Boost)                                      |         |
| Figure 18: Go-to-Sleep and Bandgap Refresh                                               | 62      |
| Figure 19: OTP Layout Scheme                                                             |         |
| Figure 20: BootROM Sequence                                                              |         |
| Figure 21: Reset Block Diagram                                                           |         |
| Figure 22: POR Timing Diagram                                                            |         |
| Figure 23: Arm Cortex-M0+ Block Diagram                                                  |         |
| Figure 24: AMBA Bus Architecture and Power Domains                                       |         |
| Figure 25: Memory Controller Block Diagram                                               | 81      |
| Figure 26: Clock Tree Diagram                                                            | 83      |
| Figure 27: Crystal Oscillator Circuits                                                   | 85      |
| Figure 28: XTAL32MHz Oscillator Frequency Trimming                                       | 86      |
| Figure 29: Automated Mechanism for XTAL32M Trim and Settling                             | 87      |
| Figure 30: OTP Controller Block Diagram                                                  | 89      |
| Figure 31: DMA Controller Block Diagram                                                  |         |
| Figure 32: DMA Channel Diagram                                                           |         |
| Figure 33: I2C Controller Block Diagram                                                  |         |
| Figure 34: Master/Slave and Transmitter/Receiver Relationships                           |         |
| Figure 35: Data Transfer on the I2C Bus                                                  |         |
| Figure 36: START and STOP Conditions                                                     |         |
| Figure 37: 7-bit Address Format.                                                         |         |
| Figure 38: 10-bit Address Format                                                         |         |
| Figure 39: Master-Transmitter Protocol                                                   |         |
| Figure 40: Master-Receiver Protocol                                                      |         |
| Figure 41: START BYTE Transfer                                                           |         |
| Figure 42: Multiple Master Arbitration                                                   |         |
| Figure 43: Multiple Master Clock Synchronization                                         |         |
| Figure 44: UART Block Diagram                                                            |         |
| Figure 45: Serial Data Format                                                            |         |
| Figure 46: Receiver Serial Data Sampling Points                                          |         |
| Figure 47: Flowchart of Interrupt Generation for Programmable THRE Interrupt Mode        |         |
| Figure 48: Flowchart of Interrupt Generation When Not in Programmable THRE Interrupt Mod |         |
|                                                                                          |         |
| Figure 49: SPI Block Diagram Figure 50: SPI Slave Mode Timing (CPOL = 0, CPHA = 0)       | ۱۱۵     |
|                                                                                          |         |
| Figure 51: Quadrature Decoder Block Diagram                                              |         |
| Figure 52: Moving Forward on Axis X                                                      |         |
| Figure 53: Moving Backwards on Axis X                                                    |         |
| Figure 54: Digital Filtering and Edge Detection Circuit                                  |         |
| Figure 55: Clockless Wake-Up Controller Circuit                                          |         |
| Figure 56: Clocked Wake-Up Controller Block Diagram                                      |         |
| Figure 57: Event Counter State Machine for the Wake-Up Interrupt Generator               | 123     |
| Datasheet Revision 3.6 26-S                                                              | ep-2022 |



| Ultra Low Power Bluetooth 5.1          | SoC                                                              | Fina |
|----------------------------------------|------------------------------------------------------------------|------|
| Figure 58: Timer 0 Block Diagram       |                                                                  | 125  |
| Figure 59: Timer 0 PWM Mode            |                                                                  | 127  |
|                                        |                                                                  |      |
|                                        |                                                                  |      |
|                                        |                                                                  |      |
|                                        | ıram                                                             |      |
|                                        | ior                                                              |      |
|                                        | Diagram                                                          |      |
|                                        | achine                                                           |      |
|                                        | tate Machine Pin Assignment and Driving Strength                 |      |
|                                        | rith Assignment and Driving Strengthith Schmitt Trigger on Input |      |
| Figure 70: Type B GPIO Pad - GPIO w    | vith Schmitt Trigger and RC Filter on Input                      | 146  |
|                                        |                                                                  |      |
|                                        | ngram                                                            |      |
|                                        | ıram                                                             |      |
|                                        | k Configuration                                                  |      |
|                                        | st Configuration                                                 |      |
|                                        | onfiguration                                                     |      |
| Figure 77: DCDC Efficiency in Boost C  | configuration                                                    | 160  |
|                                        | iagram                                                           |      |
|                                        | p Sleep mode                                                     |      |
|                                        | at Predetermined Time (Zoom In)                                  |      |
|                                        | after Predetermined Time (Zoom In)                               |      |
|                                        | at Predetermined Time (Zoom Out)                                 |      |
|                                        | Due to External Event                                            |      |
|                                        | gram                                                             |      |
|                                        | Drawinge Drawing                                                 |      |
| Tables                                 |                                                                  |      |
| Table 1: DA14531-0x Product Variants   | Differentiation                                                  | 21   |
| Table 2: DA14531 WLCSP17 Ball Des      | cription                                                         | 23   |
| Table 3: DA14531 FCGQFN24 Pin Des      | scription                                                        | 26   |
|                                        |                                                                  |      |
|                                        | nditions                                                         |      |
|                                        |                                                                  |      |
| Table 7: Timing Characteristics        |                                                                  | 35   |
|                                        | acteristics                                                      |      |
|                                        | ommended Operating Conditions                                    |      |
|                                        | ommended Operating Conditionsing Characteristics                 |      |
|                                        | Characteristics                                                  |      |
|                                        | ended Operating Conditions                                       |      |
|                                        | acteristics                                                      |      |
|                                        | Operating Conditions                                             |      |
|                                        | tics                                                             |      |
|                                        | Operating Conditions                                             |      |
| Table 18: Digital Pad - DC Characteris | tics                                                             | 40   |
|                                        | naracteristics                                                   |      |
| Table 20: Digital Pad with LPF - Recon | mmended Operating Conditions                                     | 40   |
|                                        | racteristics                                                     |      |
|                                        | racteristics                                                     |      |
|                                        | perating Conditions                                              |      |
| Table 24: GP ADC - DC Characteristic   | S                                                                | 41   |
| Datasheet                              | Revision 3.6 26-Sep-                                             | 2022 |



| Ultra LC        | ow Power Bluetooth 5.1 Soc                                          | i iiia      |
|-----------------|---------------------------------------------------------------------|-------------|
| Table 25:       | GP ADC - Electrical performance                                     | 42          |
| Table 26:       | Temperature Sensor - DC Characteristics                             | 42          |
| Table 27:       | BLE 1Mb/s specifications - Recommended Operating Conditions         | 43          |
|                 | BLE 1Mb/s specifications - AC Characteristics                       |             |
|                 | BLE 1Mb/s specifications - Timing Characteristics                   |             |
|                 | BLE 1Mb/s specifications - DC Characteristics                       |             |
|                 | Power Domains Description                                           |             |
|                 | Power Modes, Digital Power Domains, Clocks, and Wake-up Triggers    |             |
|                 | Power Rails Drivers and Voltages                                    |             |
|                 | VDD_Clamp Recommended Settings over Temperature and Load            |             |
|                 | Retainable Registers                                                |             |
|                 | OTP Header                                                          |             |
| Table 37:       | CS Commands and Description                                         | 64          |
| Table 38:       | CS Example                                                          | 65          |
| Table 39:       | Booting Sequence Steps                                              | 68          |
| Table 40:       | Reset Signals and Registers                                         | 70          |
| Table 41:       | Interrupt List                                                      | 74          |
| Table 42:       | Arm Documents List                                                  | 76          |
| Table 43:       | Memory Map                                                          | 79          |
|                 | Generated Clocks Description                                        |             |
|                 | DMA Served Peripherals                                              |             |
|                 | I2C Definition of Bits in First Byte in 10-bit Address Format       |             |
|                 | UART Baud Rate Generation                                           |             |
|                 | UART Interrupt Priorities                                           |             |
| Table 49:       | SPI Modes Configuration and SCK States                              | 114         |
|                 | SPI Timing Parameters                                               |             |
|                 | Fixed Assignment of Specific Signals                                |             |
|                 | ADC Input Channels                                                  |             |
|                 | GPADC External Input Channels and Voltage Range                     |             |
| Table 54:       | ADC_LDO Start-Up Delay                                              | 151         |
| Table 55:       | ADC Sampling Time Constant (TADC_SMPL)                              | 152         |
|                 | ENOB in Oversampling Mode                                           |             |
|                 | GPADC Calibration Procedure for Single-Ended and Differential Modes |             |
|                 | Common Mode Adjustment                                              |             |
|                 | Register map ANAMISC                                                |             |
|                 | CLK_REF_SEL_REG (0x50001600)                                        |             |
|                 | CLK_REF_CNT_REG (0x50001602)                                        |             |
|                 | CLK_REF_VAL_L_REG (0x50001604)                                      |             |
|                 | CLK_REF_VAL_H_REG (0x50001606)                                      |             |
| Table 64:       | Register map BLE                                                    | 170         |
|                 | BLE_RWBLECNTL_REG (0x40000000)                                      |             |
| Table 66:       | BLE_VERSION_REG (0x40000004)                                        | 1/3         |
| Table 67:       | BLE_RWBLECONF_REG (0x40000008)                                      | 1/4         |
| Table 68:       | BLE_INTCNTL_REG (0x4000000C)                                        | 174         |
| Table 59.       | BLE_INTSTAT_REG (0x40000010)                                        | 170<br>176  |
| Table 70.       | BLE_INTACK_REG (0x40000014)                                         | 170         |
| Table 71.       | BLE_BASETIMECNT_REG (0x40000016)                                    | 1 <i>11</i> |
|                 | BLE_FINETIMECNT_REG (0x4000001C)                                    |             |
|                 | BLE_BDADDRL_REG (0x40000024)                                        |             |
|                 | BLE_BDADDRU_REG (0x40000024)                                        |             |
|                 | BLE_CURRENTRXDESCPTR_REG (0x4000002C)                               |             |
|                 | BLE_DEEPSLCNTL_REG (0x40000030)                                     |             |
|                 | BLE_DEEPSLCNTL_REG (0x40000030)                                     |             |
|                 | BLE_DEEPSLYROP_REG (0x40000034)                                     |             |
|                 | BLE_ENBPRESET_REG (0x4000003C)                                      |             |
|                 | BLE_FINECNTCORR_REG (0x4000003C)                                    |             |
|                 | BLE_BASETIMECNTCORR_REG (0x40000044)                                |             |
|                 | BLE_DIAGCNTL_REG (0x40000050)                                       |             |
|                 | ,                                                                   |             |
| <b>Datashee</b> | et Revision 3.6 26-Se                                               | p-2022      |



| Ultra Low Power Bluetooth 5.1 SoC            | Final       |
|----------------------------------------------|-------------|
| Table 84: BLE_DIAGSTAT_REG (0x40000054)      | 181         |
| Table 85: BLE_DEBUGADDMAX_REG (0x40000058)   |             |
| Table 86: BLE_DEBUGADDMIN_REG (0x4000005C)   |             |
| Table 87: BLE_ERRORTYPESTAT_REG (0x40000060) |             |
| Table 88: BLE_SWPROFILING_REG (0x40000064)   |             |
| Table 89: BLE_RADIOCNTL1_REG (0x40000074)    |             |
| Table 90: BLE_RADIOPWRUPDN_REG (0x40000080)  |             |
| Table 91: BLE_ADVCHMAP_REG (0x40000090)      |             |
| Table 92: BLE_ADVTIM_REG (0x400000A0)        |             |
| Table 93: BLE_ACTSCANSTAT_REG (0x400000A4)   |             |
| Table 94: BLE_WLPUBADDPTR_REG (0x400000B0)   |             |
| Table 95: BLE_WLPRIVADDPTR_REG (0x400000B4)  |             |
| Table 96: BLE_WLNBDEV_REG (0x400000B8)       | 185         |
| Table 97: BLE_AESCNTL_REG (0x400000C0)       |             |
| Table 98: BLE_AESKEY31_0_REG (0x400000C4)    |             |
| Table 99: BLE_AESKEY63_32_REG (0x400000C8)   |             |
| Table 100: BLE_AESKEY95_64_REG (0x400000CC)  |             |
| Table 101: BLE_AESKEY127_96_REG (0x400000D0) |             |
| Table 102: BLE_AESPTR_REG (0x400000D4)       |             |
| Table 103: BLE_TXMICVAL_REG (0x400000D8)     |             |
| Table 104: BLE_RXMICVAL_REG (0x40000DC)      |             |
| Table 105: BLE_RFTESTCNTL_REG (0x400000E0)   |             |
| Table 106: BLE_RFTESTTXSTAT_REG (0x400000E4) |             |
| Table 107: BLE_RFTESTRXSTAT_REG (0x400000E8) |             |
| Table 108: BLE_TIMGENCNTL_REG (0x400000F0)   | 188         |
| Table 109: BLE_GROSSTIMTGT_REG (0x400000F4)  | 188         |
| Table 110: BLE_FINETIMTGT_REG (0x400000F8)   | 188         |
| Table 111: BLE_SAMPLECLK_REG (0x400000FC)    | 188         |
| Table 112: BLE_COEXIFCNTL0_REG (0x40000100)  |             |
| Table 113: BLE_COEXIFCNTL1_REG (0x40000104)  |             |
| Table 114: BLE_BLEMPRIO0_REG (0x40000108)    |             |
| Table 115: BLE_BLEMPRIO1_REG (0x4000010C)    |             |
| Table 116: BLE_CNTL2_REG (0x40000200)        |             |
| Table 117: BLE_EM_BASE_REG (0x40000208)      |             |
| Table 118: BLE_DIAGCNTL2_REG (0x4000020C)    |             |
| Table 119: BLE_DIAGCNTL3_REG (0x40000210)    |             |
| Table 120: Register map CRG                  |             |
| Table 121: CLK_AMBA_REG (0x50000000)         |             |
| Table 122: CLK_FREQ_TRIM_REG (0x50000002)    |             |
| Table 123: CLK_PER_REG (0x50000004)          |             |
| Table 124: CLK_RADIO_REG (0x50000008)        |             |
| Table 125: CLK_CTRL_REG (0x5000000A)         |             |
| Table 126: PMU_CTRL_REG (0x50000010)         |             |
| Table 127: SYS_CTRL_REG (0x50000012)         |             |
| Table 128: SYS_STAT_REG (0x50000014)         |             |
| Table 129: TRIM_CTRL_REG (0x50000016)        |             |
| Table 130: RAM_PWR_CTRL_REG (0x50000018)     |             |
| Table 131: CLK_RC32K_REG (0x50000020)        |             |
| Table 132: CLK_XTAL32K_REG (0x50000022)      |             |
| Table 133: CLK_RC32M_REG (0x50000024)        |             |
| Table 134: CLK_RCX_REG (0x50000024)          |             |
| Table 135: BANDGAP_REG (0x50000028)          |             |
| Table 136: ANA_STATUS_REG (0x5000002A)       |             |
| Table 137: XTAL32M_START_REG (0x5000002A)    |             |
| Table 138: XTALRDY_CTRL_REG (0x50000034)     |             |
| Table 139: XTAL32M_CTRL0_REG (0x50000034)    |             |
| Table 140: POR_PIN_REG (0x50000040)          |             |
| Table 141: POR_TIMER_REG (0x50000042)        |             |
| Table 142: PMU_SLEEP_REG (0x50000050)        |             |
| · · · · · · · · · · · · · · · · · · ·        |             |
| Datasheet Revision 3.6                       | 26-Sep-2022 |



| Ultra Low Power Bluetooth 5.1 SoC            | Final      |
|----------------------------------------------|------------|
| Table 143: POWER_CTRL_REG (0x50000052)       | 204        |
| Table 144: POWER_LEVEL_REG (0x50000054)      | 205        |
| Table 145: XTAL32M_TRSTAT_REG (0x50000032)   | 206        |
| Table 146: Register map CRG_TIM              | 206        |
| Table 147: CLK_RTCDIV_REG (0x5000424C)       | 206        |
| Table 148: Register map DCDC                 | 208        |
| Table 149: DCDC_CTRL_REG (0x50000080)        | 208        |
| Table 150: Register map DMA                  |            |
| Table 151: DMA0_A_STARTL_REG (0x50003600)    | 211        |
| Table 152: DMA0_A_STARTH_REG (0x50003602)    |            |
| Table 153: DMA0_B_STARTL_REG (0x50003604)    |            |
| Table 154: DMA0_B_STARTH_REG (0x50003606)    |            |
| Table 155: DMA0_INT_REG (0x50003608)         |            |
| Table 156: DMA0_LEN_REG (0x5000360A)         |            |
| Table 157: DMA0_CTRL_REG (0x5000360C)        |            |
| Table 158: DMA0_IDX_REG (0x5000360E)         |            |
| Table 159: DMA1_A_STARTL_REG (0x50003610)    |            |
| Table 160: DMA1_A_STARTH_REG (0x50003612)    | 214        |
| Table 161: DMA1_B_STARTL_REG (0x50003614)    |            |
| Table 162: DMA1_B_STARTH_REG (0x50003616)    |            |
| Table 163: DMA1_INT_REG (0x50003618)         |            |
| Table 164: DMA1_CEN_REG (0x5000361A)         |            |
| Table 166: DMA1_IDX_REG (0x5000361E)         | 216        |
| Table 167: DMA2_A_STARTL_REG (0x50003612)    | 216<br>216 |
| Table 168: DMA2_A_STARTH_REG (0x50003622)    |            |
| Table 169: DMA2_B_STARTL_REG (0x50003624)    |            |
| Table 170: DMA2_B_STARTH_REG (0x50003626)    |            |
| Table 171: DMA2_INT_REG (0x50003628)         |            |
| Table 172: DMA2_LEN_REG (0x5000362A)         |            |
| Table 173: DMA2_CTRL_REG (0x5000362C)        |            |
| Table 174: DMA2_IDX_REG (0x5000362E)         |            |
| Table 175: DMA3_A_STARTL_REG (0x50003630)    | 219        |
| Table 176: DMA3_A_STARTH_REG (0x50003632)    |            |
| Table 177: DMA3_B_STARTL_REG (0x50003634)    |            |
| Table 178: DMA3_B_STARTH_REG (0x50003636)    |            |
| Table 179: DMA3_INT_REG (0x50003638)         |            |
| Table 180: DMA3_LEN_REG (0x5000363A)         |            |
| Table 181: DMA3_CTRL_REG (0x5000363C)        |            |
| Table 182: DMA3_IDX_REG (0x5000363E)         | 222        |
| Table 183: DMA_REQ_MUX_REG (0x50003660)      |            |
| Table 185: DMA_CLEAR_INT_REG (0x50003684)    |            |
| Table 186: Register map GPADC                |            |
| Table 187: GP_ADC_CTRL_REG (0x50001500)      | 224        |
| Table 188: GP_ADC_CTRL2_REG (0x50001502)     |            |
| Table 189: GP_ADC_CTRL3_REG (0x50001504)     |            |
| Table 190: GP_ADC_OFFP_REG (0x50001508)      |            |
| Table 191: GP_ADC_OFFN_REG (0x5000150A)      | 226        |
| Table 192: GP_ADC_TRIM_REG (0x5000150C)      | 226        |
| Table 193: GP_ADC_CLEAR_INT_REG (0x5000150E) | 227        |
| Table 194: GP_ADC_RESULT_REG (0x50001510)    |            |
| Table 195: GP_ADC_SEL_REG (0x50001506)       | 227        |
| Table 196: Register map GPIO                 |            |
| Table 197: P0_DATA_REG (0x50003000)          |            |
| Table 198: P0_SET_DATA_REG (0x50003002)      |            |
| Table 199: P0_RESET_DATA_REG (0x50003004)    |            |
| Table 200: P00_MODE_REG (0x50003006)         |            |
| Table 201: P01_MODE_REG (0x50003008)         | 231        |
| Datasheet Revision 3.6 26-                   | Sep-2022   |



| Ultra Low Power Bluetooth 5.1 SoC                | Final  |
|--------------------------------------------------|--------|
| Table 202: P02_MODE_REG (0x5000300A)             | 231    |
| Table 203: P03_MODE_REG (0x5000300C)             | 231    |
| Table 204: P04_MODE_REG (0x5000300E)             | 232    |
| Table 205: P05_MODE_REG (0x50003010)             | 232    |
| Table 206: P06_MODE_REG (0x50003012)             | 232    |
| Table 207: P07_MODE_REG (0x50003014)             | 233    |
| Table 208: P08_MODE_REG (0x50003016)             | 233    |
| Table 209: P09_MODE_REG (0x50003018)             | 233    |
| Table 210: P010_MODE_REG (0x5000301A)            |        |
| Table 211: P011_MODE_REG (0x5000301C)            |        |
| Table 212: PAD_WEAK_CTRL_REG (0x5000301E)        |        |
| Table 213: Register map GPREG                    | 235    |
| Table 214: SET_FREEZE_REG (0x50003300)           |        |
| Table 215: RESET_FREEZE_REG (0x50003302)         |        |
| Table 216: DEBUG_REG (0x50003304)                |        |
| Table 217: GP_STATUS_REG (0x50003306)            |        |
| Table 218: GP_CONTROL_REG (0x50003308)           |        |
| Table 219: BLE_TIMER_REG (0x5000330A)            |        |
| Table 220: Register map I2C                      |        |
| Table 221: I2C_CON_REG (0x50001300)              |        |
| Table 222: I2C_TAR_REG (0x50001304)              |        |
| Table 223: I2C_SAR_REG (0x50001308)              |        |
| Table 224: I2C_DATA_CMD_REG (0x50001310)         |        |
| Table 226: I2C_SS_SCL_HCNT_REG (0x50001314)      |        |
| Table 220: I2C_SS_SCL_LCNT_REG (0x50001316)      |        |
| Table 228: I2C_FS_SCL_LCNT_REG (0x50001310)      |        |
| Table 229: I2C_INTR_STAT_REG (0x5000132C)        |        |
| Table 230: I2C_INTR_MASK_REG (0x50001330)        |        |
| Table 231: I2C_RAW_INTR_STAT_REG (0x50001334)    |        |
| Table 232: I2C_RX_TL_REG (0x50001338)            |        |
| Table 233: I2C_TX_TL_REG (0x5000133C)            |        |
| Table 234: I2C_CLR_INTR_REG (0x50001340)         |        |
| Table 235: I2C_CLR_RX_UNDER_REG (0x50001344)     | 249    |
| Table 236: I2C_CLR_RX_OVER_REG (0x50001348)      |        |
| Table 237: I2C_CLR_TX_OVER_REG (0x5000134C)      |        |
| Table 238: I2C_CLR_RD_REQ_REG (0x50001350)       |        |
| Table 239: I2C_CLR_TX_ABRT_REG (0x50001354)      |        |
| Table 240: I2C_CLR_RX_DONE_REG (0x50001358)      |        |
| Table 241: I2C_CLR_ACTIVITY_REG (0x5000135C)     | 250    |
| Table 242: I2C_CLR_STOP_DET_REG (0x50001360)     |        |
| Table 243: I2C_CLR_START_DET_REG (0x50001364)    |        |
| Table 244: I2C_CLR_GEN_CALL_REG (0x50001368)     |        |
| Table 245: I2C_ENABLE_REG (0x5000136C)           |        |
| Table 246: I2C_STATUS_REG (0x50001370)           |        |
| Table 247: I2C_TXFLR_REG (0x50001374)            |        |
| Table 248: I2C_RXFLR_REG (0x50001378)            |        |
| Table 250: I2C_TX_ABRT_SOURCE_REG (0x50001376)   | 253    |
| Table 251: I2C_DMA_CR_REG (0x50001388)           |        |
| Table 251: I2C_DMA_CIN_REG (0x50001386)          |        |
| Table 253: I2C_DMA_RDLR_REG (0x50001300)         |        |
| Table 254: I2C_SDA_SETUP_REG (0x50001394)        |        |
| Table 255: I2C_ACK_GENERAL_CALL_REG (0x50001398) |        |
| Table 256: I2C_ENABLE_STATUS_REG (0x5000139C)    |        |
| Table 257: I2C_IC_FS_SPKLEN_REG (0x500013A0)     |        |
| Table 258: Register map KBRD                     |        |
| Table 259: GPIO_IRQ0_IN_SEL_REG (0x50001400)     |        |
| Table 260: GPIO_IRQ1_IN_SEL_REG (0x50001402)     |        |
| Datasheet Revision 3.6 26-Sep                    | )-2022 |
|                                                  |        |



| Ultra Low Power Bluetooth 5.1 SoC                 | Final       |
|---------------------------------------------------|-------------|
| Table 261: GPIO_IRQ2_IN_SEL_REG (0x50001404)      | 259         |
| Table 262: GPIO_IRQ3_IN_SEL_REG (0x50001406)      |             |
| Table 263: GPIO_IRQ4_IN_SEL_REG (0x50001408)      |             |
| Table 264: GPIO_DEBOUNCE_REG (0x5000140C)         |             |
| Table 265: GPIO_RESET_IRQ_REG (0x5000140E)        |             |
| Table 266: GPIO_INT_LEVEL_CTRL_REG (0x50001410)   |             |
| Table 267: KBRD_IRQ_IN_SEL0_REG (0x50001412)      |             |
| Table 268: KBRD_CTRL_REG (0x50001414)             |             |
| Table 269: Register map CRG_AON                   |             |
| Table 270: HWR_CTRL_REG (0x50000300)              |             |
| Table 271: RESET_STAT_REG (0x50000304)            |             |
| Table 272: RAM_LPMX_REG (0x50000308)              |             |
| Table 273: PAD_LATCH_REG (0x5000030C)             |             |
| Table 274: HIBERN_CTRL_REG (0x50000310)           |             |
| Table 275: POWER_AON_CTRL_REG (0x50000320)        |             |
| Table 276: GP_DATA_REG (0x50000324)               |             |
| Table 277: Register map OTPC                      |             |
| Table 278: OTPC_MODE_REG (0x07F40000)             |             |
| Table 279: OTPC_STAT_REG (0x07F40004)             |             |
| Table 280: OTPC_PADDR_REG (0x07F40008)            |             |
| Table 281: OTPC_PWORD_REG (0x07F4000C)            |             |
| Table 282: OTPC TIM1 REG (0x07F40010)             |             |
| Table 283: OTPC_TIM2_REG (0x07F40014)             |             |
| Table 284: OTPC_AHBADR_REG (0x07F40018)           |             |
| Table 285: OTPC_CELADR_REG (0x07F4001C)           |             |
| Table 286: OTPC_NWORDS_REG (0x07F40020)           |             |
| Table 287: Register map QDEC                      |             |
| Table 288: QDEC_CTRL_REG (0x50000200)             |             |
| Table 289: QDEC_XCNT_REG (0x50000202)             |             |
| Table 290: QDEC_YCNT_REG (0x50000204)             |             |
| Table 291: QDEC_CLOCKDIV_REG (0x50000206)         |             |
| Table 292: QDEC_CTRL2_REG (0x50000208)            |             |
| Table 293: QDEC_ZCNT_REG (0x5000020A)             |             |
| Table 294: QDEC_EVENT_CNT_REG (0x5000020C)        |             |
| Table 295: Register map RTC                       |             |
| Table 296: RTC_CONTROL_REG (0x50004100)           | 274         |
| Table 297: RTC HOUR MODE REG (0x50004104)         | 274         |
| Table 298: RTC_TIME_REG (0x50004108)              | 275         |
| Table 299: RTC_CALENDAR_REG (0x5000410C)          | 275         |
| Table 300: RTC_TIME_ALARM_REG (0x50004110)        |             |
| Table 301: RTC CALENDAR ALARM REG (0x50004114)    |             |
| Table 302: RTC_ALARM_ENABLE_REG (0x50004118)      | 276         |
| Table 303: RTC_EVENT_FLAGS_REG (0x5000411C)       | 277         |
| Table 304: RTC_INTERRUPT_ENABLE_REG (0x50004120)  |             |
| Table 305: RTC_INTERRUPT_DISABLE_REG (0x50004124) |             |
| Table 306: RTC_INTERRUPT_MASK_REG (0x50004128)    |             |
| Table 307: RTC_STATUS_REG (0x5000412C)            |             |
| Table 308: RTC_KEEP_RTC_REG (0x50004130)          |             |
| Table 309: Register map SPI                       | 280         |
| Table 310: SPI_CTRL_REG (0x50001200)              | 280         |
| Table 311: SPI_CONFIG_REG (0x50001204)            |             |
| Table 312: SPI_CLOCK_REG (0x50001208)             | 281         |
| Table 313: SPI_FIFO_CONFIG_REG (0x5000120C)       | 282         |
| Table 314: SPI_IRQ_MASK_REG (0x50001210)          | 282         |
| Table 315: SPI_STATUS_REG (0x50001214)            |             |
| Table 316: SPI_FIFO_STATUS_REG (0x50001218)       |             |
| Table 317: SPI_FIFO_READ_REG (0x5000121C)         |             |
| Table 318: SPI_FIFO_WRITE_REG (0x50001220)        |             |
| Table 319: SPI_CS_CONFIG_REG (0x50001224)         |             |
| · · · · · · · · · · · · · · · · · · ·             |             |
| Datasheet Revision 3.6                            | 26-Sep-2022 |



| Ultra Low Power Bluetooth 5.1 SoC                | Final       |
|--------------------------------------------------|-------------|
| Table 320: SPI_FIFO_HIGH_REG (0x50001228)        | 283         |
| Table 321: SPI_TXBUFFER_FORCE_L_REG (0x5000122C) |             |
| Table 322: SPI_TXBUFFER_FORCE_H_REG (0x50001230) |             |
| Table 323: Register map Timer+3PWM               | 285         |
| Table 324: TIMER0_CTRL_REG (0x50003400)          | 285         |
| Table 325: TIMER0_ON_REG (0x50003402)            | 286         |
| Table 326: TIMERO_RELOAD_M_REG (0x50003404)      |             |
| Table 327: TIMERO_RELOAD_N_REG (0x50003406)      |             |
| Table 328: TRIPLE_PWM_FREQUENCY (0x50003408)     |             |
| Table 329: PWM2_START_CYCLE (0x5000340A)         |             |
| Table 330: PWM3_START_CYCLE (0x5000340C)         |             |
| Table 331: PWM4_START_CYCLE (0x5000340E)         |             |
| Table 332: PWM5_START_CYCLE (0x50003410)         |             |
| Table 333: PWM6_START_CYCLE (0x50003412)         |             |
| Table 334: PWM7_START_CYCLE (0x50003414)         |             |
| Table 335: PWM2_END_CYCLE (0x50003416)           |             |
| Table 336: PWM3_END_CYCLE (0x50003418)           | 288         |
| Table 337: PWM4_END_CYCLE (0x5000341A)           |             |
| Table 338: PWM5_END_CYCLE (0x5000341C)           |             |
| Table 339: PWM6_END_CYCLE (0x5000341E)           |             |
| Table 340: PWM7_END_CYCLE (0x50003420)           |             |
| Table 341: TRIPLE_PWM_CTRL_REG (0x50003422)      |             |
| Table 342: Register map Timer1                   |             |
| Table 343: TIMER1_CTRL_REG (0x50004000)          |             |
| Table 344: TIMER1_CAPTURE_REG (0x50004004)       |             |
| Table 345: TIMER1_STATUS_REG (0x50004008)        |             |
| Table 346: TIMER1_CAPCNT1_VALUE_REG (0x5000400C) |             |
| Table 347: TIMER1_CAPCNT2_VALUE_REG (0x50004010) |             |
| Table 348: TIMER1_CLR_EVENT_REG (0x50004014)     |             |
| Table 349: Register map UART                     | 292         |
| Table 350: UART_RBR_THR_DLL_REG (0x50001000)     | 294         |
| Table 351: UART_IER_DLH_REG (0x50001004)         | 295         |
| Table 352: UART_IIR_FCR_REG (0x50001008)         | 297         |
| Table 353: UART_LCR_REG (0x5000100C)             | 298         |
| Table 354: UART_MCR_REG (0x50001010)             | 299         |
| Table 355: UART_LSR_REG (0x50001014)             | 300         |
| Table 356: UART_MSR_REG (0x50001018)             |             |
| Table 357: UART_SCR_REG (0x5000101C)             | 303         |
| Table 358: UART_SRBR_STHR0_REG (0x50001030)      |             |
| Table 359: UART_SRBR_STHR1_REG (0x50001034)      | 304         |
| Table 360: UART_SRBR_STHR2_REG (0x50001038)      |             |
| Table 361: UART_SRBR_STHR3_REG (0x5000103C)      | 305         |
| Table 362: UART_SRBR_STHR4_REG (0x50001040)      | 306         |
| Table 363: UART_SRBR_STHR5_REG (0x50001044)      |             |
| Table 364: UART_SRBR_STHR6_REG (0x50001048)      |             |
| Table 365: UART_SRBR_STHR7_REG (0x5000104C)      | 308         |
| Table 366: UART_SRBR_STHR8_REG (0x50001050)      | 309         |
| Table 367: UART_SRBR_STHR9_REG (0x50001054)      | 310         |
| Table 368: UART_SRBR_STHR10_REG (0x50001058)     |             |
| Table 369: UART_SRBR_STHR11_REG (0x5000105C)     |             |
| Table 370: UART_SRBR_STHR12_REG (0x50001060)     |             |
| Table 371: UART_SRBR_STHR13_REG (0x50001064)     |             |
| Table 372: UART_SRBR_STHR14_REG (0x50001068)     |             |
| Table 373: UART_SRBR_STHR15_REG (0x5000106C)     |             |
| Table 374: UART_FAR_REG (0x50001070)             |             |
| Table 375: UART_USR_REG (0x5000107C)             |             |
| Table 376: UART_TFL_REG (0x50001080)             |             |
| Table 377: UART_RFL_REG (0x50001084)             |             |
| Table 378: UART_SRR_REG (0x50001088)             | 317         |
| Datasheet Revision 3.6                           | 26-Sep-2022 |
|                                                  |             |



| Ultra Low Power Bluetooth 5.1 SoC             | Final       |
|-----------------------------------------------|-------------|
| Table 379: UART_SRTS_REG (0x5000108C)         | 317         |
| Table 380: UART_SBCR_REG (0x50001090)         | 318         |
| Table 381: UART_SDMAM_REG (0x50001094)        | 318         |
| Table 382: UART_SFE_REG (0x50001098)          | 318         |
| Table 383: UART_SRT_REG (0x5000109C)          | 319         |
| Table 384: UART_STET_REG (0x500010A0)         | 319         |
| Table 385: UART_HTX_REG (0x500010A4)          | 320         |
| Table 386: UART_DMASA_REG (0x500010A8)        | 320         |
| Table 387: UART_DLF_REG (0x500010C0)          |             |
| Table 388: UART_UCV_REG (0x500010F8)          |             |
| Table 389: UART_UCV_HIGH_REG (0x500010FA)     |             |
| Table 390: UART_CTR_REG (0x500010FC)          | 320         |
| Table 391: UART_CTR_HIGH_REG (0x500010FE)     |             |
| Table 392: UART2_RBR_THR_DLL_REG (0x50001100) |             |
| Table 393: UART2_IER_DLH_REG (0x50001104)     |             |
| Table 394: UART2_IIR_FCR_REG (0x50001108)     |             |
| Table 395: UART2_LCR_REG (0x5000110C)         |             |
| Table 396: UART2_MCR_REG (0x50001110)         |             |
| Table 397: UART2_LSR_REG (0x50001114)         |             |
| Table 398: UART2_SCR_REG (0x5000111C)         |             |
| Table 399: UART2_SRBR_STHR0_REG (0x50001130)  |             |
| Table 400: UART2_SRBR_STHRT_REG (0x50001134)  |             |
| Table 401: UART2_SRBR_STHR2_REG (0x50001136)  |             |
| Table 403: UART2_SRBR_STHR4_REG (0x50001130)  |             |
| Table 404: UART2_SRBR_STHR5_REG (0x50001144)  |             |
| Table 405: UART2_SRBR_STHR6_REG (0x50001144)  |             |
| Table 406: UART2_SRBR_STHR7_REG (0x5000114C)  |             |
| Table 407: UART2_SRBR_STHR8_REG (0x50001150)  |             |
| Table 408: UART2_SRBR_STHR9_REG (0x50001154)  |             |
| Table 409: UART2_SRBR_STHR10_REG (0x50001158) |             |
| Table 410: UART2_SRBR_STHR11_REG (0x5000115C) |             |
| Table 411: UART2_SRBR_STHR12_REG (0x50001160) | 338         |
| Table 412: UART2_SRBR_STHR13_REG (0x50001164) |             |
| Table 413: UART2_SRBR_STHR14_REG (0x50001168) |             |
| Table 414: UART2_SRBR_STHR15_REG (0x5000116C) |             |
| Table 415: UART2_FAR_REG (0x50001170)         | 341         |
| Table 416: UART2_USR_REG (0x5000117C)         |             |
| Table 417: UART2_TFL_REG (0x50001180)         |             |
| Table 418: UART2_RFL_REG (0x50001184)         |             |
| Table 420: UART2_SRC_REG (0x50001180)         |             |
| Table 421: UART2_SDMAM_REG (0x50001194)       |             |
| Table 422: UART2_SFE_REG (0x50001198)         |             |
| Table 423: UART2_SRT_REG (0x5000119C)         |             |
| Table 424: UART2_STET_REG (0x500011A0)        |             |
| Table 425: UART2_HTX_REG (0x500011A4)         |             |
| Table 426: UART2_DMASA_REG (0x500011A8)       |             |
| Table 427: UART2_DLF_REG (0x500011C0)         |             |
| Table 428: UART2_UCV_REG (0x500011F8)         | 345         |
| Table 429: UART2_UCV_HIGH_REG (0x500011FA)    |             |
| Table 430: UART2_CTR_REG (0x500011FC)         |             |
| Table 431: UART2_CTR_HIGH_REG (0x500011FE)    |             |
| Table 432: Register map Version               |             |
| Table 433: CHIP_ID1_REG (0x50003200)          |             |
| Table 434: CHIP_ID2_REG (0x50003204)          |             |
| Table 435: CHIP_ID3_REG (0x50003208)          |             |
| Table 436: CHIP_ID4_REG (0x5000320C)          |             |
| Table 437: Register map WKUP                  | 347         |
| Datasheet Revision 3.6                        | 26-Sep-2022 |

# **DA14531**



| Ultra Low Power Bluetooth 5.1 SoC             | Final |
|-----------------------------------------------|-------|
| Table 438: WKUP_CTRL_REG (0x50000100)         | 347   |
| Table 439: WKUP_COMPARE_REG (0x50000102)      | 347   |
| Table 440: WKUP_IRQ_STATUS_REG (0x50000104)   |       |
| Table 441: WKUP_COUNTER_REG (0x50000106)      |       |
| Table 442: WKUP_SELECT_GPIO_REG (0x50000108)  | 348   |
| Table 443: WKUP2_SELECT_GPIO_REG (0x5000010A) |       |
| Table 444: WKUP_POL_GPIO_REG (0x5000010C)     | 348   |
| Table 445: WKUP2_POL_GPIO_REG (0x5000010E)    | 349   |
| Table 446: Register map WDOG                  | 350   |
| Table 447: WATCHDOG_REG (0x50003100)          | 350   |
| Table 448: WATCHDOG_CTRL_REG (0x50003102)     | 350   |
| Table 449: Ordering Information (Samples)     |       |
| Table 450: Ordering Information (Production)  |       |
| Table 451: MSL Classification                 |       |



# 1 Block Diagram



Figure 2: DA14531 Block Diagram

Datasheet Revision 3.6 26-Sep-2022



**Final** 

### 2 DA14531-0x Product Variants

Table 1 presents the differentiation among the variants of the DA14531-0x.

**Table 1: DA14531-0x Product Variants Differentiation** 

| Features                                       | DA14531-00 | DA14531-01 |
|------------------------------------------------|------------|------------|
| LE Central support                             | ✓          | ×          |
| LE Observer support                            | ✓          | ×          |
| Generation of Private addresses support        | ✓          | ×          |
| LL 2/5 Resolution of Private addresses support | ✓          | ×          |
| Compatible with SDK 6.0.16 or lower            | ✓          | ×          |
| Rest of features                               | ✓          | ✓          |



**Final** 

# 3 Packages and Pinout

The DA14531 comes in two packages:

- A Wafer Level Chip Scale Package (WLCSP) with 17 balls
- A Quad Flat Package No Leads (FCGQFN) with 24 pins

The actual pin/ball assignment is depicted in the following sections.

#### 3.1 WLCSP17



Figure 3: WLCSP17 Ball Assignment (Top View)



**Final** 

### Table 2: DA14531 WLCSP17 Ball Description

| Ball<br>no. | Pin Name         | Туре         | Reset<br>State | Description                                                                                                                                                                                                                                                                           |
|-------------|------------------|--------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Gene        | eral Purpose I/O | s (Note 3)   | •              |                                                                                                                                                                                                                                                                                       |
| F4          | P0_0             | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power-down.                                                                      |
|             | RST              | DIO (Type B) |                | RST active high hardware reset (default).                                                                                                                                                                                                                                             |
| E5          | P0_1             | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
|             | ADC0             | AI           |                | INPUT. Analog to Digital Converter input 0.                                                                                                                                                                                                                                           |
|             | SWDIO            | DIO          |                | INPUT/OUTPUT. JTAG Data input/output. Bidirectional data and control communication.                                                                                                                                                                                                   |
| C5          | P0_2             | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
|             | ADC1             | AI           |                | INPUT. Analog to Digital Converter input 1.                                                                                                                                                                                                                                           |
|             | SWCLK            | DIO          |                | INPUT JTAG clock signal (by default).                                                                                                                                                                                                                                                 |
| B4          | P0_3             | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down. Check GP_DATA_REG[P03_P04_FILT_DIS] for correct pad filter settings. |
|             | XTAL32kp         | AI           |                | INPUT. Analog input of the XTAL32K crystal oscillator.                                                                                                                                                                                                                                |
|             |                  | DI           |                | INPUT. Digital input for an external clock (square wave).                                                                                                                                                                                                                             |
| A5          | P0_4             | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down. Check GP_DATA_REG[P03_P04_FILT_DIS] for correct pad filter settings. |
|             | XTAL32km         | AO           |                | OUTPUT. Analog output of the XTAL32K crystal oscillator.                                                                                                                                                                                                                              |
| D4          | P0_5             | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
|             | SWDIO            | DIO          |                | INPUT/OUTPUT. JTAG Data input/output. Bidirectional data and control communication (by default).                                                                                                                                                                                      |
| Debu        | ıg Interface     | •            |                |                                                                                                                                                                                                                                                                                       |



| Ball<br>no. | Pin Name        | Туре     | Reset<br>State | Description                                                                                                                                                                                                                                                                               |
|-------------|-----------------|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| E5<br>D4    | SWDIO           | DIO      | I-PD           | INPUT/OUTPUT. JTAG Data input/output. Bidirectional data and control communication. Mapped on P0_1 or P0_5 (P0_5 by default).                                                                                                                                                             |
| C5          | SWCLK           | DIO      | I-PD           | INPUT JTAG clock signal. Mapped on P0_2 (by default).                                                                                                                                                                                                                                     |
| Cloc        | ks              |          |                |                                                                                                                                                                                                                                                                                           |
| D2          | XTAL32Mp        | AI       |                | INPUT. Crystal input for the 32 MHz XTAL.                                                                                                                                                                                                                                                 |
| E1          | XTAL32Mm        | AO       |                | OUTPUT. Crystal output for the 32 MHz XTAL.                                                                                                                                                                                                                                               |
| B4          | XTAL32kp        | AI       |                | INPUT. Crystal input for the 32.768 kHz XTAL. Mapped on P0_3.                                                                                                                                                                                                                             |
| A5          | XTAL32km        | AO       |                | OUTPUT. Crystal output for the 32.768 kHz XTAL. Mapped on P0_4.                                                                                                                                                                                                                           |
| Quad        | drature Decoder |          |                |                                                                                                                                                                                                                                                                                           |
|             | QD_CHA_X        | DI       |                | INPUT. Channel A for the X axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|             | QD_CHB_X        | DI       |                | INPUT. Channel B for the X axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|             | QD_CHA_Y        | DI       |                | INPUT. Channel A for the Y axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|             | QD_CHB_Y        | DI       |                | INPUT. Channel B for the Y axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|             | QD_CHA_Z        | DI       |                | INPUT. Channel A for the Z axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|             | QD_CHB_Z        | DI       |                | INPUT. Channel B for the Z axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
| SPI E       | Bus Interface   | 1        | •              |                                                                                                                                                                                                                                                                                           |
|             | SPI_CLK         | DO       |                | INPUT/OUTPUT. SPI Clock. Mapped on Px ports.                                                                                                                                                                                                                                              |
|             | SPI_DI          | DI       |                | INPUT. SPI Data input. Mapped on Px ports (Note 1).                                                                                                                                                                                                                                       |
|             | SPI_DO          | DO       |                | OUTPUT. SPI Data output. Mapped on Px ports (Note 2).                                                                                                                                                                                                                                     |
|             | SPI_EN          | DI/DO    |                | INPUT/OUTPUT. SPI Clock enable. Mapped on Px ports.                                                                                                                                                                                                                                       |
| I2C E       | Bus Interface   | •        | J              |                                                                                                                                                                                                                                                                                           |
|             | SDA             | DIO/DIOD |                | INPUT/OUTPUT. I2C bus data with open drain port. Mapped on Px ports. The mapped Px pin is automatically configured with a pull-up resistor (25 k $\Omega$ ) when pin x is mapped to the I2C_SDA PID function.                                                                             |
|             | SCL             | DIO/DIOD |                | INPUT/OUTPUT. I2C bus Clock with open drain port. In open drain mode, SCL is monitored to support bit stretching by a slave. Mapped on Px ports. The mapped Px pin is automatically configured with a pull-up resistor (25 k $\Omega$ ) when pin x is mapped to the I2C_SCL PID function. |
| UAR         | T Interface     |          |                |                                                                                                                                                                                                                                                                                           |
|             | UTX             | DO       |                | OUTPUT. UART transmit data. Mapped on Px ports.                                                                                                                                                                                                                                           |
|             | URX             | DI       |                | INPUT. UART receive data. Mapped on Px ports.                                                                                                                                                                                                                                             |
|             | URTS            | DO       |                | OUTPUT. UART Request to Send. Mapped on Px ports.                                                                                                                                                                                                                                         |
|             | UCTS            | DI       |                | INPUT. UART Clear to Send. Mapped on Px ports.                                                                                                                                                                                                                                            |



| Ball<br>no. | Pin Name               | Туре | Reset<br>State | Description                                                                                      |
|-------------|------------------------|------|----------------|--------------------------------------------------------------------------------------------------|
|             | UTX2                   | DO   |                | OUTPUT. UART2 transmit data. Mapped on Px ports.                                                 |
|             | URX2                   | DI   |                | INPUT. UART2 receive data. Mapped on Px ports.                                                   |
| ADC         | IO Channels            |      |                |                                                                                                  |
| E5          | ADC0                   | AI   |                | INPUT. Analog to Digital Converter input 0. Mapped on P0_1.                                      |
| C5          | ADC1                   | AI   |                | INPUT. Analog to Digital Converter input 1. Mapped on P0_2.                                      |
| Radi        | o Transceiver          |      |                |                                                                                                  |
| A1          | RFIOp                  | AIO  |                | RF input/output. Impedance 50 Ω.                                                                 |
| А3          | RFIOm                  | AIO  |                | RF ground.                                                                                       |
| С3          | GND_RF1                | AIO  |                | RF ground.                                                                                       |
| C1          | GND_RF2                | AIO  |                | RF ground.                                                                                       |
| Misc        | ellaneous              |      |                |                                                                                                  |
| F4          | RST                    | DIO  |                | INPUT. Reset signal (active high). Mapped on P0_0 (by default).                                  |
| G3          | LX                     | AIO  |                | INPUT/OUTPUT. Connection for the external DC-DC converter inductor.                              |
| Powe        | er and Ground          |      |                |                                                                                                  |
| E3          | VSS                    | AIO  |                | Digital ground.                                                                                  |
| G5          | V <sub>BAT_</sub> HIGH | AIO  |                | INPUT/OUTPUT. Battery connection or DCDC output in BUCK/BOOST mode, respectively. IO-supply.     |
| G1          | V <sub>BAT_</sub> LOW  | AIO  |                | INPUT/OUTPUT. Battery connection or DCDC output in BOOST/BUCK mode, respectively. System supply. |
| F2          | GND_DCDC               | AIO  |                | DCDC ground                                                                                      |

- Note 1 Data input only. MOSI in SPI slave mode and MISO in SPI master mode.
- Note 2 Data output only. MISO in SPI slave mode and MOSI in SPI master mode.
- Note 3 The differences between Type A and Type B GPIO pads are presented in Types of GPIO Pads.

**Final** 

#### 3.2 FCGQFN24



Figure 4: FCGQFN24 Pin Assignment (Top View)

Table 3: DA14531 FCGQFN24 Pin Description

| Pin<br>no. | Pin Name                      | Туре         | Reset<br>State | Description                                                                                                                                                                                                      |  |  |
|------------|-------------------------------|--------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|            | General Purpose I/Os (Note 3) |              |                |                                                                                                                                                                                                                  |  |  |
| 10         | P0_0                          | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down. |  |  |
|            | RST                           | DIO (Type B) |                | RST active high hardware reset (default).                                                                                                                                                                        |  |  |
| 11         | P0_1                          | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down. |  |  |
|            | ADC0                          | Al           |                | INPUT. Analog to Digital Converter input 0.                                                                                                                                                                      |  |  |
| 12         | P0_2                          | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O                                                                                               |  |  |

Datasheet Revision 3.6 26-Sep-2022



| Pin<br>no. | Pin Name | Туре         | Reset<br>State | Description                                                                                                                                                                                                                                                                           |
|------------|----------|--------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |              |                | port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                                                                                                                                         |
|            | ADC1     | Al           |                | INPUT. Analog to Digital Converter input 1.                                                                                                                                                                                                                                           |
|            | SWCLK    | DIO          |                | INPUT JTAG clock signal (by default).                                                                                                                                                                                                                                                 |
| 13         | P0_3     | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down. Check GP_DATA_REG[P03_P04_FILT_DIS] for correct pad filter settings. |
|            | XTAL32kp | Al           |                | INPUT. Analog input of the XTAL32K crystal oscillator.                                                                                                                                                                                                                                |
|            |          | DI           |                | INPUT. Digital input for an external clock (square wave).                                                                                                                                                                                                                             |
| 14         | P0_4     | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down. Check GP_DATA_REG[P03_P04_FILT_DIS] for correct pad filter settings. |
|            | XTAL32km | AO           |                | OUTPUT. Analog output of the XTAL32K crystal oscillator.                                                                                                                                                                                                                              |
| 24         | P0_5     | DIO (Type B) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
| 22         | P0_6     | DIO (Type A) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
|            | ADC2     | AI           |                | INPUT. Analog to Digital Converter input 2.                                                                                                                                                                                                                                           |
| 15         | P0_7     | DIO (Type A) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
|            | ADC3     | Al           |                | INPUT. Analog to Digital Converter input 3.                                                                                                                                                                                                                                           |
| 17         | P0_8     | DIO (Type A) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
| 16         | P0_9     | DIO (Type A) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |
| 9          | P0_10    | DIO (Type A) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                      |



| Pin<br>no. | Pin Name        | Туре         | Reset<br>State | Description                                                                                                                                                                                                                                                                               |
|------------|-----------------|--------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | SWDIO           | DIO          |                | INPUT/OUTPUT. JTAG Data input/output. Bidirectional data and control communication (by default).                                                                                                                                                                                          |
| 8          | P0_11           | DIO (Type A) | I-PD           | INPUT/OUTPUT with selectable pull-up/down resistors. Pull-down enabled during and after reset. General purpose I/O port bit or alternate function nodes. Contains a state retention mechanism during power down.                                                                          |
| Deb        | ug Interface    |              |                |                                                                                                                                                                                                                                                                                           |
| 9          | SWDIO           | DIO          | I-PD           | INPUT/OUTPUT. JTAG Data input/output. Bidirectional data and control communication. Mapped on P0_10 (by default).                                                                                                                                                                         |
| 12         | SWCLK           | DIO          | I-PD           | INPUT JTAG clock signal. Mapped on P0_2 (by default).                                                                                                                                                                                                                                     |
| Cloc       | ks              |              | 1              |                                                                                                                                                                                                                                                                                           |
| 3          | XTAL32Mp        | AI           |                | INPUT. Crystal input for the 32 MHz XTAL.                                                                                                                                                                                                                                                 |
| 4          | XTAL32Mm        | AO           |                | OUTPUT. Crystal output for the 32 MHz XTAL.                                                                                                                                                                                                                                               |
| 13         | XTAL32kp        | Al           |                | INPUT. Crystal input for the 32.768 kHz XTAL. Mapped on P0_3.                                                                                                                                                                                                                             |
| 14         | XTAL32km        | AO           |                | OUTPUT. Crystal output for the 32.768 kHz XTAL. Mapped on P0_4.                                                                                                                                                                                                                           |
| Qua        | drature Decoder | •            |                |                                                                                                                                                                                                                                                                                           |
|            | QD_CHA_X        | DI           |                | INPUT. Channel A for the X axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|            | QD_CHB_X        | DI           |                | INPUT. Channel B for the X axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|            | QD_CHA_Y        | DI           |                | INPUT. Channel A for the Y axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|            | QD_CHB_Y        | DI           |                | INPUT. Channel B for the Y axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|            | QD_CHA_Z        | DI           |                | INPUT. Channel A for the Z axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
|            | QD_CHB_Z        | DI           |                | INPUT. Channel B for the Z axis. Mapped on Px ports.                                                                                                                                                                                                                                      |
| SPI        | Bus Interface   |              |                |                                                                                                                                                                                                                                                                                           |
|            | SPI_CLK         | DO           |                | INPUT/OUTPUT. SPI Clock. Mapped on Px ports.                                                                                                                                                                                                                                              |
|            | SPI_DI          | DI           |                | INPUT. SPI Data input. Mapped on Px ports (Note 1).                                                                                                                                                                                                                                       |
|            | SPI_DO          | DO           |                | OUTPUT. SPI Data output. Mapped on Px ports (Note 2).                                                                                                                                                                                                                                     |
|            | SPI_EN          | DI/DO        |                | INPUT/OUTPUT. SPI Clock enable. Mapped on Px ports.                                                                                                                                                                                                                                       |
| I2C        | Bus Interface   |              |                |                                                                                                                                                                                                                                                                                           |
|            | SDA             | DIO/DIOD     |                | INPUT/OUTPUT. I2C bus Data with open drain port. Mapped on Px ports. The mapped Px pin is automatically configured with a pull-up resistor (25 k $\Omega$ ) when pin x is mapped to the I2C_SDA PID function.                                                                             |
|            | SCL             | DIO/DIOD     |                | INPUT/OUTPUT. I2C bus Clock with open drain port. In open drain mode, SCL is monitored to support bit stretching by a slave. Mapped on Px ports. The mapped Px pin is automatically configured with a pull-up resistor (25 k $\Omega$ ) when pin x is mapped to the I2C_SCL PID function. |
| UAR        | T Interface     |              |                |                                                                                                                                                                                                                                                                                           |



| Pin<br>no. | Pin Name             | Туре | Reset<br>State | Description                                                                                      |
|------------|----------------------|------|----------------|--------------------------------------------------------------------------------------------------|
|            | UTX                  | DO   |                | OUTPUT. UART transmit data. Mapped on Px ports.                                                  |
|            | URX                  | DI   |                | INPUT. UART receive data. Mapped on Px ports.                                                    |
|            | URTS                 | DO   |                | OUTPUT. UART Request to Send. Mapped on Px ports.                                                |
|            | UCTS                 | DI   |                | INPUT. UART Clear to Send. Mapped on Px ports.                                                   |
|            | UTX2                 | DO   |                | OUTPUT. UART2 transmit data. Mapped on Px ports.                                                 |
|            | URX2                 | DI   |                | INPUT. UART2 receive data. Mapped on Px ports.                                                   |
| ADC        | C IO Channels        |      |                |                                                                                                  |
| 11         | ADC0                 | AI   |                | INPUT. Analog to Digital Converter input 0. Mapped on P0_1.                                      |
| 12         | ADC1                 | AI   |                | INPUT. Analog to Digital Converter input 1. Mapped on P0_2.                                      |
| 22         | ADC2                 | AI   |                | INPUT. Analog to Digital Converter input 2. Mapped on P0_6.                                      |
| 15         | ADC3                 | AI   |                | INPUT. Analog to Digital Converter input 3. Mapped on P0_7.                                      |
| Rad        | io Transceiver       |      | •              |                                                                                                  |
| 1          | RFIOp                | AIO  |                | RF input/output. Impedance 50 Ω.                                                                 |
| 18         | RFIOm                | AIO  |                | RF ground.                                                                                       |
| 19         | GND_RF1              | AIO  |                | RF ground.                                                                                       |
| 2          | GND_RF2              | AIO  |                | RF ground.                                                                                       |
| Misc       | cellaneous           |      |                |                                                                                                  |
| 10         | RST                  | DIO  |                | INPUT. Reset signal (active high). Mapped on P0_0 (by default).                                  |
| 6          | LX                   | AIO  |                | INPUT/OUTPUT. Connection for the external DC-DC converter inductor.                              |
| Pow        | er and Ground        |      |                |                                                                                                  |
| 23         | VSS                  | AIO  |                | Digital ground.                                                                                  |
| 20         | GND                  | AIO  |                | Analog ground.                                                                                   |
| 7          | VBAT_HIGH            | AIO  |                | INPUT/OUTPUT. Battery connection or DCDC output in BUCK/BOOST mode, respectively. IO supply.     |
| 5          | V <sub>BAT_LOW</sub> | AIO  |                | INPUT/OUTPUT. Battery connection or DCDC output in BOOST/BUCK mode, respectively. System supply. |
| 21         | GND_DCDC             | AIO  |                | DCDC ground.                                                                                     |

- Note 1 Data input only. MOSI in SPI slave mode and MISO in SPI master mode.
- Note 2 Data output only. MISO in SPI slave mode and MOSI in SPI master mode.
- Note 3 The differences between Type A and Type B GPIO pads are presented in Types of GPIO Pads.



**Final** 

## 4 Specifications

All MIN/MAX specification limits are guaranteed by design, production testing and/or statistical characterization. Typical values are based on characterization results at default measurement conditions and are informative only.

Default measurement conditions (unless otherwise specified):  $V_{BAT\_HIGH} = 3.0 \text{ V}$  (buck mode),  $V_{BAT\_LOW} = 1.5 \text{ V}$  (boost mode),  $T_A = 25 \,^{\circ}\text{C}$ . All radio measurements are performed with standard RF measurement equipment providing a source/load impedance of 50  $\Omega$ . All listed currents involving any radio operation have been conducted without the external CLC filter.

Due to the voltage dependent capacitance of MLCC capacitors the specified capacitor values at  $V_{BAT\_HIGH}$  and  $V_{BAT\_LOW}$  are effective capacitances.



Figure 5: Boost Configuration System Diagram



Figure 6: Buck Configuration System Diagram



**Final** 

# 4.1 Absolute Maximum Ratings

**Table 4: Absolute Maximum Ratings** 

| Parameter                         | Description                                            | Conditions                                                                   | Min  | Max | Unit |
|-----------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------|------|-----|------|
| V <sub>BAT_LIM_LOW</sub>          | Limiting supply voltage                                | Battery voltage in boost configuration, supply voltage in buck configuration | -0.2 | 3.6 | V    |
| VBAT_LIM_HIG                      | Limiting supply voltage                                | Battery voltage in buck configuration, supply voltage in boost configuration | -0.2 | 3.6 | V    |
| VPIN_LIM_defau                    | Limiting voltage on a pin                              |                                                                              | -0.2 | 3.6 | V    |
| VESD_HBM_FC<br>GQFN24             | Electrostatic discharge voltage (Human Body Model)     | RFIOm and RFIOp pins only up to 2.5 kV                                       |      | 4   | kV   |
| VESD_HBM_WL                       | Electrostatic discharge voltage<br>(Human Body Model)  |                                                                              |      | 2   | kV   |
| V <sub>ESD_CDM_FC</sub><br>GQFN24 | Electrostatic discharge voltage (Charged Device Model) |                                                                              |      | 500 | V    |
| V <sub>ESD_CDM_WL</sub>           | Electrostatic discharge voltage (Charged Device Model) |                                                                              |      | 500 | V    |
| T <sub>STG</sub>                  | Storage temperature                                    |                                                                              | -50  | 150 | °C   |

# 4.2 Recommended Operating Conditions

**Table 5: Recommended Operating Conditions** 

| Parameter                | Description                                                                                 | Conditions                                                                               | Min  | Тур | Max | Unit |
|--------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------|-----|-----|------|
| IL_VBAT_HIGH_<br>BOOTING | Maximum external DC load current on V <sub>BAT_HIGH</sub> rail during booting in boost mode | Boost mode booting sequence active                                                       |      |     | 50  | μΑ   |
| VBAT_BYPASS              | Supply voltage.Battery voltage.                                                             | For OTP functionality refer to VBAT_HIGH_OTP_Program/Read. Minimum boot voltage is 1.8 V | 1.1  |     | 3.3 | V    |
| VBAT_HIGH_BO             | DCDC output                                                                                 | For OTP functionality refer to VBAT_HIGH_OTP_Program/Read                                | 1.8  |     | 3.3 | V    |
| VBAT_HIGH_BU             | Supply voltage.Battery voltage.                                                             | For OTP functionality refer to VBAT_HIGH_OTP_Program/Read                                | 1.8  |     | 3.6 | V    |
| VBAT_LOW_BO              | Supply voltage.Battery voltage.                                                             |                                                                                          | 1.1  |     | 1.6 | V    |
| V <sub>BAT_LOW_BU</sub>  | DCDC or LDO_LOW output                                                                      |                                                                                          | 1.1  |     | 3.3 | V    |
| VBAT_HIGH_OT P_Program   | Voltage range for OTP programming                                                           | Required temperature for programming: -40 °C to 85 °C                                    | 2.25 |     | 3.6 | V    |

Datasheet Revision 3.6 26-Sep-2022



**Final** 

| Parameter              | Description                   | Conditions | Min  | Тур | Max                   | Unit |
|------------------------|-------------------------------|------------|------|-----|-----------------------|------|
| VBAT_HIGH_OT<br>P_Read | Voltage range for OTP reading |            | 1.62 |     | 3.6                   | ٧    |
| VPIN_default           | Voltage on a pin              |            | -0.2 |     | VBAT<br>_HIGH<br>+0.2 | V    |
| TA                     | Ambient temperature           |            | -40  |     | 85                    | ů    |

### 4.3 DC Characteristics

### **Table 6: DC Characteristics**

| Parameter                 | Description            | Conditions                                                              | Min | Тур | Max | Unit |
|---------------------------|------------------------|-------------------------------------------------------------------------|-----|-----|-----|------|
| IBAT_HIGH_HIB<br>ERN_0kB  | Battery supply current | Hibernation mode, no RAM retained, no oscillator running Note 1         |     | 270 |     | nA   |
| IBAT_HIGH_HIB<br>ERN_48kB | Battery supply current | Hibernation mode, 48 kB<br>RAM retained, no oscillator<br>running       |     | 750 |     | nA   |
| IBAT_LOW_HIB<br>ERN_0kB   | Battery supply current | Hibernation mode, no RAM retained, no oscillator running Note 2         |     | 240 |     | nA   |
| BAT_LOW_HIB ERN_0kB_5DEG  | Battery supply current | Hibernation mode at 5 °C,<br>0kB RAM retained, no<br>oscillator running |     | 150 |     | nA   |
| BAT_LOW_HIB               | Battery supply current | Hibernation mode, 48 kB<br>RAM retained, no oscillator<br>running       |     | 700 |     | nA   |
| BAT_LOW_DP_<br>SLP_0kB    | Battery supply current | Deep-sleep with 0 kB RAM retained, running on RCX                       |     | 0.9 |     | μA   |
| IBAT_LOW_EX_<br>SLP_20kB  | Battery supply current | Extended-sleep with 20 kB<br>RAM retained, running on<br>RCX            |     | 1.2 |     | μA   |
| IBAT_LOW_EX_<br>SLP_48kB  | Battery supply current | Extended-sleep with 48 kB<br>RAM retained, running on<br>RCX            |     | 1.6 |     | μΑ   |
| BAT_HIGH_DP_<br>SLP_0kB   | Battery supply current | Deep-sleep with no RAM retained, running on RCX                         |     | 1   |     | μΑ   |
| BAT_HIGH_EX_<br>SLP_20kB  | Battery supply current | Extended-sleep mode with 20 kB RAM retained, running on RCX             |     | 1.2 |     | μA   |
| IBAT_HIGH_EX_<br>SLP_48kB | Battery supply current | Extended-sleep mode with<br>48 kB RAM retained, running<br>on RCX       |     | 1.6 |     | μA   |



**Final** 

| Parameter                             | Description            | Conditions                                                                                                                 | Min | Тур | Max | Unit |
|---------------------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|------|
| IBAT_LOW_ACT<br>_RX                   | Battery supply current | Application with Receiver<br>Active, CPU idle at 16 MHz,<br>DCDC off                                                       |     | 5   |     | mA   |
| IBAT_LOW_ACT<br>_TX                   | Battery supply current | Application with Pout = 0 dBm, Power setting 9, Transmit continuous unmodulated output power, CPU idle at 16 MHz, DCDC off |     | 8   |     | mA   |
| BAT_HIGH_ACT<br>_RX                   | Battery supply current | Application with Receiver<br>Active, CPU idle at 16 MHz,<br>DCDC on                                                        |     | 2.2 |     | mA   |
| IBAT_HIGH_ACT<br>_TX                  | Battery supply current | Application with Pout = 0 dBm,Power setting 9, Transmit continuous unmodulated output power, CPU idle at 16 MHz, DCDC on   |     | 3.5 |     | mA   |
| BAT_LOW_RUN<br>_16MHz                 | Battery supply current | CPU executing code from<br>RAM running on XTAL32M<br>oscillator at 16 MHz, DCDC<br>off                                     |     | 830 |     | μА   |
| BAT_HIGH_RU<br>N_16MHz                | Battery supply current | CPU executing code from<br>RAM running on XTAL32M<br>oscillator at 16 MHz                                                  |     | 380 |     | μΑ   |
| I <sub>BAT_</sub> HIGH_IDL<br>E_16MHz | Battery supply current | CPU in Wait-for-Interrupt<br>(WFI) state running on<br>XTAL32M oscillator at 16<br>MHz                                     |     | 230 |     | μА   |
| I <sub>BAT_LOW_IDLE</sub>             | Battery supply current | CPU in Wait-for-Interrupt<br>(WFI) state running on<br>XTAL32M oscillator at 16<br>MHz, DCDC off                           |     | 460 |     | μА   |
| BAT_HIGH_RST                          | Battery supply current | Reset pin asserted, buck configuration, V <sub>BAT_HIGH</sub> = 3.0 V, at 25 °C                                            |     | 200 |     | μΑ   |
| IBAT_LOW_RST                          | Battery supply current | Reset pin asserted, boost configuration, V <sub>BAT_LOW</sub> = 1.5 V, at 25 °C                                            |     | 200 |     | μΑ   |

Note 1  $I_{BAT\_HIGH}$  is Buck configuration at VBAT = 3 V, at 25 °C

Note 2 I<sub>BAT\_LOW</sub> is Boost configuration at VBAT = 1.5 V, at 25 °C



**Final** 

## 4.4 Timing Characteristics

**Table 7: Timing Characteristics** 

| Parameter      | Description   | Conditions                                                                                                                                                                                                                                         | Min  | Тур | Max | Unit |
|----------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----|------|
| tsta_hiber     | Start-up time | Time from hibernation to the first executed code instruction. Applies to both buck or boost modes, excludes capacitors charging time. Assumes VBAT_LOW=VBAT_HIGH with use of the resistive switch so no charging of the respective rail is needed. |      | 0.2 | 0.4 | ms   |
| tsta_slp_buck  | Start-up time | Time from GPIO toggle to the first executed code instruction. Applicable for both deep and extended sleep mode. Application in buck configuration at 3 V battery voltage, excluding capacitor charging.                                            | 0.86 |     | 1.2 | ms   |
| tsta_slp_boost | Start-up time | Time from GPIO toggle to<br>the first executed code<br>instruction. Applicable for<br>both deep and extended<br>sleep mode. Application in<br>boost configuration at 1.5 V<br>battery voltage, excluding<br>capacitor charging.                    | 0.83 |     | 1.1 | ms   |

### 4.5 RCX Oscillator

**Table 8: RCX Oscillator - Timing Characteristics** 

| Parameter                                                      | Description                           | Conditions                                                      | Min  | Тур | Max  | Unit        |
|----------------------------------------------------------------|---------------------------------------|-----------------------------------------------------------------|------|-----|------|-------------|
| $\Delta f_{RC}$                                                | RCX oscillator frequency drift        | 100 ms time slot                                                |      | 100 | 500  | ppm         |
| $\Delta f_{RC}/\Delta V_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{$ | Supply voltage dependency (VBAT_HIGH) |                                                                 | -500 | 80  | 500  | ppm/V       |
| $\Delta f_{RC}/\Delta V_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{_{$ | Supply voltage dependency (VBAT_LOW)  |                                                                 | -500 | 200 | 3000 | ppm/V       |
| f <sub>RCX</sub>                                               | RCX oscillator frequency              | at target fixed trim setting                                    | 13   | 15  | 17   | kHz         |
| $\Delta f_{RC}/\Delta T_{_1}$                                  | Temperature dependency                | Temperature range -40 °C to 85 °C, RCX_BIAS at preferred value  | -125 |     | 125  | ppm/d<br>eg |
| $\Delta f_{RC}/\Delta T_{_2}$                                  | Temperature dependency                | Temperature range -40 °C to 105 °C, RCX_BIAS at preferred value | -200 |     | 200  | ppm/d<br>eg |

**Final** 

#### 4.6 XTAL32MHz Oscillator

Table 9: XTAL32MHz Oscillator - Recommended Operating Conditions

| Parameter               | Description                  | Conditions                                                                                                | Min | Тур | Max  | Unit       |
|-------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------|-----|-----|------|------------|
| P <sub>DRV_MAX</sub>    | Maximum drive power          | Note 1                                                                                                    |     |     | 100  | μW         |
| VCLK_EXT                | External clock voltage       | In case of external clock<br>source on XTAL32Mp<br>(XTAL32Mm floating or<br>connected to mid-level 0.6 V) |     | 0.9 |      | V          |
| <b>Φ</b> N_EXT_32M      | Phase noise                  | f <sub>C</sub> = 50 kHz; in case of external clock source                                                 |     |     | -130 | dBc/H<br>z |
| $\Delta f_{XTAL\_TRIM}$ | Crystal frequency trim       |                                                                                                           |     | 2   |      | ppm        |
| f <sub>XTAL_32M</sub>   | Crystal oscillator frequency |                                                                                                           |     | 32  |      | MHz        |
| $\Delta f_{XTAL}$       | Crystal frequency tolerance  | After optional trimming; including aging and temperature drift  Note 2                                    | -20 |     | 20   | ppm        |
| $\Delta f_{XTAL\_UNT}$  | Crystal frequency tolerance  | Untrimmed; including aging and temperature drift Note 3                                                   | -40 |     | 40   | ppm        |
| ESR_1pF                 | Equivalent series resistance | C <sub>0</sub> <1pF                                                                                       |     |     | 200  | Ω          |
| ESR_3pF                 | Equivalent series resistance | C <sub>0</sub> <3pF                                                                                       |     |     | 80   | Ω          |
| ESR_5pF                 | Equivalent series resistance | C <sub>0</sub> <5pF                                                                                       |     |     | 50   | Ω          |
| CL                      | Load capacitance             | No external capacitors are required                                                                       | 4   | 6   | 8    | pF         |

**Note 1** Select a crystal which can handle a drive level of at least this specification.

#### 4.7 XTAL32kHz Oscillator

Table 10: XTAL oscillator 32kHz - Recommended Operating Conditions

| Parameter         | Description                  | Conditions                                                     | Min | Тур    | Max | Unit |
|-------------------|------------------------------|----------------------------------------------------------------|-----|--------|-----|------|
| fclk_ext          | External clock frequency     | at pin 32KXTAL1/P0_3 in GPIO mode                              | 10  |        | 100 | kHz  |
| f <sub>XTAL</sub> | Crystal oscillator frequency |                                                                | 30  | 32.768 | 35  | kHz  |
| ESR               | Equivalent series resistance |                                                                |     |        | 100 | kΩ   |
| C <sub>L</sub>    | Load capacitance             | No external capacitors are required for a 6 pF or 7 pF crystal | 6   | 7      | 9   | pF   |
| C <sub>0</sub>    | Shunt capacitance            |                                                                |     | 1      | 2   | pF   |

Datasheet Revision 3.6 26-Sep-2022

Note 2 Using the internal varicaps a wide range of crystals can be trimmed to the required tolerance.

**Note 3** Maximum allowed frequency tolerance for compensation by the internal varicap trimming mechanism.



**Final** 

| Parameter            | Description                                   | Conditions                                                                           | Min  | Тур | Max | Unit |
|----------------------|-----------------------------------------------|--------------------------------------------------------------------------------------|------|-----|-----|------|
| ΔfχταL               | Crystal frequency tolerance (including aging) | Timing accuracy is dominated by crystal accuracy. A much smaller value is preferred. | -250 |     | 250 | ppm  |
| P <sub>DRV_MAX</sub> | Maximum drive power                           | Note 1                                                                               | 0.1  |     |     | μW   |

**Note 1** Select a crystal that can handle a drive level of at least this specification.

Table 11: XTAL oscillator 32kHz - Timing Characteristics

| Parameter | Description                      | Conditions                                               | Min | Тур | Max | Unit |
|-----------|----------------------------------|----------------------------------------------------------|-----|-----|-----|------|
| tsta_xtal | Crystal oscillator start-up time | Typical application, time until 1000 clocks are detected |     | 100 | 300 | ms   |

## 4.8 RC32MHz Oscillator

# Table 12: RC32MHz Oscillaor - Timing Characteristics

| Parameter          | Description             | Conditions         | Min | Тур  | Max  | Unit |
|--------------------|-------------------------|--------------------|-----|------|------|------|
| frc32M_TRIMM<br>ED | RC oscillator frequency | at target trimming | 29  | 30.5 | 31.5 | MHz  |

## 4.9 DC-DC Converter

**Table 13: DCDC Converter - Recommended Operating Conditions** 

| Parameter              | Description                                                 | Conditions                            | Min | Тур | Max  | Unit |
|------------------------|-------------------------------------------------------------|---------------------------------------|-----|-----|------|------|
| Соит                   | External capacitor                                          | Effective value at DC output voltage  | 1   |     |      | μF   |
| LEXT                   | External inductor                                           |                                       | 2   | 2.2 | 2.4  | μΗ   |
| V <sub>BAT</sub> _HIGH | Operational supply voltage, applied to VBAT_HIGH            | POWER_LEVEL_REG[DCD<br>C_LEVEL] = 0x0 | 1.8 |     | 3.6  | V    |
| V <sub>BAT_LOW</sub>   | Operational supply voltage, applied to V <sub>BAT_LOW</sub> | POWER_LEVEL_REG[DCD<br>C_LEVEL] = 0x1 | 1.1 |     | 1.65 | V    |
| IL_VBAT_HIGH_<br>1V8   | Load current on V <sub>BAT_HIGH</sub> in BOOST mode         | V <sub>OUT</sub> = 1.8 V<br>Note 1    |     |     | 20   | mA   |
| IL_VBAT_HIGH_<br>2V5   | Load current on V <sub>BAT_HIGH</sub> in BOOST mode         | Vout = 2.5 V<br>Note 1                |     |     | 10   | mA   |
| IL_VBAT_HIGH_<br>3V0   | Load current on V <sub>BAT_HIGH</sub> in BOOST mode         | Vout = 3.0 V<br>Note 1                |     |     | 10   | mA   |

Note 1 IL\_VBAT\_HIGH\_BOOTING is applicable during booting



**Final** 

**Table 14: DCDC Converter - DC Characteristics** 

| Parameter              | Description                  | Conditions                                                                                                       | Min   | Тур | Max   | Unit |
|------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------|-------|-----|-------|------|
| Vo_BUCK_1V1            | DC output voltage            | DCDC_LEVEL = 0x0<br>DCDC_TRIM = 0x3                                                                              | 1.075 | 1.1 | 1.125 | V    |
| Vo_BOOST_1V            | DC output voltage            | DCDC_LEVEL = 0x1<br>DCDC_TRIM = 0x3                                                                              | 1.75  | 1.8 | 1.85  | V    |
| Vo_BOOST_2V<br>5       | DC output voltage            | DCDC_LEVEL = 0x2<br>DCDC_TRIM = 0x3                                                                              | 2.425 | 2.5 | 2.575 | V    |
| Vo_BOOST_3V            | DC output voltage            | DCDC_LEVEL = 0x3<br>DCDC_TRIM = 0x3                                                                              | 2.9   | 3   | 3.1   | V    |
| <b>П</b> СОNV_ВИСК     | Conversion efficiency        | V <sub>BAT</sub> = 3.0 V<br>V <sub>OUT</sub> = 1.1 V<br>I <sub>LOAD</sub> = 10 mA                                | 80    | 85  | 90    | %    |
| <b>П</b> СОNV_ВООЅТ    | Conversion efficiency        | V <sub>BAT</sub> = 1.5 V<br>V <sub>OUT</sub> = 1.8 V<br>I <sub>LOAD</sub> = 10 mA                                | 85    | 90  | 95    | %    |
| V <sub>RPL_BUCK</sub>  | Ripple voltage               | V <sub>BAT</sub> = 3.0 V<br>V <sub>OUT</sub> = 1.1 V<br>I <sub>LOAD</sub> = 1 - 20 mA<br>C <sub>EXT</sub> = 1 μF | 5     | 15  | 25    | mV   |
| V <sub>RPL_BOOST</sub> | Ripple voltage               | V <sub>BAT</sub> = 1.5 V<br>V <sub>OUT</sub> = 1.8 V<br>I <sub>LOAD</sub> = 1 - 20 mA<br>C <sub>EXT</sub> = 1 μF | 5     | 20  | 35    | mV   |
| IQ_VBAT_HIGH           | Quiescent current BUCK mode  | VBAT_HIGH = 3.0 V No load on VBAT_LOW                                                                            |       |     | 40    | μΑ   |
| IQ_VBAT_LOW            | Quiescent current BOOST mode | V <sub>BAT_LOW</sub> = 1.5 V<br>No load on V <sub>BAT_HIGH</sub>                                                 |       |     | 75    | μА   |

# 4.10 LDO\_LOW Characteristics

# Table 15: LDO\_LOW - Recommended Operating Conditions

| Parameter        | Description        | Conditions | Min | Тур | Max | Unit |
|------------------|--------------------|------------|-----|-----|-----|------|
| C <sub>OUT</sub> | Output capacitance |            | 1   |     | 10  | μF   |

# Table 16: LDO\_LOW - DC Characteristics

| Parameter | Description    | Conditions                                                                | Min   | Тур | Max   | Unit |
|-----------|----------------|---------------------------------------------------------------------------|-------|-----|-------|------|
| Vo_active | Output voltage | Active mode (high current) POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x3 (default) | 1.067 | 1.1 | 1.133 | >    |



**Final** 

| Parameter               | Description                                                                                             | Conditions                                                                             | Min   | Тур | Max   | Unit |
|-------------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------|-----|-------|------|
|                         |                                                                                                         | I <sub>LOAD</sub> = 1 mA                                                               |       |     |       |      |
| Vo_sleep                | Output voltage                                                                                          | Sleep mode (low current) POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x3 (default) ILOAD = 100 µA | 1.056 | 1.1 | 1.144 | V    |
| Vo_trim_0               | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x0                                                   |       | -75 |       | mV   |
| V <sub>O_TRIM_1</sub>   | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x1                                                   |       | -50 |       | mV   |
| Vo_trim_2               | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO<br>_LOW_TRIM] = 0x2                                                |       | -25 |       | mV   |
| V <sub>O_TRIM_3</sub>   | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x3                                                   |       | 0   |       | mV   |
| Vo_trim_4               | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x4                                                   |       | 25  |       | mV   |
| Vo_trim_5               | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x5                                                   |       | 50  |       | mV   |
| Vo_trim_6               | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x6                                                   |       | 75  |       | mV   |
| Vo_trim_7               | Trim step, delta from 1.1 V nominal value                                                               | POWER_LEVEL_REG[LDO _LOW_TRIM] = 0x7                                                   |       | 100 |       | mV   |
| I <sub>Q_ACTIVE</sub>   | Quiescent current                                                                                       | No load                                                                                |       | 12  |       | μA   |
| I <sub>Q_SLEEP</sub>    | Quiescent current                                                                                       | No load                                                                                |       | 40  |       | nA   |
| R <sub>ON_SW_HIGH</sub> | On resistance of the high<br>Ohmic switch between<br>VBAT_HIGH and VBAT_LOW rail                        | Buck mode, V <sub>BAT_HIGH</sub> = 1.62<br>V, V <sub>BAT_LOW</sub> = 1.1 V             |       | 250 |       | Ω    |
| Ron_sw_low              | On resistance of the low<br>Ohmic switch between<br>V <sub>BAT_HIGH</sub> and V <sub>BAT_LOW</sub> rail | Buck mode, V <sub>BAT_HIGH</sub> = 1.62<br>V, V <sub>BAT_LOW</sub> = 1.1 V             |       | 10  |       | Ω    |
| Ron_sw_low<br>_Boost    | On resistance of the low<br>Ohmic switch between<br>VBAT_HIGH and VBAT_LOW rail                         | Boost mode, V <sub>BAT_LOW</sub> = 1.1                                                 |       | 10  |       | Ω    |

# **4.11 Digital I/O Characteristics**

# **Table 17: Digital Pad - Recommended Operating Conditions**

| Parameter            | Description                 | Conditions              | Min         | Тур  | Max | Unit |
|----------------------|-----------------------------|-------------------------|-------------|------|-----|------|
| I <sub>L_HIDRV</sub> | Driving current - high mode |                         |             | 3.5  |     | mA   |
| I <sub>L_LODRV</sub> | Driving current - low mode  |                         |             | 0.35 |     | mA   |
| ViH                  | HIGH level input voltage    | V <sub>DD</sub> = 0.9 V | 0.7*V<br>DD |      |     | V    |



**Final** 

| Parameter | Description             | Conditions              | Min | Тур | Max         | Unit |
|-----------|-------------------------|-------------------------|-----|-----|-------------|------|
| VIL       | LOW level input voltage | V <sub>DD</sub> = 0.9 V |     |     | 0.3*V<br>DD | ٧    |

## **Table 18: Digital Pad - DC Characteristics**

| Parameter              | Description               | Conditions                                           | Min                   | Тур  | Max                   | Unit |
|------------------------|---------------------------|------------------------------------------------------|-----------------------|------|-----------------------|------|
| Ін                     | HIGH level input current  | VI=VBAT_HIGH = 3.0 V                                 | -10                   |      | 10                    | μΑ   |
| IIL                    | LOW level input current   | V <sub>I</sub> =V <sub>SS</sub> = 0 V                | -10                   |      | 10                    | μΑ   |
| I <sub>IH_PD</sub>     | HIGH level input current  | VI=VBAT_HIGH = 3.0 V                                 | 60                    |      | 180                   | μΑ   |
| I <sub>IL_PU</sub>     | LOW level input current   | VI=VSS = 0 V, VBAT_HIGH = 3.0 V                      | -180                  |      | -60                   | μΑ   |
| V <sub>OH</sub>        | HIGH level output voltage | I <sub>O</sub> = 3.5 mA, V <sub>BAT_HIGH</sub> = 1.7 | 0.8*VB<br>AT_HI<br>GH |      |                       | ٧    |
| VoL                    | LOW level output voltage  | lo = 3.5 mA, V <sub>ват_нідн</sub> = 1.7<br>V        |                       |      | 0.2*VB<br>AT_HI<br>GH | ٧    |
| V <sub>OH_LOWDRV</sub> | HIGH level output voltage | I <sub>O</sub> = 0.3 mA, V <sub>BAT_HIGH</sub> = 1.7 | 0.8*VB<br>AT_HI<br>GH |      |                       | V    |
| Vol_lowdrv             | LOW level output voltage  | Io = 0.3 mA, V <sub>BAT_HIGH</sub> = 1.7             |                       |      | 0.2*VB<br>AT_HI<br>GH | V    |
| Cin                    | Input capacitance         |                                                      |                       | 0.75 |                       | pF   |

# Table 19: Digital Pad with LPF - DC Characteristics

| Parameter | Description       | Conditions       | Min | Тур  | Max | Unit |
|-----------|-------------------|------------------|-----|------|-----|------|
| Cin       | Input capacitance | Note 1<br>Note 2 |     | 3.85 |     | pF   |

**Note 1** Digital pad characteristics are equal to the standard GPIO pads unless overruled or added in this table.

**Note 2** P0\_3 and P0\_4 are type B pads with selectable filter via GP\_DATA\_REG[P03\_P04\_FILT\_DIS], C<sub>IN</sub> is equal to a Type A pad both with filter enabled or disabled.

# Table 20: Digital Pad with LPF - Recommended Operating Conditions

| Parameter            | Description                 | Conditions | Min | Тур  | Max | Unit |
|----------------------|-----------------------------|------------|-----|------|-----|------|
| I <sub>L_HIDRV</sub> | Driving current - high mode |            |     | 3.5  |     | mA   |
| I <sub>L_LODRV</sub> | Driving current - low mode  |            |     | 0.35 |     | mA   |



**Final** 

## 4.12 Power On Reset

Table 21: POR VBAT\_LOW - DC Characteristics

| Parameter         | Description                           | Conditions | Min  | Тур  | Max | Unit |
|-------------------|---------------------------------------|------------|------|------|-----|------|
| V <sub>тн_н</sub> | POR VBAT_LOW reset release voltage    |            |      | 1.05 | 1.1 | ٧    |
| V <sub>TH_L</sub> | POR VBAT_LOW reset activation voltage |            | 0.95 | 1    |     | V    |

## Table 22: POR VBAT\_HIGH - DC Characteristics

| Parameter         | Description                            | Conditions | Min  | Тур  | Max | Unit |
|-------------------|----------------------------------------|------------|------|------|-----|------|
| V <sub>тн_н</sub> | POR VBAT_HIGH reset release voltage    |            |      | 1.75 | 1.8 | V    |
| V <sub>TH_L</sub> | POR VBAT_HIGH reset activation voltage |            | 1.62 | 1.66 |     | V    |

# 4.13 **GP ADC**

# Table 23: GP ADC - Recommended Operating Conditions

| Parameter            | Description                 | Conditions | Min | Тур | Max | Unit |
|----------------------|-----------------------------|------------|-----|-----|-----|------|
| N <sub>BIT_ADC</sub> | Number of bits (resolution) |            |     | 10  |     | bit  |

# Table 24: GP ADC - DC Characteristics

| Parameter          | Description                                                 | Conditions                                                                 | Min | Тур | Max | Unit |
|--------------------|-------------------------------------------------------------|----------------------------------------------------------------------------|-----|-----|-----|------|
| E <sub>G</sub>     | ADC gain error without software correction (single-ended)   | Trimmed bandgap                                                            | -3  |     | 3   | %    |
| Eg_cor             | ADC gain error after software correction (single-ended)     | Trimmed bandgap & Gain<br>Error + Offset correction<br>applied             | -1  |     | 1   | %    |
| E <sub>OFS</sub>   | ADC offset error without software correction (single-ended) | Trimmed bandgap, no chopping                                               | -40 |     | 40  | LSB  |
| Eofs_cor           | ADC offset error after software correction (single-ended)   | Trimmed bandgap, chopping enabled & Gain Error + Offset correction applied | -4  |     | 4   | LSB  |
| E <sub>G_DIF</sub> | ADC gain error without software correction (differential)   | Trimmed bandgap                                                            | -3  |     | 3   | %    |
| Eg_dif_cor         | ADC gain error after software correction (differential)     | Trimmed bandgap & Gain<br>Error + Offset correction<br>applied             | -1  |     | 1   | %    |



**Final** 

| Parameter              | Description                                                           | Conditions                                                                                | Min | Тур | Max | Unit |
|------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----|-----|-----|------|
| Eofs_dif               | ADC offset error without software correction (differential)           | Trimmed bandgap, no chopping                                                              | -20 |     | 20  | LSB  |
| Eofs_dif_cor           | ADC offset error after software correction (differential)             | Trimmed bandgap, chopping enabled & Gain Error + Offset correction applied                | -4  |     | 4   | LSB  |
| Eg_attnx               | ADC gain error after software correction (including attenuator)       | Trimmed bandgap & GPADC<br>Gain Error + Offset<br>correction applied                      | -4  |     | 4   | %    |
| E <sub>OFS_ATTNX</sub> | ADC offset error after software correction (including attenuator)     | Trimmed bandgap, chopping enabled & GPADC Gain Error + Offset correction applied          | -16 |     | 16  | LSB  |
| Eg_offsh               | ADC gain error after software correction (including offset shifter)   | Trimmed bandgap & Offset<br>Shifter Gain Error + Offset<br>correction applied             | -1  |     | 1   | %    |
| Eofs_offsh             | ADC offset error after software correction (including offset shifter) | Trimmed bandgap, chopping enabled & Offset Shifter Gain Error + Offset correction applied | -4  |     | 4   | LSB  |
| INL                    | Integral non-linearity                                                | Note 1                                                                                    | -2  |     | 2   | LSB  |
| DNL                    | Differential non-linearity                                            |                                                                                           | -2  |     | 2   | LSB  |
| ENOB                   | Effective Number Of Bits                                              | no averaging, no chopping,<br>Single-Ended: V <sub>IN,PP</sub> =<br>800mV                 |     | 9   |     | bit  |
| ENOBAVG128             | Effective Number Of Bits                                              | 128x averaging, Single-<br>Ended: V <sub>IN,PP</sub> = 800mV                              |     | 11  |     | bit  |

**Note 1** INL is the deviation of a code from a straight line passing through the actual endpoints of the transfer curve.

# Table 25: GP ADC - Electrical performance

| Parameter | Description                | Conditions | Min | Тур | Max | Unit |
|-----------|----------------------------|------------|-----|-----|-----|------|
| tconv_adc | Conversion time of the ADC |            |     | 125 | 500 | ns   |

# **4.14 Temperature Sensor**

# **Table 26: Temperature Sensor - DC Characteristics**

| Parameter                       | Description                                                                     | Conditions                                                | Min | Тур | Max | Unit |
|---------------------------------|---------------------------------------------------------------------------------|-----------------------------------------------------------|-----|-----|-----|------|
| TSENSE_RANG E                   | Temperature sensor range                                                        |                                                           | -40 |     | 105 | °C   |
| T <sub>SENSE_ACC_</sub> OTP_CSP | Applies to the CSP package.<br>Absolute accuracy of<br>temperature sensor using | T <sub>AMBIENT</sub> = 25°C, V <sub>BAT_LOW</sub> = 1.1 V | -4  |     | 4   | °C   |



**Final** 

| Parameter              | Description                                                                                                                                                                                                                                             | Conditions                         | Min  | Тур  | Max  | Unit       |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------|------|------|------------|
|                        | calibration value from OTP (single point calibration at 25 °C).  Formula: Tx = 25 °C + (ADCx - ADCotp_CAL_25C) / (TCsense * 64) (64 is used to correct 16b to 10b ADC values)                                                                           |                                    |      |      |      |            |
| TSENSE_ACC_<br>OTP_QFN | Applies to the QFN package. Absolute accuracy of temperature sensor using calibration value from OTP (single point calibration at 25 °C).  Formula: Tx = 25 °C + (ADCx - ADCotp_CAL_25C) / (TCsense * 64) (64 is used to correct 16b to 10b ADC values) | Tambient = 25°C, Vbat_low = 1.1 V  |      | ±4   |      | ů          |
| TCsense                | Temperature coefficient of the internal temperature sensor                                                                                                                                                                                              | Reading via GP_ADC (10-bit result) | 1.15 | 1.45 | 1.75 | LSB/°<br>C |

# **4.15** Radio

# Table 27: BLE 1Mb/s specifications - Recommended Operating Conditions

| Parameter       | Description         | Conditions  | Min  | Тур          | Max    | Unit |
|-----------------|---------------------|-------------|------|--------------|--------|------|
| foper           | Operating frequency |             | 2400 |              | 2483.5 | MHz  |
| N <sub>CH</sub> | Number of channels  |             |      | 40           |        | 1    |
| f <sub>CH</sub> | Channel frequency   | K = 0 to 39 |      | 2402+<br>K*2 |        | MHz  |

# Table 28: BLE 1Mb/s specifications - AC Characteristics

| Parameter         | Description       | Conditions                                                                          | Min | Тур   | Max | Unit |
|-------------------|-------------------|-------------------------------------------------------------------------------------|-----|-------|-----|------|
| Psens_clean       | Sensitivity level | Dirty Transmitter disabled;<br>DC-DC converter disabled;<br>PER = 30.8 %<br>Note 1  |     | -94   |     | dBm  |
| Psens_epkt        | Sensitivity level | Extended packet size (255 octets) Note 1                                            |     | -90.5 |     | dBm  |
| P <sub>SENS</sub> | Sensitivity level | Normal Operating<br>Conditions; DC-DC converter<br>disabled; PER = 30.8 %<br>Note 1 |     | -93   |     | dBm  |
| Psens_eoc         | Sensitivity level | Extreme Operating Conditions; DC-DC converter                                       |     |       | -90 | dBm  |



Final

| Parameter                        | Description                                       | Conditions                                                                                                                                                           | Min | Тур   | Max | Unit |
|----------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|-----|------|
|                                  |                                                   | enabled; PER = 30.8 %; -40 $^{\circ}$ C $\leq$ T <sub>A</sub> $\leq$ +85 $^{\circ}$ C Note 1                                                                         |     |       |     |      |
| P <sub>SENS_EPKT_</sub><br>CLEAN | Sensitivity level                                 | Dirty Transmitter disabled;<br>DC-DC converter disabled;<br>Extended packet size (255<br>octets)<br>Note 1                                                           |     | -91.5 |     | dBm  |
| P <sub>I_MAX</sub>               | Maximum input power level                         | DC-DC converter disabled;<br>PER = 30.8 %<br>Note 1                                                                                                                  | 0   |       |     | dBm  |
| P <sub>INT_IMD</sub>             | Intermodulation distortion interferer power level | worst-case interferer level @ $f_1$ , $f_2$ with $2*f_1 - f_2 = f_0$ , $ f_1 - f_2 $ = n MHz and n = 3, 4, 5; $P_{WANTED} = -64$ dBm @ $f_0$ ; $PER = 30.8$ % Note 1 | -35 | -20.5 |     | dBm  |
| CIR <sub>0</sub>                 | Carrier to interferer ratio                       | $n = 0$ ; interferer @ $f_1 = f_0 +$<br>n*1 MHz;<br>Note 1                                                                                                           |     | 7.5   | 21  | dB   |
| CIR <sub>1</sub>                 | Carrier to interferer ratio                       | n = ±1; interferer @ f <sub>1</sub> = f <sub>0</sub> +<br>n*1 MHz;<br>Note 1                                                                                         |     | -1.5  | 15  | dB   |
| CIR <sub>P2</sub>                | Carrier to interferer ratio                       | n = +2 (image frequency);<br>interferer @ f <sub>1</sub> = f <sub>0</sub> + n*1<br>MHz;<br>Note 1                                                                    |     | -27   | -9  | dB   |
| CIR <sub>M2</sub>                | Carrier to interferer ratio                       | $n = -2$ ; interferer @ $f_1 = f_0 + n*1$ MHz;<br>Note 1                                                                                                             |     | -31   | -17 | dB   |
| CIR <sub>P3</sub>                | Carrier to interferer ratio                       | n = +3 (image frequency + 1 MHz); interferer @ f <sub>1</sub> = f <sub>0</sub> + n*1 MHz; Note 1                                                                     |     | -37.5 | -15 | dB   |
| CIR <sub>M3</sub>                | Carrier to interferer ratio                       | $n = -3$ ; interferer @ $f_1 = f_0 + n*1$ MHz;<br>Note 1                                                                                                             |     | -43   | -27 | dB   |
| CIR <sub>4</sub>                 | Carrier to interferer ratio                       | n  ≥ 4 (any other BLE channel); interferer @ f <sub>1</sub> = f <sub>0</sub> + n*1 MHz;                                                                              |     | -41.5 | -27 | dB   |
| P <sub>BL_I</sub>                | Blocker power level                               | 30 MHz ≤ f <sub>BL</sub> ≤ 2000 MHz;<br>P <sub>WANTED</sub> = -67 dBm<br>Note 1                                                                                      | -17 | 5     |     | dBm  |
| P <sub>BL_II</sub>               | Blocker power level<br>Note 2                     | 2003 MHz ≤ f <sub>BL</sub> ≤ 2399 MHz;<br>P <sub>WANTED</sub> = -67 dBm<br>Note 1                                                                                    | -17 | 0     |     | dBm  |



Final

| Parameter             | Description                  | Conditions                                                                                                                   | Min | Тур  | Max | Unit       |
|-----------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----|------|-----|------------|
| P <sub>BL_III</sub>   | Blocker power level          | 2484 MHz ≤ f <sub>BL</sub> ≤ 2997 MHz;<br>P <sub>WANTED</sub> = -67 dBm<br>Note 1                                            | -17 | 0    |     | dBm        |
| $P_{BL\_IV}$          | Blocker power level          | $3000 \text{ MHz} \le f_{BL} \le 12.75 \text{ GHz};$ $P_{WANTED} = -67 \text{ dBm}$ Note 1                                   | -17 | 5    |     | dBm        |
| Lacc_rssi             | Level accuracy               | Tolerance at 5 % to 95 % confidence interval of $P_{RF}$ : when RXRSSI[7:0] = $X$ , 50 < $X$ < 175; burst mode, 1500 packets |     | 0    | 3   | dB         |
| Lres_rssi             | Level resolution             | Gradient of monotonous<br>range for RXRSSI[7:0] = $X$ ,<br>50 < X < 175; burst mode,<br>1500 packets                         |     | 0.5  |     | dB/LS<br>B |
| ACP <sub>2M</sub>     | Adjacent channel power level | f <sub>OFS</sub> = 2 MHz;<br>Note 1                                                                                          |     | -53  |     | dBm        |
| ACP <sub>2M_EOC</sub> | Adjacent channel power level | Extreme Operating Conditions; fors = 2 MHz; -40 $^{\circ}$ C $\leq$ T <sub>A</sub> $\leq$ +85 $^{\circ}$ C Note 1            |     | -53  | -47 | dBm        |
| ACP <sub>3M</sub>     | Adjacent channel power level | f <sub>OFS</sub> ≥ 3 MHz;<br>Note 1                                                                                          |     | -57  |     | dBm        |
| ACP <sub>3M_EOC</sub> | Adjacent channel power level | Extreme Operating Conditions; $f_{OFS} \ge 3$ MHz; -40 $^{\circ}C \le T_{A} \le +85$ $^{\circ}C$ Note 1                      |     | -57  | -47 | dBm        |
| P <sub>O_12</sub>     | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 12                                                                                        |     | 2.5  |     | dBm        |
| P <sub>O_11</sub>     | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 11                                                                                        |     | 1.5  |     | dBm        |
| Po_10                 | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 10                                                                                        |     | 1    |     | dBm        |
| Po_09                 | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 9                                                                                         |     | 0    |     | dBm        |
| P <sub>O_08</sub>     | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 8                                                                                         |     | -1   |     | dBm        |
| Po_07                 | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 7                                                                                         |     | -2   |     | dBm        |
| Po_06                 | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 6                                                                                         |     | -3.5 |     | dBm        |
| P <sub>O_05</sub>     | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 5                                                                                         |     | -5   |     | dBm        |
| P <sub>O_04</sub>     | Output power level           | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 4                                                                                         |     | -7   |     | dBm        |
|                       |                              |                                                                                                                              |     |      |     |            |



**Final** 

| Parameter         | Description        | Conditions                           | Min | Тур   | Max | Unit |
|-------------------|--------------------|--------------------------------------|-----|-------|-----|------|
| P <sub>O_03</sub> | Output power level | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 3 |     | -10   |     | dBm  |
| P <sub>O_02</sub> | Output power level | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 2 |     | -13.5 |     | dBm  |
| P <sub>O_01</sub> | Output power level | RF_ATTR_REG[PA_POWE<br>R_SETTING]= 1 |     | -19.5 |     | dBm  |

Note 1 Measured according to Bluetooth® Low Energy Test Specification RF-PHY.TS/5.1.0

# Table 29: BLE 1Mb/s specifications - Timing Characteristics

| Parameter | Description                  | Conditions                       | Min | Тур | Max | Unit |
|-----------|------------------------------|----------------------------------|-----|-----|-----|------|
| thold     | Hold time of radio Ido's     | Temperature from -40 °C to 55 °C | 500 |     |     | ms   |
| tHOLD_EOC | Hold time of the radio Ido's | Temperature from -40 °C to 85 °C | 10  |     |     | ms   |

# Table 30: BLE 1Mb/s specifications - DC Characteristics

| Parameter                 | Description                             | Conditions                                                                                                       | Min | Тур | Max | Unit |
|---------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------|-----|-----|-----|------|
| IBAT_RF_RX                | Current at V <sub>BAT_LOW</sub> = 1.1 V | Radio receiver and synthesizer active; T <sub>A</sub> = 25 °C                                                    |     | 4.3 |     | mA   |
| I <sub>BAT_RF_TX_12</sub> | Current at V <sub>BAT_LOW</sub> = 1.1 V | Radio transmitter and synthesizer active; power setting = 12; Pout = 2.5 dBm; T <sub>A</sub> = 25 °C             |     | 7.9 |     | mA   |
| I <sub>BAT_RF_TX_9</sub>  | Current at V <sub>BAT_LOW</sub> = 1.1 V | Radio transmitter and<br>synthesizer active; power<br>setting = 9; Pout = 0 dBm; T <sub>A</sub><br>= 25 °C       |     | 6.9 |     | mA   |
| IBAT_RF_TX_6              | Current at V <sub>BAT_LOW</sub> = 1.1 V | Radio transmitter and synthesizer active; power setting = 6; P <sub>OUT</sub> = -3.5 dBm; T <sub>A</sub> = 25 °C |     | 5.7 |     | mA   |

Note 2 Frequencies close to the ISM band can show slightly worse performance



**Final** 

# 5 System Overview

#### 5.1 Internal Blocks

The DA14531 contains the following blocks:

Arm Cortex-M0+ CPU with Wake-up Interrupt Controller (WIC). This processor provides 0.9 dMIPS/MHz and is used for assisting the Bluetooth® LE protocol implementation, for providing processing power for calculations or data fetches required by applications, and for housekeeping, including controlling the power scheme of the system.

**BLE core.** This is the baseband hardware accelerator for the Bluetooth® LE protocol.

**ROM.** This 144-kB ROM contains the Bluetooth® LE protocol stack and the boot code sequence.

**OTP.** This 32-kB OTP memory array is used to store application code and Bluetooth<sup>®</sup> LE profiles. It also contains the system configuration and calibration data.

**System SRAM (SysRAM).** This 48-kB SysRAM is primarily used to mirror the program code from the OTP when the system wakes/powers up. It also serves as a Data RAM for intermediate variables and various data that the protocol requires. It can be used as an extra memory space for the Bluetooth® LE TX and RX data structures (Exchange RAM). The SysRAM cells can not only be retained during sleep modes but also be completely switched off during active mode if not needed.

**UART and UART2.** The serial interface of the UART implements hardware flow control while UART2 does not. Both UARTs feature FIFOs with depths of 16 bytes each.

**SPI.** This is the serial peripheral interface (SPI) with master/slave capability and it has separate FIFOs for RX and TX of two 16-bit words each.

**I2C.** This Master/Slave I2C interface is used for sensors and/or host Micro-Controllers Units (MCUs) communication. It comprises a 32-place 9-bit deep FIFO.

**General Purpose (GP) ADC**. This 10-bit analog-to-digital converter (ADC) has four external input channels (GPIOs) and internal channels for reading die temperature, the battery voltage, and other internal analog nodes.

Radio Transceiver. This block implements the RF part of the BLE protocol.

Clock Generator. This block is responsible for clocking the system. It contains two XTAL oscillators, one running at 32 MHz (XTAL32M) and used for the active mode of the system and the other running at 32.768 kHz (XTAL32K) and used for the sleep modes of the system. There are also three RC oscillators available: a 32 MHz oscillator (RC32M) with low precision (> 500 ppm), a 32 kHz oscillator (RC32K) with low precision (> 500 ppm), and a ~15 kHz oscillator (RCX) with high precision (< 500 ppm). The RCX oscillator can be used as a sleep clock to replace the XTAL32K oscillator to further improve the power dissipation of the system while reducing the bill of materials. The RC32M oscillator is used to provide a clock to mirror the OTP code into the SysRAM while the XTAL32M oscillator is settling directly after power/wake up. This clock is also used to run the Booter at power-up. An external digital clock can be used as a sleep clock to replace the XTAL32K or the RCX oscillator.

Timers. This block contains three timers:

- A 16-bit general purpose timer (Timer0) with two pulse width modulation (PWM) signals (PWM1 is inverted to PWM0)
- An 11-bit timer (Timer1) with two capture channels
- A 14-bit timer (Timer2) that controls six PWM signals that all have the same frequency, but each has a configurable duty cycle

**Real Time Clock (RTC).** This hardware controller supports the complete time of day clock: 12/24 hours, minutes, seconds, milliseconds, and hundredths of a millisecond. It includes a configurable alarm function and can be programmed to generate an interrupt on any event, like a rollover of the month, day, hour, minute, second, or hundredths of a millisecond.



**Final** 

**Wake-Up Timer.** This timer captures external events and it can be used on any of the GPIO ports as a wake-up trigger based on a programmable number of external events.

**Quadrature Decoder.** This block decodes the pulse trains from a rotary encoder to provide the step and the direction of a movement of an external device. Three axes (X, Y, and Z) are supported. The block also supports an edge counting mode which enables counting positive or negative edges on the selected GPIOs.

**Keyboard Controller.** This circuit enables the reading and debouncing of a programmable number of GPIOs and generates an interrupt upon a configurable action.

AHB/APB Bus. This block implements the AMBA Lite version of the AHB and APB specifications.

**Power Management.** This sophisticated power management circuit is equipped with a Buck/Boost DC-DC converter and several low-dropout regulators (LDOs) that can be turned on/off via software.

A more detailed description of each component of the DA14531 is presented in the following sections.

## 5.2 Power Management Unit

#### 5.2.1 Introduction

The DA14531 has an integrated power management unit (PMU) which comprises a VDD\_Clamp, a POR circuitry, a DCDC converter, and various LDOs. The system diagram of the integrated PMU is shown in Figure 7.

#### **Features**

- Boost, Buck, and DCDC bypass configurations
- Single inductance DCDC converter configured for Boost or Buck configuration
- Programmable DCDC converter outputs
- Active and sleep mode LDOs
- Low BOM and use of small external components

#### 5.2.2 Architecture

The PMU integrates two externally decoupled power rails: V<sub>BAT\_HIGH</sub> and V<sub>BAT\_LOW</sub>, and one internal V<sub>DD</sub> power rail. There are three main power configurations: Buck, Boost, and Bypass. The integrated PMU configures itself automatically to the appropriate mode depending on how the battery is initially connected to the application.

- V<sub>BAT\_HIGH</sub>: voltage range of 1.8 V 3.6 V. This power rail is used for the blocks which require a
  higher supply voltage. The OTP and the GPIOs are connected to this power rail. V<sub>BAT\_HIGH</sub> is
  protected by the POR circuit POR\_HIGH, which generates a POR when the voltage drops below
  the threshold voltage.
- V<sub>BAT\_LOW</sub>: the main system supply and most internal blocks are powered from this rail. Its
  functional range is from 1.1 V to 3.3 V. When used in Boost configuration, its default voltage
  range is from 1.1 V to 1.65 V, and within this range, the DCDC converter can provide a supply at
  V<sub>BAT\_HIGH</sub> in the range of 1.8 V to 3.0 V (see Section 5.2.3.2). V<sub>BAT\_LOW</sub> is protected with the POR
  circuit POR\_LOW which generates an HW reset when the voltage drops below the threshold
  voltage.
- The internal V<sub>DD</sub> power rail supplies the digital power domains (see Section 5.2.2.1 for the details)

The VDD\_Clamp and RC32k blocks are supplied by the highest of VBAT\_HIGH and VBAT\_LOW.

In the Buck configuration (Figure 7), the battery is connected to  $V_{BAT\_HIGH}$ . The voltage on  $V_{BAT\_LOW}$  is generated from  $V_{BAT\_HIGH}$ . In Boost configuration (Figure 8), the battery is connected to  $V_{BAT\_LOW}$ . The voltage on  $V_{BAT\_HIGH}$  is generated from  $V_{BAT\_LOW}$ . The different power modes of the system are explained in Section 5.2.2.2.



**Final** 



Figure 7: Power Management Unit: Buck Configuration



Figure 8: Power Management Unit: Boost Configuration

In bypass configuration (Figure 9), the DCDC is bypassed and the battery is connected to both  $V_{BAT\_LOW}$  and  $V_{BAT\_HIGH}$ . In this mode, an external inductor is omitted resulting to lower BOM. GPIOs supply follows the battery voltage in this configuration. The minimum cold boot voltage is 1.8 V. After cold boot and providing that no OTP or GPIO (at a specific voltage level) is needed, POR HIGH can be disabled and then  $V_{BAT\_BYPASS}$  can go down to 1.1 V.

Note that since VBAT\_LOW is limited to a max of 3.3 V, the battery/supply voltage shall not exceed that level in the bypass configuration. If an application requires supply levels up to 3.6 V and the choice is made to omit the DCDC converter (reduced BOM at the cost of higher current consumption), it is recommended to use the "Buck Configuration" and enable LDO\_LOW to power the VBAT\_LOW rail (instead of via DCDC converter).



**Final** 



Figure 9: Power Management Unit: Bypass Configuration

## 5.2.2.1 Digital Power Domains

The DA14531 supports a number of digital power domains that can be turned on and off by software (Figure 10). Some of the blocks contain registers that can retain their values even if the digital power domain where they reside is powered off. RAM cells can retain their contents independently from the digital power domains state.



Figure 10: Digital Power Domains

The list of blocks residing in each one of the digital power domains is presented in Table 31.

**Table 31: Power Domains Description** 

| Domain<br>Name | Description                                                                          |
|----------------|--------------------------------------------------------------------------------------|
| PD_AON         | Always powered domain. It contains a Clock-less Wake Up controller and the pad-ring. |



**Final** 

| Domain<br>Name | Description                                                                                                                                                                                                      |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PD_SLP         | Sleep power domain. It comprises the Arm/WIC, the Bluetooth® LE Timer, the PMU/Clock Generation, the Clocked Wakeup Controller, the Quadrature Decoder, and various registers required for the Wake-Up sequence. |
| PD_SYS         | System Power Domain. It comprises the AHB bus, the OTP cell and controllers, the ROM, the System RAM, the Watchdog, the SW Timer, and the GPIO port multiplexing.                                                |
| PD_TIM         | Timer Power Domain. It comprises the RTC and the Timer1. These two blocks can be active during sleep modes.                                                                                                      |
| PD_RAD         | Radio Power Domain. It comprises the Bluetooth® LE Core and the digital PHY of the Radio.                                                                                                                        |

#### 5.2.2.2 Power Modes

There are five different power modes in the DA14531:

- Active mode: System is active and operates at full speed
- Sleep mode: No power gating has been programmed. The Cortex CPU is idle, waiting for an interrupt. PD SYS is on. PD TIM and PD RAD depend on the programmed enabled value
- Extended Sleep mode: PD\_AON, PD\_SLP, and conditionally PD\_TIM are active. RAM is expected to be retained for
  - Keeping a Bluetooth<sup>®</sup> LE connection alive (stack variables or Bluetooth<sup>®</sup> LE data)
  - Potentially keep the application code and it can be omitted if the OTP is instructed to automatically get mirrored into RAM upon every wake-up
- **Deep Sleep mode**: Shipping clocked mode with all domains disabled. RAM may or may not be retained. RTC operation is programmable
- **Hibernation mode**: Shipping clock-less mode with all domains disabled. RAM may or may not be retained. No clock is running

A summary of the power modes, the digital power domains, as well as the clocks and wake-up capabilities are explained in Table 32.



**Final** 

# Table 32: Power Modes, Digital Power Domains, Clocks, and Wake-up Triggers

| Power Mode                                 | Digital Power<br>Domains                                            | LDOs, DCDC Converter, and VDD Level                                                                                        | Clock<br>Availability | RAM                                                                                | Wake Up from                                                                                             |
|--------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Active or Sleep<br>(WFI)                   | PD_AON = ON PD_SLP = ON PD_SYS = ON PD_TIM = OPTIONAL PD_RAD = OPT  | VDD = 0.9 V DCDC = ON (Buck or Boost) LDO_LOW = OFF LDO_CORE = ON, Active (0.9 V) VDD_Clamp = OFF LDO_RADIO = Programmable | All                   | SysRAM1 = ON (Application) SysRAM2 = optionally retained SysRAM3 = ON (Stack Data) |                                                                                                          |
| Extended Sleep<br>(with or without<br>OTP) | PD_AON = ON PD_SLP = ON PD_SYS = OFF PD_TIM = OPTIONAL PD_RAD = OFF | VDD = 0.75 V DCDC = OFF LDO_LOW = ON, in Buck mode. LDO_CORE = ON, in retain mode (0.75 V) VDD_Clamp = OFF LDO_RADIO = OFF | RCX or<br>XTAL32K     | SysRAMx = optionally retained<br>(typically only SysRAM1 is<br>retained)           | <ul> <li>from any GPIOs</li> <li>RTC alarm</li> <li>Timer1</li> <li>Bluetooth® LE sleep timer</li> </ul> |
| Deep Sleep                                 | PD_AON = ON PD_SLP = ON PD_SYS = OFF PD_TIM = OPTIONAL PD_RAD = OFF | VDD = 0.75 V DCDC = OFF LDO_LOW = ON, in Buck mode LDO_CORE = ON, in retain mode (0.75 V) VDD_Clamp = OFF LDO_RADIO = OFF  | RCX or<br>XTAL32K     | SysRAMx = optionally retained (Typically OFF)                                      | <ul><li>from any GPIOs</li><li>RTC alarm</li><li>Timer1</li></ul>                                        |

# **DA14531**



# **Ultra Low Power Bluetooth 5.1 SoC**

**Final** 

| Power Mode  | Digital Power<br>Domains                                                    | LDOs, DCDC Converter, and VDD Level                                                                      | Clock<br>Availability | RAM                           | Wake Up from                              |
|-------------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------|-------------------------------|-------------------------------------------|
| Hibernation | PD_AON = ON<br>PD_SLP = OFF<br>PD_SYS = OFF<br>PD_TIM = OFF<br>PD_RAD = OFF | VDD = ~0.75 V<br>DCDC = OFF<br>LDO_LOW = OFF<br>LDO_CORE = OFF<br>VDD_Clamp = ~0.75 V<br>LDO_RADIO = OFF | No Clocks             | SysRAMx = optionally retained | Wake up from P0_1, P0_2, P0_3, P0_4, P0_5 |



**Final** 

Table 33 shows the typical rail voltages and their drivers present during various PMU modes.

**Table 33: Power Rails Drivers and Voltages** 

| Configurations | Mode                   | V <sub>BAT_HIGH</sub>                                              | V <sub>BAT_LOW</sub>    | V <sub>DD</sub>                  |  |
|----------------|------------------------|--------------------------------------------------------------------|-------------------------|----------------------------------|--|
|                | Active                 |                                                                    | DCDC out (1.1 V)        | LDO_CORE (0.9 V)                 |  |
| Buck           | Deep or Extended Sleep | Battery (3.6 V – 1.8 V)                                            | LDO_LOW (1.1 V)         | LDO_CORE in retain mode (0.75 V) |  |
|                | Hibernation            |                                                                    | 0 V (none)              | VDD_Clamp (~0.75 V)              |  |
|                | Active                 | DCDC out (3 V - 1.8 V)                                             |                         | LDO_CORE 0.9 V                   |  |
| Boost          | Deep or Extended Sleep | Parasitic diodes in DCDC or clamp (V <sub>BAT_LOW</sub> ) (Note 1) | Battery (1.5V – 1.1 V)  | LDO_CORE in retain mode (0.75 V) |  |
|                | Hibernation            | Parasitic diodes in DCDC or clamp (V <sub>BAT_LOW</sub> ) (Note 1) |                         | VDD_Clamp (~0.75 V)              |  |
|                | Active                 |                                                                    |                         | LDO_CORE (0.9 V)                 |  |
| Bypass         | Deep or Extended Sleep | Battery (3.3 V – 1.1 V)                                            | Battery (3.3 V – 1.1 V) | LDO_CORE in retain mode (0.75 V) |  |
|                | Hibernation            |                                                                    |                         | VDD_Clamp (~0.75 V)              |  |

Note 1 Parasitic diodes in DCDC and LDO\_LOW circuits prevent VBAT\_HIGH from dropping to 0 V. VBAT\_HIGH can also be programmed to be clamped to VBAT\_LOW.

**Final** 

#### 5.2.2.3 VDD Level in Hibernation

While in Hibernation, the Always On domain (PD\_AON) is supplied by a clamp. Since the reference is not enabled, the actual voltage supplied by the clamp is depending on the load and temperature. To ensure proper operation of the PD\_AON across the application operating temperature range and load, it is recommended to configure the voltage level of the VDD\_Clamp using POWER\_AON\_CTRL\_REG[LDO\_RET\_TRIM] according to Table 34.

Table 34: VDD\_Clamp Recommended Settings over Temperature and Load

| Temperature Range | 0 kB Retained RAM | 48 kB Retained RAM |
|-------------------|-------------------|--------------------|
| -40 °C to +40 °C  | 0xE               | 0xD                |
| -40 °C to +60 °C  | 0xD               | 0xC                |
| -40 °C to +85 °C  | 0xB               | 0xA                |

## 5.2.2.4 Retainable Registers

When the system enters one of the sleep modes, some registers need to retain their values even though their power domain might be shut down. These special retainable registers and their power domains are described in Table 35.

**Table 35: Retainable Registers** 

| Power Domains | Retainable Registers             |  |
|---------------|----------------------------------|--|
|               | OTPC_MODE_REG                    |  |
|               | OTPC_TIM1_REG                    |  |
|               | OTPC_TIM2_REG                    |  |
| PD_SYS        | OTPC_AHBADR_REG                  |  |
|               | OTPC_CELADR_REG                  |  |
|               | OTPC_NWORDS_REG                  |  |
|               | DEBUG_REG                        |  |
|               | BLE_CNTL2_REG                    |  |
|               | RF_ADCI_DC_OFFSET_REG            |  |
| PD RAD        | RF_ADCQ_DC_OFFSET_REG            |  |
| FU_NAD        | RF_DC_OFFSET_RESULT_REG          |  |
|               | RF_DC_OFFSET_FULL_RES_REG        |  |
|               | RF_DC_OFFSET_MPAR_RES0/1/2/3_REG |  |

## 5.2.3 Programming

## **5.2.3.1** Buck Configuration

In Buck configuration (Figure 7), the voltage on  $V_{BAT\_LOW}$  and  $V_{DD}$  is generated from  $V_{BAT\_HIGH}$  in the following ways:

## • Hibernation Mode

In hibernation mode, the  $V_{BAT\_LOW}$  rail is not powered and the digital core  $V_{DD}$  is supplied by the VDD clamp.

The VDD clamp is supplied automatically by selecting the highest of  $V_{BAT\_HIGH}$  and  $V_{BAT\_LOW}$ . Since in Buck configuration the  $V_{BAT\_HIGH}$  rail is always the highest supply on the chip, it is safe to disable this



**Final** 

automatic supply selection. Setting POWER\_AON\_CTRL\_REG[CMP\_VCONT\_SLP\_DISABLE] = 0x1 forces the clamp to use  $V_{BAT\_HIGH}$  as supply and reduces the hibernation current by approximately 40 nA.

### • Extended Sleep and Deep Sleep Modes

In the extended sleep mode or deep sleep mode, the V<sub>BAT\_LOW</sub> rail is supplied from LDO\_LOW which is in a retention low power mode. The digital core V<sub>DD</sub> is powered from LDO\_CORE, retention mode. To configure this mode the following settings must be applied:

- POWER\_CTRL\_REG[LDO\_LOW\_CTRL\_REG] = 0x3
- POWER\_CTRL\_REG[LDO\_CORE\_RET\_ENABLE] = 0x1

## • Active and Sleep Modes

The V<sub>BAT\_LOW</sub> rail is powered by LDO\_LOW or by the DCDC converter. To enable the DCDC converter the following settings must be applied:

- POWER LEVEL REG[DCDC LEVEL] = 0x0
- DCDC\_CTRL\_REG[DCDC\_ENABLE] = 0x1

The DCDC converter is automatically disabled and re-enabled when PD\_SYS is powered down and powered up again. Therefore, to use the DCDC converter to power V<sub>BAT\_LOW</sub> rail, LDO\_LOW has to be turned off again after the system wakes up by setting the register:

- POWER CTRL REG[LDO LOW CTRL REG] = 0x1
- Register settings when the V<sub>BAT\_LOW</sub> rail is powered by LDO\_LOW:
  - POWER CTRL REG[LDO LOW CTRL REG] = 0x3

#### 5.2.3.2 Boost Configuration

### NOTE

In the Boost configuration, several diodes between  $V_{BAT\_HIGH}$  and  $V_{BAT\_LOW}$  can prevent  $V_{BAT\_HIGH}$  from dropping more than a few hundred millivolts below  $V_{BAT\_LOW}$ .

During boot, external circuits connected to the  $V_{BAT\_HIGH}$  rail must be disabled. To guarantee a smooth startup, a user must keep the total load of VBAT\\_HIGH to less than 50  $\mu$ A.

In Boost configuration (Figure 8), voltages on  $V_{BAT\_HIGH}$  and  $V_{DD}$  are generated from  $V_{BAT\_LOW}$  as explained below:

#### Hibernation Mode

Hibernation mode is generally a state in which the device stays longer. It is recommended to force the VBAT\_HL\_RES switch on to reduce the power consumption from the comparator. When the VBAT\_HL RES switch is on, VBAT\_HIGH is connected to VBAT\_LOW. The register setting is:

POWER AON CTRL REGIVBAT HL CONNECT RES CTRL] = 0x1

In the hibernation mode of the Boost configuration, the digital core V<sub>DD</sub> is powered from VDD Clamp.

## • Extended Sleep and Deep Sleep Modes

The digital core  $V_{DD}$  is supplied by LDO\_CORE switched to retention mode. The reference voltage for this LDO is generated by periodically enabling and sampling the bandgap (see Section 5.3.3 for details).  $V_{BAT\ HIGH}$  rail can be supplied by the following options:

- Diodes controlled: V<sub>BAT\_HIGH</sub> is connected to V<sub>BAT\_LOW</sub> via diodes. This option is useful for short sleep durations, typically below a second. When no significant load is present on V<sub>BAT\_HIGH</sub>, it will not drop below V<sub>BAT\_LOW</sub> during the sleep interval. This is the reset setting.
- Software controlled: VBAT\_HIGH and VBAT\_LOW are connected via VBAT\_HL\_RES. In typical use
  cases, this setting is energy efficient for sleep durations longer than one second. This mode
  requires the following register settings:
  - POWER\_CTRL\_REG[LDO\_CORE\_RET\_ENABLE] = 0x1

**Final** 

- POWER\_AON\_CTRL\_REG[VBAT\_HL\_CONNECT\_RES\_CTRL] = 0x2
- O HW controlled: For short sleep durations, typically under one second, in combination with increased load conditions that can discharge V<sub>BAT\_HIGH</sub> to the level of V<sub>BAT\_LOW</sub> during the sleep interval, it is recommended to use the HW-controlled V<sub>BAT\_HIGH</sub> connection, in which the two rails are connected as soon as V<sub>BAT\_HIGH</sub> drops to the same level of V<sub>BAT\_LOW</sub> (+/- 50 mV). This mode requires the following register settings:
  - POWER\_AON\_CTRL\_REG[LDO\_CORE\_RET\_ENABLE] = 0x1
  - POWER\_CTRL\_REG[CMP\_VBAT\_HIGH\_OK\_ENABLE] = 0x1
  - POWER\_AON\_CTRL\_REG[VBAT\_HL\_CONNECT\_RES\_CTRL] = 0x3

#### Active and Sleep Modes

In these modes, the V<sub>BAT\_HIGH</sub> rail is normally powered by the DCDC converter at 1.8 V. This level can be changed to 2.5 V or 3.0 V by configuring POWER\_LEVEL\_REG[DCDC\_LEVEL].

Since the Boost converter is only needed to generate 1.8 V allowing for accessing to the OTP cell and supply the GPIOs, it is possible to disable it when access to the OTP is not required and no GPIOs are being driven. In this mode the  $V_{BAT\_HL\_SW}$  should be activated to clamp  $V_{BAT\_HIGH}$  at  $V_{BAT\_LOW}$ , allowing some load on  $V_{BAT\_HIGH}$  and GPIO operation at a reduced speed and voltage. Note that this mode rapidly discharges  $V_{BAT\_HIGH}$  from the boosted voltage down to the  $V_{BAT\_LOW}$  level. Also, the POR HIGH block has to be masked or disabled to avoid resets:

- if it is masked, the POR\_HIGH status remains available, but it will not generate a reset
- o if it is disabled, the status becomes unavailable as well

The following settings are required to enter this mode of operation:

- POWER\_CTRL\_REG[POR\_VBAT\_HIGH\_DISABLE] = 0x1 (Disable) or
- POWER\_AON\_CTRL\_REG[POR\_VBAT\_HIGH\_RST\_MASK] = 0x1 (Mask)
- DCDC\_CTRL\_REG[DCDC\_ENABLE] = 0x0
- POWER\_CTRL\_REG[VBAT\_HL\_CONNECT] = 0x1

## 5.2.3.3 Bypass Configuration

In the bypass configuration, the  $V_{BAT\_HIGH}$  and  $V_{BAT\_LOW}$  rails are shorted on the PCB. This configuration is detected by the chip as a boost configuration, but since the boost converter is not able to generate a voltage on  $V_{BAT\_HIGH}$ , the initial voltage has to be above 1.75 V to allow the OTP to be read and mirrored.

The software can disable the DCDC converter and LDO\_LOW to reduce quiescent current and avoid unnecessary switching of the DCDC converter. The following register settings are required to accomplish this:

- DCDC CTRL REG[DCDC ENABLE] = 0x0
- POWER\_CTRL\_REG[LDO\_LOW\_CTRL\_REG] = 0x1

If the voltage drops below 1.75 V, POR\_HIGH must be masked to prevent unnecessary resets. The OTP reads cannot be performed after this point. Masking POR\_HIGH is done by the following setting:

POWER AON CTRL REGIPOR VBAT HIGH RST MASK] = 0x1

When POR\_HIGH is masked, its status remains available, but it will not generate a reset. POR HIGH can be also disabled by the following setting:

• POWER\_CTRL\_REG[POR\_VBAT\_HIGH\_DISABLE] = 0x1

When POR\_ HIGH is disabled, its status becomes unavailable.

**Final** 

## 5.3 HW FSM (Power-Up, Wake-Up, and Go-to-Sleep)

The HW Finite State Machine (FSM) responsible for the power-up, wake-up, and go-to-sleep processes of the system is presented in Figure 11.



Figure 11: Power-Up/Wake-Up/Sleep FSM Diagram

The details of the power-up, wake-up, and sleep sequences of the FSM for the different modes are described in the following sections.

In Boost configuration the DCDC is enabled by the Booter during power up. After waking up, if the DCDC was left enabled, it will be started by the HW FSM. In Buck configuration, upon a wake-up, the DCDC is enabled by programming DCDC\_CTRL\_REG[DCDC\_ENABLE]. If DCDC\_ENABLE is kept asserted before the system goes to sleep, the DCDC will be started by the HW FSM upon waking up. If DCDC\_ENABLE is cleared before the system goes to sleep, the DCDC can only be started by SW asserting this bit after a wake-up. When the system is allowed to go to sleep, the HW FSM is activated and the DCDC controller is automatically turned off.

## 5.3.1 Power-Up/Wake-Up in Buck Configuration

At the beginning of a power-up (cold boot), the PMU detects whether the system is in a Buck or a Boost configuration, and this decision is retained from that point on. The power-up (cold boot) sequence of the Buck configuration is shown in Figure 12. When the system is at the start of the



**Final** 

Buck configuration path, then V<sub>BAT\_HIGH</sub> rail has a stable supply already and "boost\_mode = 0" (which means buck is identified) has been set.

To start the system, it is required that the  $V_{BAT\_LOW}$  rail is also brought up to an acceptable level, which is done by HW, enabling the resistive switch VBAT\_HL\_RES and monitoring POR\_LOW. The rising voltage of the  $V_{BAT\_LOW}$  rail will eventually trigger POR\_LOW to "ok" after that, the bandgap will be enabled. The HW FSM runs at 32 kHz from the RC32K oscillator at this time, and it will dynamically change to 512 kHz in one clock cycle after the switch is enabled. The HW FSM will continue working at 512 kHz. When the reference voltage from the bandgap is stable, LDO\_LOW is enabled. After a stable 1.1 V is generated, LDO\_CORE is enabled to generate a stable  $V_{DD}$  of 0.9 V. After this, the main system clock, RC32MHz, is enabled. All conditions are now in place to release the system reset so that the Booter can start running. An indicative time needed to power up the system in Buck configuration up until the application SW starts running, is around 2.5 ms. The time required to charge  $V_{BAT\_LOW}$  and  $V_{BAT\_HIGH}$  depends on the external capacitor values on these rails.



Figure 12: Power-Up (Buck)

In hibernation, the resistive switch VBAT\_HL\_RES can be closed to pre-charge V<sub>BAT\_LOW</sub> to the level of V<sub>BAT\_HIGH</sub> by programming POWER\_AON\_CTRL\_REG[VBAT\_HL\_CONNECT\_RES\_CTRL]. Therefore, during the wake-up sequence from the hibernation mode, step "Charge V<sub>BAT\_LOW</sub>" can be omitted (Figure 13) via POWER\_AON\_CTRL\_REG[CHARGE\_VBAT\_DISABLE]. All other steps are the same as in the power-up cold-boot sequence. The total time needed to wake up the system from hibernation up until booter software starts running is around 185 µs.



Figure 13: Wake-Up from Hibernation (Buck)

The wake-up sequence from the clocked, extended sleep, or deep sleep mode using an external GPIO toggle is shown in Figure 14. The difference between the power-up and wake-up sequence in the Buck configuration is that the  $V_{BAT\_LOW}$  rail is already charged via the switch  $VBAT\_HL\_RES$  in the wake-up sequence as shown in Figure 11. Therefore, when the system wakes up from a deep sleep or an extended deep sleep, the bandgap will be enabled within one 32 kHz clock cycle after the wake-up signal is triggered. After the bandgap is enabled, LDO\_LOW and LDO\_CORE will be enabled one after the other. The total time which is needed to wake up the system until the software starts running is around 800  $\mu$ s. If RAM has been retained, running software means application, if not then the Booter will be started.

**Final** 



Figure 14: Wake-Up (Buck)

A GPIO trigger will have to go through the wake-up controller first, which requires 7 RCX clock cycles before it is allowed to trigger the PMU and have the state machine running. Even after all power rails are done, switching the system clock from RCX into RC32M (so software starts running) takes 3.5 RCX clock cycles (indicated in state = RUNNING:SWITCH) in Figure 14.

If the system wakes up from an internal timer running at the RCX clock, then the WokenUp signal will be asserted 6 RCX clock cycles after the timer generates the interrupt (for example,  $\sim$ 400  $\mu$ s).

## 5.3.2 Power-Up/Wake-Up in Boost Configuration

At the beginning of a power-up (cold boot), the PMU detects whether the system is in a Buck or a Boost configuration, and this decision is retained in the system. The power-up (cold boot) sequence of the Boost configuration is shown in Figure 15. When the system is at the start of the Boost configuration path, then  $V_{BAT\_LOW}$  has a stable supply already and "boost\_mode = 1" (which means boost is identified) has been set.

Because the supply on the V<sub>BAT\_LOW</sub> rail is already on an acceptable level, the bandgap will be enabled in the first step and LDO\_CORE in the second step. After this, the resistive switch VBAT\_HL\_RES is closed to bring V<sub>BAT\_HIGH</sub> up to the same level as V<sub>BAT\_LOW</sub>. This is needed for the DCDC converter to start since its drivers run on the V<sub>BAT\_HIGH</sub> rail. When the V<sub>BAT\_HIGH</sub> rail is stable, the system reset can be released for the Booter to start running. The DCDC will be enabled during the first actions in the Booter (Section 5.5). An indicative time that is needed to power up the system in Boost configuration up until software starts running is around 1.2 ms. The time required to charge V<sub>BAT\_HIGH</sub> depends on the external capacitor values on this rail.



Figure 15: Power-Up (Boost)

In hibernation, the resistive switch VBAT\_HL\_RES can be closed to pre-charge  $V_{BAT\_HIGH}$  to the level of  $V_{BAT\_LOW}$  by programming POWER\_AON\_CTRL\_REG[VBAT\_HL\_CONNECT\_RES\_CTRL]. Therefore, during the wake-up sequence from the hibernation mode, step "Charge  $V_{BAT\_HIGH}$ " can be omitted (Figure 16) via POWER\_AON\_CTRL\_REG[CHARGE\_VBAT\_DISABLE]. All other steps are the same as in the power-up cold-boot sequence. The total time needed to wake up the system from hibernation up until booter software starts running is around 180  $\mu$ s.



**Final** 



Figure 16: Wake-Up from Hibernation (Boost)

In the wake-up sequence from deep or extended sleep using a GPIO toggle, the step Charge  $V_{BAT\_HIGH}$  lasts minimum 4 clock cycles (Figure 17). This time is sufficient to quickly re-charge  $V_{BAT\_HIGH}$  under the condition that the leakage current and the sleep interval are sufficiently low and the  $V_{BAT\_HIGH}$  voltage does not drop below  $V_{BAT\_LOW}$ . The state Charge  $V_{BAT\_HIGH}$  can be omitted by using the resistive paths. The total time which is needed to power up the system until the software starts running is around 865  $\mu$ s. If RAM has been retained, running software means application, if not then the Booter will be started.



Figure 17: Wake-Up from Extended/Deep Sleep (Boost)

A GPIO trigger will have to go through the wake-up controller first, which requires 7 RCX clock cycles before it can trigger the PMU and have the state machine running. Even after all power rails are done, switching the system clock from RCX into RC32M (so software starts running) takes 3.5 RCX clock cycles (indicated in state = RUNNING:SWITCH) in Figure 17.

If the system wakes up from an internal timer running at the RCX clock, then the WokenUp signal will be asserted 6 RCX clock cycles after the timer generates the interrupt (for example, ~400 µs).

## 5.3.3 Go-to-Sleep and Refresh Bandgap

The system can enter a sleep state, either sleep Buck or sleep Boost, depending on the status of the <code>boost\_mode</code> bit. The sleep state disables the power-consuming blocks and triggers the "hold mode" for the bandgap referenced voltages. After a certain amount of time (sleep refresh counter), these "hold" voltages need to be refreshed. The lower loop of the FSM in Figure 11 enables the bandgap, refreshes the voltages, checks for BOD events via the POR circuits and if ok, resets the refresh timer and goes back to sleep. This is an autonomous cycle led by hardware until the system is woken up by a wake-up event. The refresh timer can be configured by setting the PMU\_SLEEP\_REG [BG\_REFRESH\_INTERVAL] bit field (1 LSB = 64 × 32 kHz clock cycles). The go-to-sleep and the bandgap refresh sequence are shown in Figure 18.



**Final** 



Figure 18: Go-to-Sleep and Bandgap Refresh

# 5.4 OTP Memory Layout

The OTP memory has to be programmed according to a specific layout, which structures information to be easily accessible from the BootROM code as well as the actual application. An overview of the layout scheme is presented in Figure 19.



Figure 19: OTP Layout Scheme

The OTP memory is a matrix of 8Kx32-bit words. The contents are described below:

- Interrupt Vectors: they are the vectors of the interrupt service routines and always reside at the address 0x0. This is part of the application (customer) code. The size of this vector list is 32 words
- **Customer Code:** it contains the applications and the profiles that a customer has developed. The size is known and fixed before the mass production and the programming of the OTP
- Configuration Script (Section 5.4.2): it is used to program registers with values that are defined during production testing, to store a trim value for the application software, and to define the UART time-out timer during booting. It is executed by the Booter to prepare and initialize the system before the CPU starts running the application code. Available size is 60 words
- **OTP Header:** it contains various information about the configuration of the system and the Bluetooth® LE-specific data. The size of the header is 16 words

#### 5.4.1 OTP Header

The OTP header breakdown is presented in Table 36.



**Final** 

Table 36: OTP Header

|         | Words    |                                                                                                                                                                                                                                                                                                                                                  | Programmed during |                          |  |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------|--|
| Address | (32-bit) | Description                                                                                                                                                                                                                                                                                                                                      | Chip Test         | Product<br>Manufacturing |  |
| 7F87FC0 | 1        | Application Programmed Flag #1 0x1234A5A5 = Application is in OTP                                                                                                                                                                                                                                                                                |                   | Yes                      |  |
| 7F87FC4 | 1        | Application Programmed Flag #2 0xA5A51234 = Application is in OTP                                                                                                                                                                                                                                                                                |                   | Yes                      |  |
| 7F87FC8 | 1        | Boot-specific configuration:  Bits[7:0]:  OxAA = Boot from SPI port at a specific location  OxFF = Normal sequence  Bits[15:8] = Wake up Command opcode  Bits[23:16] = SPI_DIV  Bits[31:24]:  Ox00 = Two-wire UART (P0_0/P0_1)  Ox01 = One-wire UART (P0_3)  Ox02 = One-wire UART (P0_5)  Default (all other values) = Two-wire UART (P0_0/P0_1) |                   | Yes                      |  |
| 7F87FCC | 1        | Boot-specific port mapping:  Bits[7:4] = SPI_CLK, Port number  Bits[3:0] = SPI_CLK, Pin number  Bits[15:12] = SPI_EN, Port number  Bits[11:8] = SPI_EN, Pin number  Bits[23:20] = SPI_DO, Port number  Bits[19:16] = SPI_DO, Pin number  Bits[31:28] = SPI_DI, Port number  Bits[27:24] = SPI_DI, Pin number                                     |                   | Yes                      |  |
| 7F87FD0 | 1        | Device and Package Flag:  Bits[7:0]:  0 0xFF = WLCSP with P0_5  0 0x66 = WLCSP without P0_5  0 0xAA = FCGQFN24  Bits[15:8]:  0 0xFF = 531  0 0x30 = 530  Others = Reserved  Bits[31:16] = Reserved                                                                                                                                               | Yes               |                          |  |
| 7F87FD4 | 2        | Bluetooth Device Address (64-bit word). It is handled as a string of bytes.                                                                                                                                                                                                                                                                      |                   | Yes                      |  |
| 7F87FDC | 1        | OTP DMA length (number of 32-bit words).                                                                                                                                                                                                                                                                                                         |                   | Yes                      |  |



**Final** 

|         | Words<br>(32-bit) | Description                                                                                                       | Programmed during |                          |  |
|---------|-------------------|-------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------|--|
| Address |                   |                                                                                                                   | Chip Test         | Product<br>Manufacturing |  |
| 7F87FE0 | 1                 | Position: Bits[7:0] = X coord Bits[15:8] = Y coord Bits[23:16] = Wafer # Bits[31:24] = LOT #                      | Yes               |                          |  |
| 7F87FE4 | 1                 | Tester: Bits[7:0] = Tester_Site Bits[15:8] = Tester_ID (LSB) Bits[23:16] = Tester_ID (MSB) Bits[31:24] = Reserved | Yes               |                          |  |
| 7F87FE8 | 1                 | TimeStamp: Bits[7:0] = TS_Byte0 Bits[15:8] = TS_Byte1 Bits[23:16] = TS_Byte2 Bits[31:24] = TS_Byte3               | Yes               |                          |  |
| 7F87FEC | 5                 | Reserved for Future Needs                                                                                         |                   |                          |  |

The Device and Package Flag reflects what the current device (DA14531) is and which package is used. Default (unprogrammed) values are 0xFFFFFFF.

Boot-specific mapping value is used to define a specific configuration for the SPI interface when used for booting from an external device (either an MCU or a FLASH). Byte0 is the flag to instruct the BootROM to use the specific SPI pin mapping and skip the rest of the serial peripheral interfaces. The BootROM takes care of waking up an external flash when the flash memory is in a deep power-down state.

Byte1 is used for the Wake-up Command opcode that the flash memory responds to. If Byte0 is left unprogrammed, BootROM will send the "0xAB" opcode by default. Furthermore, the BootROM can wake up the external flash by toggling the CS pin.

Two more flags indicate whether the application code has indeed been programmed (burned) into the OTP. Both flags are read by the BootROM software designating that the system is in the Normal mode and not in the Development mode (Section 5.5).

#### 5.4.2 Configuration Script

The Configuration Script (CS) is a table of 32-bit entries and is 60 words deep, so in total, the CS can utilize 240 bytes of space.

The CS is used to program registers with values that are defined during production testing, to store a trim value for the application software, and to define the UART time-out timer during booting. It is executed by the Booter to prepare and initialize the system before the CPU starts running the application code.

The format of the commands in the CS is presented in Table 37.

# **Table 37: CS Commands and Description**

| # | Command Type  | Description                                                             |
|---|---------------|-------------------------------------------------------------------------|
| 1 | Start Command | One 32-bit word containing 0xA5A5A5A5 to signal a valid CS is in place. |

**Final** 

| # | Command Type              | Description                                                                                                                                                                                                                                                |  |  |
|---|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2 | Register<br>Configuration | <ul> <li>One 32-bit word containing an address of an existing register</li> <li>One 32-bit word containing the data value of the register</li> <li>These are always in pairs with the address sitting in even memory addresses.</li> </ul>                 |  |  |
|   |                           | One 32-bit word which is equal to 0x9000YYXX indicating that the next word is a value stored during production testing. More specifically:                                                                                                                 |  |  |
|   | CDK Value                 | <ul> <li>9: it indicates that the following word(s) are not to be stored to registers but will be<br/>used by the SDK SW</li> </ul>                                                                                                                        |  |  |
| 3 | SDK Value                 | YY: it indicates that YY amount of words follow                                                                                                                                                                                                            |  |  |
|   |                           | <ul> <li>XX: it is an increasing value and can be used for indexing by the SW application.</li> <li>If YY &gt; 1, XX will not be increased for the words that belong to the same value</li> </ul>                                                          |  |  |
|   |                           | One or more 32-bit words can represent one value.                                                                                                                                                                                                          |  |  |
| 4 | SWD mode                  | One 32-bit word which is equal to 0x70000000. It prevents the JTAG from being enabled at the end of the Booter and the Booter will not enter the endless while (1) loop. Instead, it will continue to rescan all peripherals in the development mode path. |  |  |
| 5 | UART STX<br>timeout value | One 32-bit word which is equal to 0x8XXXXXXX. The XXXXXXX is used to program the selected STX timeout in multiples of 100 $\mu$ s. So, for example, 0x80000028 is 40 × 100 $\mu$ S = 4 ms.                                                                 |  |  |
| 6 | SPI Clock value           | 0xA0000000  This value overwrites the default 2-MHz clock speed of the SPI boot path and sets it to 32 MHz.                                                                                                                                                |  |  |

The Booter stops processing the CS once it encounters an empty OTP value (0xFFFFFFF). This way, no more processing time is spent checking the rest and it is possible to add new entries later, for example, to patch/update previous entries.

An example describing the format of the configuration script is presented in Table 38.

**Table 38: CS Example** 

| Words | Even Words          | Odd Words         | Description                                                                                  |
|-------|---------------------|-------------------|----------------------------------------------------------------------------------------------|
| 0-1   | 0xA5A5A5A5          | 0x80000028        | Start command of the CS Script, followed by STX timeout value of 4 ms (40 × 100 $\mu$ s)     |
| 2-3   | <address></address> | <value></value>   | Booter automatically writes the <value> to the <address></address></value>                   |
| 4-5   | 0x90000301          | <value></value>   | Three calibration values stored during production testing. SDK should know what this is for. |
| 6-7   | <value></value>     | <value></value>   |                                                                                              |
| 8-9   | <address></address> | <value></value>   | Booter automatically write the <value> to the <address></address></value>                    |
| 10-11 | <address></address> | <value></value>   | Booter automatically write the <value> to <address></address></value>                        |
| 12-13 | 0x90000402          | <value1></value1> | Four calibration values stored during production testing. SDK should know what this is for.  |
| 14-15 | <value2></value2>   | <value3></value3> | Calibration value stored during production testing. SDK should know what this is for.        |
| 16-17 | <value4></value4>   | 0x70000000        | Disable SWD                                                                                  |
| 18-19 | 0xFFFFFFF           | (don't care)      | Booter stops running the CS after an empty entry, so anything after this is "don't care".    |

# 5.5 BootROM Sequence

The booting process of DA14531 is presented in Figure 20. The Booter is always executed when a POR or an HW Reset occurs, or the RESET\_ON\_WAKEUP feature is configured.



**Final** 

The booter will start executing with the RC32M clock, to speed up its execution. Then the Booter checks whether the system is in the Boost configuration or not. The configuration (Buck or Boost) has been already decided by the HW and should be readable by SW at the ANA\_STATUS\_REG[BOOST\_SELECTED] bit field. To access the OTP, V<sub>BAT\_HIGH</sub> needs to be set at ≥ 1.8 V. In the Boost configuration the DCDC is enabled to boost V<sub>BAT\_HIGH</sub> at 1.8 V and BOOST\_VBAT\_OK = 1 confirms that the voltage at the DCDC is stable. After the OTP is operational, the Booter initializes the UART baud rate at 115.2 kHz, and the CS (Section 5.4.2) is enabled to be executed.

After the CS has been executed, the Booter has to decide whether the device is in Development or Normal mode by reading the two words indicated as application flags in the OTP. The OTP image is copied into RAM starting at address 0x0 by the Booter.

In Development mode, the "Boot from Specific" flag will be evaluated. If the flag is programmed, new pin locations for booting from an external SPI slave to make DA14531 an SPI Master will be set. The "Boot from Specific" flag addresses mostly the QFN package allowing for booting from a different pin configuration than the default one, so that the system can boot from an external FLASH using the development mode. The details of the configuration are presented in Section 5.4.1. If this path is entered, the system will always try to boot from UART so that the SPI Flash can be updated if needed. Any of the three UART configurations specified in Table 39 can be selected by writing bits [31:24] at the "Boot specific config" field in the OTP header. If booting from SPI Flash fails, the Booter will jump back to the normal scan sequence of the peripheral devices.

If the "Boot from Specific" flag is not programmed, the system should continue with scanning the different serial interfaces to identify whether a device is connected to it. After OTP is disabled, six steps as described in Table 39 are performed. Before using the UART, the XTAL32M clock needs to be enabled. All the boot steps are protected by a timeout.



**Final** 



Figure 20: BootROM Sequence

The one-wire UART boot capability is introduced due to the limited amount of GPIOs in the WLCSP package. The one-wire UART boot leaves four GPIOs for the application and one GPIO for programming/debugging. Since the booting from the UART protocol is a half-duplex, a single GPIO is used in DA14531 for the external UART. The protocol is the same as for a two-wire UART booting except that the Booter SW needs to change the pin direction before sending or receiving information.



**Final** 

**Table 39: Booting Sequence Steps** 

|          | Step 1:<br>Boot from<br>External<br>SPI Master | Step 2: Boot<br>from 1-wire<br>UART (First<br>Option) | Step 3:<br>Boot from<br>1-wire<br>UART<br>(Second<br>Option) | Step 4:<br>Boot from<br>2-wire<br>UART | Step 5:<br>Boot from<br>External<br>SPI Slave | Step 6:<br>Boot from<br>I2C |
|----------|------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------|----------------------------------------|-----------------------------------------------|-----------------------------|
| P0_0/RST | MISO                                           |                                                       |                                                              | Tx                                     | MOSI                                          |                             |
| P0_1     | MOSI                                           |                                                       |                                                              | Rx                                     | SCS                                           |                             |
| P0_2     |                                                |                                                       |                                                              |                                        |                                               |                             |
| P0_3     | SCS                                            |                                                       | RxTx                                                         |                                        | MISO                                          | SDA                         |
| P0_4     | SCK                                            |                                                       |                                                              |                                        | SCK                                           | SCL                         |
| P0_5     |                                                | RxTx (Default)                                        |                                                              |                                        |                                               |                             |
| P0_6     |                                                |                                                       |                                                              |                                        |                                               |                             |
| P0_7     |                                                |                                                       |                                                              |                                        |                                               |                             |
| P0_8     |                                                |                                                       |                                                              |                                        |                                               |                             |
| P0_9     |                                                |                                                       |                                                              |                                        |                                               |                             |
| P0_10    |                                                |                                                       |                                                              |                                        |                                               |                             |
| P0_11    |                                                |                                                       |                                                              |                                        |                                               |                             |

If no bootable devices are found on any of the serial interfaces, the Booter can do two things, depending on what is stored in the CS. If the "Debugger disable" (0x70000000) command is stored there, the Booter will start scanning for peripherals again. Otherwise, it enters the endless loop with the debugger (JTAG) being enabled. The debugger can be connected to P0\_5 in the WLCSP17 package or P0\_10 in the FCGQFN24 package.

After the BootROM sequence has been completed, the default system clock is RC32M, regardless of which boot path has been chosen and all GPIOs are set back to their default reset values.

**Final** 

## 6 Reset

## 6.1 Introduction

The DA14531 comprises a reset (RST) pad which is active high. It contains an RC filter with a resistor of 465 k $\Omega$  and a capacitor of 3.5 pF to suppress spikes. It also contains a 25 k $\Omega$  pull-down resistor. This pad should be driven externally by a field-effect transistor (FET) or a single button connected to VBAT. The typical latency of the RST pad is in the range of 2  $\mu$ s.

#### **Features**

- RC spike filter on RST to suppress external spikes (465 kΩ, 3.5 pF)
- Three different reset lines (SW, HW, and POR)
- Latching the cause of a reset operation (RESET\_STAT\_REG)
- Configurable POR circuitry



Figure 21: Reset Block Diagram

## 6.2 Architecture

## 6.2.1 POR, HW, and SW Reset

There are three main reset signals in the DA14531:

- The Power-On Reset (POR): it is optionally triggered by a GPIO set as the POR source with a selectable polarity and/or the RST pad (PO\_0) after a programmable time delay
- The HW reset: it is optionally triggered by the RST pad (P0\_0) when it becomes active for a short period of time (less than the programmable delay for POR)
- The SW reset: it is triggered by writing the SYS\_CTRL\_REG[SW\_RESET] bit

The POR signal is generated:

- Internally and will release the system's flip flops as soon as the VDD, VBAT\_HIGH, and VBAT\_LOW voltages crossed the specified thresholds
- Externally by a POR source (RST pad multiplexed on a GPIO or P0\_0 configured as RST pin)



**Final** 

The HW reset can also be automatically activated when the system wakes up from the Extended or Deep Sleep mode by programming the bit PMU\_CTRL\_REG[RESET\_ON\_WAKEUP]. The POR and the HW reset basically run the cold start-up sequence and the BootROM code is executed.

The SW reset is the logical OR of a signal from the Cortex CPU (triggered by writing SCB->AIRCR = 0x05FA0004) and the SYS\_CTRL\_REG[SW\_RESET] bit. It is mainly used to reboot the system after the base address has been remapped.

The block diagram of the reset block is depicted in Figure 21.

Certain registers are reset by POR only, or by POR and the HW reset signal but not by the SW reset. These registers are listed in Table 40.

**Table 40: Reset Signals and Registers** 

| Reset by POR Only            | Reset by POR or HW Reset | Reset by POR, HW Reset, or SW Reset |
|------------------------------|--------------------------|-------------------------------------|
| BANDGAP_REG                  | BLE_CNTL2_REG            | The rest of the Register File       |
| POR_PIN_REG                  | CLK_AMBA_REG[OTP_ENABLE] |                                     |
| POR_TIMER_REG                | CLK_FREQ_TRIM_REG        |                                     |
| HWR_CTRL_REG                 | CLK_RADIO_REG            |                                     |
| RESET_STAT_REG[PORESET_STAT] | CLK_CTRL_REG             |                                     |
| PAD_LATCH_REG                | PMU_CTRL_REG             |                                     |
| POWER_AON_CTARL_REG          | SYS_CTRL_REG             |                                     |
| GP_DATA_REG                  | TRIM_CTRL_REG            |                                     |
| TEST_VDD_REG                 | RAM_PWR_CTRL_REG         |                                     |
|                              | CLK_RC32K_REG            |                                     |
|                              | CLK_XTAL32K_REG          |                                     |
|                              | CLK_RC32M_REG            |                                     |
|                              | CLK_RCX_REG              |                                     |
|                              | XTALRDY_CTRL_REG         |                                     |
|                              | XTAL32M_CTRL0_REG        |                                     |
|                              | PMU_SLEEP_REG            |                                     |
|                              | POWER_CTRL_REG           |                                     |
|                              | POWER_LEVEL_REG          |                                     |
|                              | DCDC_CTRL_REG            |                                     |
|                              | RAM_LPMX_REG             |                                     |
|                              | HIBERN_CTRL_REG          |                                     |
|                              | CLK_RTCDIV_REG           |                                     |
|                              | RTC_CONTROL_REG          |                                     |
|                              | RTC_KEEP_RTC_REG         |                                     |
|                              | OTPC_*_REG               |                                     |
|                              | QDEC_*_REG               |                                     |



**Final** 

| Reset by POR Only | Reset by POR or HW Reset     | Reset by POR, HW Reset, or SW Reset |
|-------------------|------------------------------|-------------------------------------|
|                   | All RF calibration registers |                                     |

## 6.2.2 POR Functionality

The POR functionality is available by two sources:

- RST Pad: the RST pad is always capable of producing a POR
- GPIO Pin: a GPIO can be selected by the user application to act as a POR source

The time needed for a GPIO pin selected for the POR to be active is stored in the POR\_TIMER\_REG. The register field POR\_TIME is a 7-bit field that holds the time factor by which the total time for POR is calculated. The maximum value of the field is 0x7F. The total time for POR is calculated by the following formula:

Total time = 
$$POR_TIME \times 4096 \times RC32k$$
 clock period (1)

where RC32k clock period = 31.25 µs at 25 °C.

The maximum time for which a POR can be performed is ~16.2 seconds at 25 °C.

The RC32k clock frequency depends on temperature, so based on the temperature span of -10 °C to 50 °C, the clock frequency range is calculated to be 25 kHz to 39 kHz. Then,

 $T_{PORcold} = 13 s$ 

 $T_{PORhot} = 20.8 s$ 

### 6.2.2.1 POR Timer Clock

The POR timer is clocked by the RC32k clock. If an SW application disables the RC32k, the HW takes care of enabling the RC32k clock when a POR source (the RST pad or a selected GPIO pin) is asserted. It should be noted that if the POR is generated from the RST pad, the RC32k will operate with the reset (default) trimming value. If a GPIO pin is used as the POR source, the RC32k clock will be trimmed. The timing difference between both cases is expected to be minor.

#### 6.2.2.2 RST Pad

The RST pad will produce an HW reset if the pin active time is less than the programmed value in the POR\_TIMER\_REG register or a POR if the pin active time is greater than or equal to that value. Reset pad is always Active High.

### 6.2.2.3 POR from GPIO

When a GPIO is used as a POR source, the selected pin retains its capability to act as GPIO. The POR\_PIN\_REG[PIN\_SELECT] field holds the required GPIO pin number. If the value of the PIN\_SELECT field equals 0, the POR triggered by GPIO functionality is disabled. The polarity of the pin can be configured by the POR\_PIN\_REG [POR\_POLARITY] bit, where 0 means Active Low and 1 means Active High.

# 6.2.3 POR Timing Diagram

The operation of the POR triggered by both the RST pad and a selected GPIO pin is depicted in Figure 22.

**Final** 



Figure 22: POR Timing Diagram

#### 6.2.4 POR Considerations

When a POR source (the RST pad or a selected GPIO pin) is asserted, the POR timer starts to count. When the POR source is released before the timer has expired, the POR timer will be reset to 0. If a POR source is asserted while there is already an asserted POR, and the first POR is released after the second POR is asserted, and the total time of the two asserted sources is larger than or equal to the POR TIME, POR will occur.

It should also be noted that the POR timer triggered by the RST pad can only expire once. After the POR timer has expired, the RST pad has to be released so the timer can be reloaded. There is no such limitation when a GPIO is used as the POR source.

The POR\_PIN\_REG[PIN\_SELECT] field cannot survive any reset (POR, HW reset, or SW reset), therefore, users must take special care on setting up the GPIO POR source right after a reset. This also applies to the POR\_TIMER\_REG[POR\_TIME] field after a POR.

Be aware that, if a GPIO is used as a POR source, the dynamic current of the system increases due to the dynamic current consumed by the RC32k oscillator. This increase is calculated to be from 100 nA to 120 nA and it is also present during the sleep time period. POR from the RST pad does not add this dynamic current consumption.

## 6.3 Programming

To configure the functionality of triggering a POR by a GPIO pin, follow the steps below:

- 1. Select a GPIO to be set as the POR source by programming POR PIN REG[POR PIN SELECT].
- 2. Set up the input polarity of the GPIO that causes POR by programming POR\_PIN\_REG[POR\_PIN\_POLARITY].
- 3. Configure the time for the POR to happen by programming POR\_TIMER\_REG[POR\_TIME]. The default time is around three seconds.

| NOTE          |                                                                              |
|---------------|------------------------------------------------------------------------------|
| To set up the | e time when the RST pad produces a POR, just set the POR_TIMER_REG register. |

**Final** 

# 7 Arm Cortex-M0+

### 7.1 Introduction

The Arm Cortex-M0+ processor is a 32-bit Reduced Instruction Set Computing (RISC) processor with a von Neumann architecture (single bus interface). It uses an instruction set called Thumb, which was first supported in the ARM7TDMI processor, but it also uses several newer instructions from the Armv6 architecture and a few instructions from the Thumb-2 technology. Thumb-2 technology extends the previous Thumb instruction set to allow all operations to be carried out in one CPU state. The instruction set in Thumb-2 includes both 16-bit and 32-bit instructions; most instructions generated by the C compiler use the 16-bit instructions, and the 32-bit instructions are used when the 16-bit version cannot carry out the required operations. This results in high code density and avoids the overhead of switching between two instruction sets.

In total, the Cortex-M0+ processor supports only 56 base instructions, although some instructions can have more than one form. Although the instruction set is small, the Cortex-M0+ processor is highly capable because the Thumb instruction set is highly optimized.

Academically, the Cortex-M0+ processor is classified as load-store architecture, as it has separate instructions for reading and writing to memory, and instructions for arithmetic or logical operations that use registers. It has a two-stage pipeline (fetch+predecode and decode+execute) as opposed to its predecessor (Cortex-M0) that has a three-stage pipeline (fetch, decode, and execute).

A simplified block diagram of the Cortex-M0+ is shown in Figure 23.



Figure 23: Arm Cortex-M0+ Block Diagram

## **Features**

- Thumb instruction set: highly efficient, of high code density, and able to execute all Thumb and Thumb-2 instructions
- High performance: up to 0.9 DMIPS/MHz (Dhrystone 2.1) with fast multiplier
- Built-in Nested Vectored Interrupt Controller (NVIC): this makes interrupt configuration and coding of exception handlers easy. When an interrupt request is taken, the corresponding interrupt handler is executed automatically without the need to determine the exception vector in software



**Final** 

- Interrupts can have four different programmable priority levels and the NVIC automatically handles nested interrupts
- The design is configured to respond to exceptions (for example, interrupts) as soon as possible (minimum 15 clock cycles)
- Non maskable interrupt (NMI) input for safety critical systems
- Easy to use and C friendly. There are only two modes, Thread mode and Handler mode. The whole application, including exception handlers, can be written in C without any assemblers
- Built-in System Tick timer for OS support. A 24-bit timer with a dedicated exception type is included in the architecture, which the OS can use as a tick timer or as a general timer in other applications without an OS
- SuperVisor Call (SVC) instruction with a dedicated SVC exception and Pendable SuperVisor service (PendSV) to support various operations in an embedded OS
- Architecturally defined sleep modes and instructions to enter sleep. The sleep features allow
  power consumption to be reduced dramatically. Defining sleep modes as an architectural feature
  makes porting of software easier because the sleep modes are entered by specific instructions
  rather than implementation defined control registers
- Fault handling exception to catch various sources of errors in the system
- Support for 21 interrupts
- Little endian memory support
- Wake-up Interrupt Controller (WIC) to allow the processor to be powered down during sleep, while interrupt sources are still allowed to wake up the system
- Halt mode debug allows the processor activity to stop completely so that register values can be accessed and modified. No overhead in code size and stack memory size
- CoreSight technology allows memories and peripherals to be accessed from the debugger without halting the processor
- Supports Serial Wire Debug (SWD) connections. The SWD protocol can handle the same debug features as the JTAG, but it only requires two wires and is already supported by a number of debug solutions from various tools vendors
- Four (4) hardware breakpoints and two (2) watch points
- Breakpoint instruction support for an unlimited number of software breakpoints
- Programmer's model similar to the ARM7TDMI processor. Most existing Thumb code for the ARM7TDMI processor can be reused. This also makes it easy for ARM7TDMI users, as there is no need to learn a new instruction set.

# 7.2 Architecture

# 7.2.1 Interrupts

This section lists all 21 interrupt lines, except the NMI interrupt, and describes their sources and functionality. The overview of the interrupts is illustrated in Table 41.

# Table 41: Interrupt List

| IRQ<br>Number<br>(Inherent<br>Priority) | IRQ Name           | Description                                                            |
|-----------------------------------------|--------------------|------------------------------------------------------------------------|
| 0                                       | BLE_WAKEUP_LP_IRQn | Wake up the system from Low Power (Extended Sleep) interrupt from BLE. |
| 1                                       | BLE_GEN_IRQn       | Bluetooth® LE Interrupt. Sources:                                      |

**Final** 

| IRQ<br>Number<br>(Inherent | IRQ Name         | Description                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|----------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Priority)                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|                            |                  | <ul> <li>BLE_FINETGTIM_IRQn: Fine Target Timer interrupt generated when Fine Target timer expires. The timer resolution is 625 µs base time reference</li> <li>BLE_GROSSTGTIM_IRQn: Gross Target Timer interrupt generated when Gross Target timer expired. The timer resolution is 16 times 625 µs base time reference</li> <li>BLE_CSCNT_IRQn: 625 µs base time reference interrupt,</li> </ul> |  |  |  |  |
|                            |                  | available in active modes                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|                            |                  | <ul> <li>BLE_SLP_IRQn: End of Sleep mode interrupt</li> <li>BLE_ERROR_IRQn: Error interrupt, generated when undesire</li> </ul>                                                                                                                                                                                                                                                                   |  |  |  |  |
|                            |                  | behavior or bad programming occurs in the BLE Core                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                            |                  | BLE_RX_IRQn: Receipt interrupt at the end of each received packets                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                            |                  | <ul> <li>BLE_EVENT_IRQn: End of Advertising/Scanning/Connection<br/>events interrupt</li> </ul>                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|                            |                  | BLE_CRYPT_IRQn: Encryption/Decryption interrupt, generated when AES and/or CCM processing is finished                                                                                                                                                                                                                                                                                             |  |  |  |  |
|                            |                  | BLE_SW_IRQn: SW triggered interrupt, generated on SW request                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| 2                          | UART_IRQn        | UART interrupt.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 3                          | UART2_IRQn       | UART2 interrupt.                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 4                          | I2C_IRQn         | I2C interrupt.                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 5                          | SPI_IRQn         | SPI interrupt.                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 6                          | ADC_IRQn         | Analog-Digital Converter interrupt.                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 7                          | KEYBRD_IRQn      | Keyboard interrupt.                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 8                          | BLE_RF_DIAG_IRQn | Baseband or Radio Diagnostics Interrupt. Triggered by internal events of the Radio or Baseband selected by the BLE_RF_DIAGIRQ_REG. For Debug purposes only.                                                                                                                                                                                                                                       |  |  |  |  |
| 9                          | RF_CAL_IRQn      | RF Calibration Interrupt.                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| 10                         | GPIO0_IRQn       | GPIO interrupt through debounce.                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 11                         | GPIO1_IRQn       | GPIO interrupt through debounce.                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 12                         | GPIO2_IRQn       | GPIO interrupt through debounce.                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 13                         | GPIO3_IRQn       | GPIO interrupt through debounce.                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 14                         | GPIO4_IRQn       | GPIO interrupt through debounce.                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 15                         | SWTIM_IRQn       | Timer0/2 interrupt.                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 16                         | WKUP_QUADEC_IRQn | Combines the Wake-up Capture Timer interrupt, the GPIO interrupt, and the QuadDecoder interrupt.                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 17                         | TIM1_IRQn        | Timer1 interrupt.                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 18                         | RTC_IRQn         | Real Time Clock interrupt.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
| 19                         | DMA_IRQn         | DMA interrupt.                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 20                         | XTAL32RDY_IRQn   | XTAL32M settling ready interrupt.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |

Interrupt priorities are programmable by the Arm Cortex-M0+. The lower the priority number, the higher the priority level. The priority level is stored in a byte-wide register, which is set to 0x0 at reset.



**Final** 

Interrupts with the same priority level follow a fixed priority order using the interrupt number listed in Table 41 (a lower interrupt number has a higher priority level).

To access the Cortex-M0+ NVIC registers, the Cortex Microcontroller Software Interface Standard (CMSIS) functions can be used. The input parameter IRQn of the CMSIS NVIC access functions is the IRQ number. This can be the IRQ number or (more conveniently) the corresponding IRQ name listed in Table 41. For example, the corresponding interrupt handler name in the vector table for IRQ#15 is SPI\_Handler. For more information on the Arm Cortex-M0+ interrupts and the corresponding CMSIS functions, see section 4.2 Nested Vectored Interrupt Controller in the Cortex-M0+ Devices Generic User Guide.

The Watchdog interrupt is connected to the NMI input of the processor.

## 7.2.2 System Timer (systick)

The Cortex-M0+ System Timer (SysTick) can be configured for using two different clocks. The SysTick Control & Status (STCSR) register specifies which clock should be used by the counter.

- STCSR[CLKSOURCE] = 0: use the (fixed) external reference clock STCLKEN of 1 MHz
- STCSR[CLKSOURCE] = 1: use the (HCLK\_DIV dependent) processor clock SCLK (for example, 2, 4, 8, or 16 MHz)

The default SysTick Timer configuration uses the (fixed) external reference clock STCLKEN (STCSR[CLKSOURCE] = 0). When necessary, higher clock frequencies can be used with STCSR[CLKSOURCE] = 1, but the software should take the HCLK\_DIV dependent core clock SCLK into account about the timing.

### 7.2.3 Wake-Up Interrupt Controller

The Wake-up Interrupt Controller (WIC) is a peripheral that can detect an interrupt and wake the processor from Extended Sleep mode. The WIC is enabled only when the SLEEPDEEP bit in the system control register is set to 1 (see *System Control Register* in the *Cortex-M0+ Technical Reference Manual*).

The WIC is not programmable and does not have any registers or user interface. It operates entirely from hardware signals. When the WIC is enabled and the processor enters Extended Sleep mode, the power management unit in the system can power down most of the Cortex-M0+ processor. This has the side effect of stopping the SysTick timer. When the WIC receives an interrupt, it takes a number of clock cycles to wake up the processor and restore its state before it can process the interrupt. This means the interrupt latency is increased in Extended Sleep mode.

# 7.3 Programming

For more information on the Arm Cortex-M0+, see the documents listed in Table 42.

**Table 42: Arm Documents List** 

|   | Document Title                              | Arm Document Number                                       |  |  |
|---|---------------------------------------------|-----------------------------------------------------------|--|--|
| 1 | Cortex-M0+ Devices Generic User Guide       | Arm DUI 0662B (available on the website)                  |  |  |
| 2 | Cortex-M0+ Technical Reference Manual, r0p1 | Arm DDI 0484C (available on the website)                  |  |  |
| 3 | Armv6-M Architecture Reference Manual       | Arm DDI 0419C (can be downloaded by registered customers) |  |  |

**Final** 

# 8 AMBA Bus

### 8.1 Introduction

The DA14531 is based on the AMBA 2.0 AHB and APB components. The AHB is an AMBA Lite version which requires a single master on the system, but there is arbitration between the Arm Cortex-M0+ CPU and the Direct Memory Access (DMA) engine. There are two APB bridges, one for APB16 and the other for APB32, implementing three different decoded slaves which are grouped according to the power domain structure of the chip.

The AMBA bus organization is presented in Figure 24.



Figure 24: AMBA Bus Architecture and Power Domains

### 8.2 Architecture

Since the DA14531 consists of several different power domains that are digitally controlled and can be shut down completely, various slave resources, especially on the APB bus, are grouped together to reduce signal isolation requirements. On the AHB Lite bus, the CPU or the DMA can be the master, while OTP, Bluetooth® LE Core, Memory and ROM controllers are slaves.

The Always On power domain (PD\_AON) contains only the clock-less wake-up controller and the start-up hardware FSM responsible for the activation of the power devices within the system.

The sleep power domain (PD\_SLP) contains the clock tree, the Bluetooth® LE Timer, the Clocked Wake-up Controller, and the Quadrature Decoder. These blocks are supposed to trigger or to capture wake-up events while the system is in any of the clocked sleep modes.

The timers power domain (PD\_TIM) contains special purpose timers that might or might not be crucial for an application: a full featured Real Time Clock (RTC) engine and Timer1. The registers of these blocks are 32-bit wide, hence they are connected to the APB32 bus.

The APB16 bus connects to the radio power domain (PD\_RAD), which consists of the Radio control unit and the Bluetooth® LE controller, and to the peripheral blocks which are all part of the same power domain as the CPU (PD SYS).



**Final** 

# 8.3 **Programming**

Since the AMBA Bus only acknowledges a single master at a time, a programmable arbitration is implemented to decide whether the Arm Cortex-M0+ or the DMA is the master. The priority can be configured in the GP\_CONTROL\_REG[CPU\_DMA\_BUS\_PRIO] with the CPU having the highest priority by default.

**Final** 

# 9 Memory Map

# Table 43: Memory Map

| Address                   | Description                                                                           | Power Domain |
|---------------------------|---------------------------------------------------------------------------------------|--------------|
| 0x00000000                | Boot/BLE ROM/OTP/RAM                                                                  |              |
| 0x04000000                | Remapped address space based on SYS_CTRL_REG[REMAP_ADR0].                             |              |
| 0x04000000<br>0x07F00000  | RESERVED                                                                              |              |
| 0x07F00000                | Boot/BLE ROM                                                                          |              |
| 0x07F24000                | Contains Boot ROM code and BLE protocol related code.                                 |              |
| 0x07F24000<br>0x07F40000  | RESERVED                                                                              |              |
| 0x07F40000                | OTP-Regs                                                                              | PD_SYS       |
| 0x07F40100                | Contains the control registers of the OTP Subsystem.                                  |              |
| 0x07F40100<br>0x07F80000  | RESERVED                                                                              |              |
| 0x07F80000                | ОТР                                                                                   |              |
| 0x07F88000                | Contains the OTP cell actual memory space.                                            |              |
| 0x07F88000<br>0x07F C0000 | RESERVED                                                                              |              |
| 0x07FC0000                | System RAM                                                                            |              |
| 0x07FCC000                | 48 kB. Contains application code, data for the application, stack, and                |              |
|                           | heap. SysRAM1 (16 kB): 0x07FC0000 to 0x07FC3FFF                                       |              |
|                           | SysRAM2 (12 kB): 0x07FC4000 to 0x07FC6FFF                                             |              |
|                           | SysRAM3 (20 kB): 0x07FC7000 to 0x07FCBFFF                                             |              |
| 0x07FD8000                | RESERVED                                                                              | l            |
| 0x40000000                |                                                                                       |              |
| 0x40000000                | AHB/BLE-Regs                                                                          | PD_RAD       |
| 0x40001000                | Contains the control registers of the BLE Link Layer Processor.                       |              |
| 0x40001000                | AHB/Radio                                                                             | PD_RAD       |
| 0x40004000                |                                                                                       |              |
| 0x40004000                | RESERVED                                                                              |              |
| 0x50000000                |                                                                                       |              |
| 0x50000000                | APB16/PMU-CRG                                                                         | PD_SLP       |
| 0x50000100                | Contains the control registers of the Power Management Unit and the Clock Generator.  |              |
| 0x50000100                | APB16/wake-up                                                                         | PD_SLP       |
| 0x50000200                | Contains the registers of the clocked and clock-less wake up controllers.             |              |
| 0x50000200                | APB16/Quadrature Decoder                                                              | PD_SLP       |
| 0x50000300                | Contains Logic that implements a step counter for X and Y axis from a rotary encoder. |              |
| 0x50000300                | RESERVED                                                                              |              |
| 0x50001000                |                                                                                       |              |



**Final** 

| Address    | Description                                             | Power Domain |
|------------|---------------------------------------------------------|--------------|
| 0x50001000 | APB16/UART                                              | PD_SYS       |
| 0x50001100 | Contains the control registers of the UART.             |              |
| 0x50001100 | APB16/UART2                                             | PD_SYS       |
| 0x50001200 | Contains the control registers of the UART2.            |              |
| 0x50001200 | APB16/SPI                                               | PD_SYS       |
| 0x50001300 | Contains the control registers of the SPI interface.    |              |
| 0x50001300 | APB16/I2C                                               | PD_SYS       |
| 0x50001400 | Contains the control registers of the I2C interface.    |              |
| 0x50001400 | APB16/Kbrd                                              | PD_SYS       |
| 0x50001500 | Contains the registers of the Keyboard controller.      |              |
| 0x50001500 | APB16/ADC                                               | PD_SYS       |
| 0x50001600 | Contains the registers of the 4-channel ADC.            |              |
| 0x50001600 | APB16/AnaMisc                                           | PD_SYS       |
| 0x50001700 | Contains registers for various analog blocks.           |              |
| 0x50001700 | RESERVED                                                |              |
| 0x50003000 |                                                         |              |
| 0x50003000 | APB16/Ports                                             | PD_SYS       |
| 0x50003100 | Contains the mode and direction registers of the GPIOs. |              |
| 0x50003100 | APB16/Watchdog                                          | PD_SYS       |
| 0x50003200 | Contains the control registers of the Watchdog timer.   |              |
| 0x50003200 | APB16/Version                                           | PD_SYS       |
| 0x50003300 | Contains the version/revision of the chip.              |              |
| 0x50003300 | APB16/Gen Purpose                                       | PD_SYS       |
| 0x50003400 | Contains general purpose control registers.             |              |
| 0x50003400 | APB16/Timer                                             | PD_SYS       |
| 0x50003500 | Contains the control registers of Timer0 and Timer2.    |              |
| 0x50003500 | APB16/RF Monitor                                        | PD_SYS       |
| 0x50003600 | Contains the control registers of the RFMON.            |              |
| 0x50003600 | APB16/DMA                                               | PD_SYS       |
| 0x50003700 | Contains the control registers of the DMA.              |              |
| 0x50003700 | RESERVED                                                |              |
| 0x50004000 |                                                         |              |
| 0x50004000 | APB32/Timer1                                            | PD_TIM       |
| 0x50004100 | Contains the control registers of Timer1.               |              |
| 0x50004100 | APB32/RTC                                               | PD_TIM       |
| 0x50004200 | Contains the control registers of the Real Time Clock.  |              |
| 0x50004200 | RESERVED                                                |              |
| 0xE0000000 |                                                         |              |
| 0xE0000000 | Internal Private Bus                                    | PD_SYS       |
| 0xE0100000 | Contains various registers of the Arm Cortex-M0+.       |              |

**Final** 

# 10 Memory Controller

### 10.1 Introduction

The Memory Controller of DA14531 is responsible for the interface between the memory cells and the masters of the system that request access. It comprises two arbiters which use a fixed priority level scheme to allow parallelization between the three main masters of the RAM. The memory controller also provides the actual physical sequence of the RAM cells in a continuous memory space to enable the activation of the required amount of SysRAM only to save power.

The block diagram is presented in Figure 25.

#### **Features**

- Three different capacities for the RAM cells with retention capability (12 kB, 16 kB, and 20 kB)
- Arbitration among the AHB masters (CPU or DMAs), OTP, and the BLE core
- Transparently interfaces the AHB busses to memory signaling
- Fixed arbitration algorithm with time sharing



Figure 25: Memory Controller Block Diagram

### 10.2 Architecture

The Memory Controller contains two Arbiters which connect to the following busses via a Mux-Demux:

- Bluetooth® LE Mem I/F: this is a memory interface directly from the Bluetooth® 5.1 Core to the RAM used as an exchange memory (TX/RX descriptors and others). This interface always operates at 16 MHz
- System Mem I/F: This is a memory interface directly from the OTP memory to the RAM used for copying data after power-up/wake-up



**Final** 

### 10.2.1 Arbitration

The arbitration is a mixture of the highest priority and a fair use policy. If more than one master request access to cells which reside under the same arbiter, time division is employed. This is to make sure none of the busses can stall the others for a long period. The OTP and Bluetooth<sup>®</sup> LE accesses are handled as very critical and therefore they have the highest priority.

**Final** 

# 11 Clock Generation

### 11.1 Clock Tree

The generation of the system's clocks is described in detail in Figure 26.



Figure 26: Clock Tree Diagram



**Final** 

Figure 26 shows the possible clock sources as well as all different divisions and multiplexing paths towards the generation of each block's clock. Furthermore, the required registers that have to be programmed are also shown in Figure 26.

Internal clock sources of DA14531 are the RC32M, RC32K/512K, and RCX oscillators. External clock sources of DA14531 are the 32 MHz crystal oscillator (the pins XTAL32Mp and XTAL32Mm), the 32.768 kHz crystal oscillator (the pins XTAL32kp and XTAL32km mapped on P0\_3 and P0\_4, respectively), or an external digital clock (the pin P0\_3).

There are two main clock lines which are of interest:

- Ip\_clk: this is the low power clock used for the sleep modes and can only be either the RCX, the RC32K, the XTAL32K, or an externally supplied digital clock
- sys\_clk: this is the system clock used for the AMBA clock (hclk), which runs the CPU, the
  memories, and the bus. This clock source can be one of the oscillators or an externally supplied
  digital clock

The clock names depicted in Figure 26 are explained in Table 44.

**Table 44: Generated Clocks Description** 

| Clock Name             | Description                                                                                                                     |  |  |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| wakeupct_clk           | Clocked wake-up controller clock.                                                                                               |  |  |
| apb_clk                | AMBA APB interface clock.                                                                                                       |  |  |
| otp_clk                | OTP controller clock.                                                                                                           |  |  |
| hclk                   | AMBA AHB interface clock.                                                                                                       |  |  |
| ble_hclk               | AMBA AHB clock for the BLE core.                                                                                                |  |  |
| wdog_clk               | Watchdog clock.                                                                                                                 |  |  |
| pmu_rc_clk             | Clock for the PMU and analog start-up FSM.                                                                                      |  |  |
| icp_clk_512_c (512KHz) | Clock for the Charge pump in the LDO_CORE.                                                                                      |  |  |
| gen_por_timer          | Clock for the POR_FORCE Timer.                                                                                                  |  |  |
| spi_clk                | Clock for the SPI controller. This clock is further divided by 2, 4, 8, or 14 as defined by SPI_CTRL_REG[SPI_CLK].              |  |  |
| spi_fast_clk           | Fast 32 MHz clock for the SPI controller.                                                                                       |  |  |
| i2c_clk                | Clock for the I2C controller. This clock is further divided to provide 100 kHz or 400 kHz as defined by I2C_CON_REG[I2C_SPEED]. |  |  |
| uart_clk               | Clock for the UART.                                                                                                             |  |  |
| uart2_clk              | Clock for the UART2.                                                                                                            |  |  |
| quad_clk               | Clock for the quadrature decoders.                                                                                              |  |  |
| rfcu_clk               | Clock for the RF control unit of the Radio.                                                                                     |  |  |
| tmr0_clk, tmr2_clk     | Timer0/2 clocks.                                                                                                                |  |  |
| tmr1_clk               | Timer1 clock.                                                                                                                   |  |  |
| tmr0_on_clk            | Timer0 ON counter clock.                                                                                                        |  |  |
| rtc_clk                | Clock for Real Time Clock (RTC).                                                                                                |  |  |
| gp_adc_clk             | General Purpose ADC conversion clock.                                                                                           |  |  |
| ble_crypt_clk          | Clock for the Crypto block of the Bluetooth® LE core.                                                                           |  |  |
| ble_master1_clk        | Internal clock for the Bluetooth® LE core.                                                                                      |  |  |
| ble_master2_clk        | Internal clock for the Bluetooth® LE core.                                                                                      |  |  |



**Final** 

| Clock Name | Description                              |  |  |
|------------|------------------------------------------|--|--|
| arb_clk    | Clock for the memory controller arbiter. |  |  |
| ble_lp_clk | Bluetooth® LE core low power clock.      |  |  |
| pll        | PLL clock.                               |  |  |

### 11.1.1 General Clock Constraints

There are certain constraints on various clocks regarding their frequency relations or the effectiveness. This section summarizes these rules:

- The minimum of the AMBA clock (hclk) should be 8 MHz when Bluetooth<sup>®</sup> LE is utilized. This is also the clock of the Cortex CPU and ensures the required MIPS for handling the Bluetooth<sup>®</sup> LE Protocol
- The AMBA clock (hclk) should always be greater or equal to the ble\_\*\_clks. This is required for the proper operation of the Bluetooth<sup>®</sup> LE protocol. For example, hclk at 16 MHz and Bluetooth<sup>®</sup> LE clocks at 8 MHz is an acceptable combination but not the other way around

# 11.2 Crystal Oscillators

The Digital Controlled XTAL Oscillators (DXCO) are designed for low power consumption and high stability. There are two such crystal oscillators in the system, one at 32 MHz (XTAL32M) and the other at 32.768 kHz (XTAL32K). The XTAL32K has no trimming capabilities and is used as the clock of the Deep Sleep/Extended Sleep modes. The XTAL32M can be trimmed.

The principal schematic of the two oscillators is shown in Figure 27. No external components to the DA14531 are required other than the crystal itself. If the crystal has a case connection, it is advised to connect the case to ground.



**Figure 27: Crystal Oscillator Circuits** 

### 11.2.1 Frequency Control (32 MHz Crystal)

The 8-bit register CLK\_FREQ\_TRIM\_REG controls the trimming of the 32 MHz crystal oscillator. The frequency is trimmed by two on-chip variable capacitor banks. Both capacitor banks are controlled by the same register.

The capacitance of both variable capacitor banks varies from the minimum to the maximum value in 256 equal steps. With CLK\_FREQ\_TRIM\_REG[XTAL32M\_TRIM] = 0x00, the minimum capacitance and thus the maximum frequency are selected. With CLK\_FREQ\_TRIM\_REG[XTAL32M\_TRIM] = 0xFF, the maximum capacitance and thus the minimum frequency are selected.

The five least significant bits of CLK\_FREQ\_TRIM\_REG register (XTAL32M\_TRIM<4:0>) directly control five binary weighted capacitors (Figure 28). The three most significant bits of CLK\_FREQ\_TRIM\_REG register (XTAL32M\_TRIM<7:5>) are binary to the thermometer decoded. Each of the seven outputs of the decoder controls a capacitor, of which the value is 32 times the value of the smallest capacitor.

**Final** 



Figure 28: XTAL32MHz Oscillator Frequency Trimming

# 11.2.2 Automated Trimming and Settling Notification

There is provision in the DA14531 for automating the actual trimming of the 32 MHz crystal oscillator. This is a special hardware block that realizes the XTAL trimming in a single step. Notification about the XTAL oscillator being settled after applying the trim value is also provided in form of an interrupt, namely, the XTAL32RDY\_IRQn line. The automated mechanism for applying the trim value and signaling that the oscillator is settled is described in Figure 29.

The XTAL32RDY\_IRQn is always triggered as soon as an internal counter reaches the value programmed at XTALRDY\_CTRL\_REG. This counter runs on the RC32M clock if the system is powering up, or on a selected low power clock if the system is waking up. The enabling of the XTAL32M is always done by HW. There are two sections until the interrupt notifies the software that the XTAL32M can be used:

- The start-up section, where the XTAL32M oscillator is slowly converging towards the initial frequency of the crystal. This section ends with the application of the trim value to achieve a <50 ppm, 32 MHz clock
- The settling section, where the XTAL32M oscillator settles to the preferred frequency after the application of the trim value which is done automatically by HW

There are two ways of deciding when the start-up section ends and when the trim values are supposed to be applied. This decision is controlled by TRIM\_CTRL\_REG[XTAL\_TRIM\_SELECT] bit field:

- Counter Mode: trim value stored in the CLK\_FREQ\_REG is applied as soon as an internal counter reaches the value XTAL\_COUNT\_N-1. This is the default mode
- Current Mode: trim value is applied as soon as the current drops

The different modes are illustrated in Figure 29.

**Final** 



Figure 29: Automated Mechanism for XTAL32M Trim and Settling

In both modes mentioned above, trimming is done by HW. In the current mode, upon assertion of XTAL32M\_TRIM\_READY, the interrupt counter value is stored in a shadow register XTALRDY\_STAT\_REG to enable SW understanding when the start-up section is finished.

The settling section usually takes no more than five to 10 clock cycles. Using the explanation above, fine tuning and reducing the XTAL32M latency is feasible. One feature of the XTAL32\_CLK\_CNT is that it asserts an observable signal (SYS\_STAT\_REG[XTAL32\_SETTLE\_READY]) as soon as the counter reaches a pre-defined threshold programmed at TRIM\_CTRL\_REG[XTAL\_SETTLE\_N]. This allows the SW to have an indication of the status of the clock by adjusting the threshold accordingly.

# 11.3 RC Oscillators

There are three RC oscillators in the DA14531:

- One providing 32 MHz (RC32M)
- One providing 32 kHz and 512 kHz (RC32K/512K)
- One providing a frequency of 15 kHz (RCX)

The RC32M is powered by  $V_{BAT\_LOW}$  which is available during Active or Sleep mode. The output clock is slower than 32 MHz if untrimmed and it is used to clock the CPU and the digital part of the chip during power-up or wake-up, while the XTAL32M oscillator is settling.

The simple RC oscillator (RC32K/512K) operates on VDD and provides 32 kHz or 512 kHz. The main usage of the RC32K/512K oscillator is for internal clocking during power-up or start-up. It clocks the HW FSM which brings up the power management system of the chip. In the power-up or start-up sequence, the clock dynamically changes from 32 kHz to 512 kHz to speed up the sequence. The



**Final** 

enhanced RC oscillator (RCX) provides a stable 15 kHz frequency and operates on V<sub>BAT\_LOW</sub> which is available during Active or Sleep mode.

The RCX oscillator can be used to replace the 32.768 kHz crystal, since it has a precision of < 500 ppm, while its output frequency needs to be recalibrated over temperature.

Using the RCX requires the following registers to be set:

- Set GP\_DATA\_REG = 0x20 after the system wakes up
- RCX calibration (the calibration is optional, see Section 11.3.1 for the RCX calibration)
- Go to sleep: set GP\_DATA\_REG = 0x40 after the sleep procedure is handled

The procedure is also implemented as a part of the SDK.

### 11.3.1 Frequency Calibration

The output frequency of the 32 kHz crystal oscillator and the three RC-oscillators can be measured relative to the 32/2 (16) MHz crystal oscillator using the on-chip reference counter.

The measurement procedure is as follows:

- 1. REF CNT VAL = N (the larger number N is, the more accurate and longer the calibration will be)
- CLK\_REF\_SEL\_REG = 0x0000 (RC32K) or CLK\_REF\_SEL\_REG = 0x0001 (RC32M) or CLK\_REF\_SEL\_REG = 0x0002 (XTAL32K) or CLK\_REF\_SEL\_REG = 0x0003 (RCX)
- 3. Start the calibration: CLK\_REF\_SEL\_REG[REF\_CAL\_START] = 1
- 4. Wait until CLK\_REF\_SEL\_REG[REF\_CAL\_START] = 0
- 5. Read CLK\_REF\_VAL\_H\_REG and CLK\_REF\_VAL\_L\_REG = M (32-bit values)
- 6. Frequency =  $(N/M) \times 32/2 \text{ MHz}$

If the RCX is used as a sleep clock, the frequency calibration should be implemented on each active time of a connection interval to guarantee a correct operation.

**Final** 

# 12 OTP Controller

### 12.1 Introduction

The OTP controller realizes all functions of the OTP macro cell in an automated and transparent way. The controller facilitates all data transfers (reading and programming), comprises a DMA engine which connects to the AHB bus as a master, and has the highest priority to copy code from OTP into SysRAM in mirrored mode. The block diagram is presented in Figure 30.

### **Features**

- Implements all timing constraints for any access to the physical OTP cell
- Automatic single Error Code Correction (ECC) 6 bits (implemented in the OTP cell)
- 32-bit read in a single read access from the OTP cell
- Single word buffer for programming. No burst programming supported
- Empty words are 0xFFFFFFF. Zeros are programmed per 32-bit word
- Embedded DMA engine for fast mirroring of the OTP contents into the SysRAM
- Embedded DMA supports reading in bursts of 4 × 32-bit words
- Transparent random address access to the OTP memory cells via the AHB slave memory interface
- Hardwired handshaking with the PMU to realize the mirroring procedure



Figure 30: OTP Controller Block Diagram

### 12.2 Architecture

The OTP controller block includes the OTP macro cell and pure digital logic implementing the controlling functions. The OTP memory communicates with the controller through a proprietary interface.

The internal organization of the OTP cell is 32-bit data and 6-bit ECC for each of the 8192 addressable positions. The six bits of the ECC are only accessible within the OTP cell. The ECC is generated by the OTP cell during the programming and is used again by the OTP cell in a transparent way during reading.

The AHB master interface is controlled by a DMA engine with an internal FIFO of eight 32-bit words. The DMA engine supports AHB reads and writes. The AHB address where memory access should begin is programmed into the DMA engine at OTPC AHBADR REG[OTPC AHBADR]. The number



**Final** 

of the 32-bit words of a transfer minus 1 must be specified in OTPC\_NWORDS\_REG[OTP\_NWORDS].

The DMA engine internally supports the following burst types:

- Eight words incremental burst (INCR8)
- Four words incremental burst (INCR4)
- Unspecified incremental burst (INCR) with a length different from 1, 4, or 8
- Single word access (SINGLE)

The slave block combines two AHB slave interfaces: one is for the registers and can be read from/written to, and the other is for the contents of the OTP memory and is read-only.

The OTP controller configures the OTP cell to be in one of the following modes:

- Deep Stand-by Mode (DSTBY). In this mode, the required power supplies are applied to the OTP cell, while the internal LDO of the OTP cell is inactive.
- Stand-by Mode (STBY). In this mode, the OTP cell is disabled by deactivating the chip select signal. The OTP cell is powered and the internal LDO is enabled. The power consumption of the OTP cell in this mode is not the minimum possible but is less than in an active mode (RD, PROG, PVFY, RINI, AREAD). This is the state from which any active mode of operation can be transitioned into with the least delay.
- Read Mode (RD). When this mode is used, the contents of the OTP cell can be read at the
  respective AHB address space. This mode can also be used to execute software in place (XIP).
  A read request is translated by the OTP controller into the corresponding control sequence for
  the OTP cell to retrieve the requested data.
- Programming Mode (PROG). The PROG mode provides the functionality to program a 32-bit word into an OTP position. The OTP cell expands the 32-bit word by calculating and automatically appending a 6-bit checksum (ECC). Please note that there is no way to access these extra six bits of the ECC information. Programming is performed only for bits equal to 0. Bits equal to 1 are bypassed to save programming time. Because the ECC value is unknown to the controller, there are always six extra programming pulses applied to the ECC bits. Programming is done by issuing a programming request stored in the Programming Buffer (PBUF). PBUF consists of two configuration registers storing the 32-bit data value and the 13-bit address in the OTP cell where the value should be programmed. A new request can only be stored in PBUF when the previous one is served. A status bit indicates whether this has already been done, therefore programming should be monitored by SW before a new programming request is issued.
- Programming Verification Mode (PVFY). The PVFY mode forces the OTP cell to enter a special margin read mode. This mode is used to verify the content of the OTP positions that have been programmed using the PROG mode and to verify that the programmed data is retrieved correctly under all corner cases. When this mode is used, the contents of the OTP cell can be read at the respective AHB address space. The CPU must read all OTP positions that have been programmed by accessing the corresponding addresses and verify that all the retrieved words are equal to the expected values.
- Read Initial State Mode (RINI). The RINI mode implements a production test of the initial margin read, which should be performed in the OTP cell, before the first programming is applied. This test verifies that the OTP cell is empty (all the bits are equal to 1). The OTP controller will send the required control sequence to the OTP cell to enable the test mode. Then the CPU should read all the content of the OTP cell at the respective AHB address space and verify that all the retrieved words are equal to 0xFFFFFFF. The RINI mode should be used after the PROG mode to verify the content of the OTP positions that have been programmed and specify the bits that remain un-programmed. This verification is required to ensure that the programming process has not affected the un-programmed bits. This specific read mode is a margin read, which means that it is not an equivalent to the normal read and should only be used for verification.
- Automatic Read Mode (AREAD). This mode is used to mirror large parts of the OTP cell into RAM through the AHB master interface and the integrated DMA controller.



**Final** 

Transitioning from one mode to another automatically steps through the STBY mode.

# 12.2.1 OTP Accessing Considerations

Access to the OTP memory (read/write) can only be performed at certain voltage ranges. Users are responsible for meeting these conditions while accessing the OTP. The recommended operation conditions of the OTP memory can be found under Recommended Operating Conditions section.

# 12.3 Programming

To configure the OTP controller, follow the sequence of steps below:

- 1. Enable clock for the OTP controller by setting the CLK\_AMBA\_REG[OTP\_ENABLE] bit.
- 2. Put the OTP in STBY mode (OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 0x1).
- 3. Wait for OTP mode to change (OTPC\_STAT\_REG[OTPC\_STAT\_MRDY] = 1).
- 4. Set OTP speed by writing OTPC\_TIM1\_REG and OTPC\_TIM2\_REG if the system clock speed is to be reduced. These numbers basically generate asynchronous timing signals towards the OTP cell that comply to the default internal 16 MHz bus speed.
- 5. Perform an OTP access:
  - a. Programming:
    - i. Set up OTP write mode (OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 0x3).
    - ii. Wait for OTP mode to change (OTPC STAT REGIOTPC STAT MRDY] = 1).
    - iii. Check OTPC STAT REG[OTPC STAT PBUF EMPTY] = 1
    - iv. Write the data to be programmed to OTPC\_PWORD\_REG.
    - v. Write the address to which the data is to be programmed to OTPC PADDR REG.
    - vi. Wait until the programming is finished (OTPC STAT REG[OTPC STAT PRDY] = 1).
    - vii. Switch to OTP verify mode (OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 0x4).
    - viii. Wait for OTP mode to change (OTPC STAT REGIOTPC STAT MRDY] = 1).
    - ix. Read back and compare the data written.
    - x. Put the OTP in STBY mode (OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 0x1).
    - xi. Wait for OTP mode to change (OTPC STAT REG[OTPC STAT MRDY] = 1).

### b. Reading:

- i. Set up OTP read mode (OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 0x2).
- ii. Wait for OTP mode to change (OTPC\_STAT\_REG[OTPC\_STAT\_MRDY] = 1).
- iii. Read the OTP word.
- iv. Put the OTP in STBY mode (OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 0x1).
- v. Wait for OTP mode to change (OTPC STAT REG[OTPC STAT MRDY] = 1).

**Final** 

## 13 DMA Controller

### 13.1 Introduction

The 4-channel direct memory access (DMA) controller transfers data of eight bits, 16 bits, or 32 bits between the on-chip supported peripherals (SPI, UART, UART2, I2C, and ADC) and the on-chip RAM and supports regular memory-to-memory transfers. The DMA also supports a programmable interrupt generation to generate an interrupt after a certain number of transfers to off load the Cortex interrupt rate. The on-chip peripheral requests are multiplexed on the two available channel pairs to increase the DMA utilization. A block diagram of the controller is depicted on Figure 27.

### **Features**

- Four channels with an optional peripheral trigger
- Full 32-bit source and destination pointers
- Flexible interrupt generation
- Programmable length
- Flexible peripheral request per channel
- Option to initialize memory (DMA\_INIT)
- Programmable edge-sensitive request support (recommended when writing to UART/UART2 and I2C)



Figure 31: DMA Controller Block Diagram

### 13.2 Architecture

### 13.2.1 DMA Peripherals

By default, the DMA assumes memory-to-memory transactions. Each DMA channel can also be connected with the hand-shaking signals or other request signals of the corresponding peripherals (Table 45).

**Final** 

**Table 45: DMA Served Peripherals** 

| Name   | Direction |  |  |
|--------|-----------|--|--|
| SPI    | RX/TX     |  |  |
| UART   | RX/TX     |  |  |
| UART2  | RX/TX     |  |  |
| 12C    | RX/TX     |  |  |
| GP-ADC | RX        |  |  |

# 13.2.2 Input/Output Multiplexer

The multiplexing of peripheral requests is controlled by DMA\_REQ\_MUX\_REG. Thus, if DMA\_REQ\_MUX\_REG[DMAxy\_SEL] is set to a certain (non-reserved) value, the TX/RX request from the corresponding peripheral will be routed to DMA channels y (TX request) and x (RX request), respectively. Similarly, an acknowledging de-multiplexing mechanism is applied.

When two or more bit-fields (peripheral selectors) of DMA\_REQ\_MUX\_REG have the same value, the lesser significant selector will be given priority (see also the register's description).

# 13.2.3 DMA Channel Operation

A DMA channel is switched on with bit DMA\_ON. This bit is automatically reset if the DMA channel's transfer is finished. The DMA channels can either be triggered by SW or by a peripheral DMA request. If DREQ\_MODE is 0, a DMA channel is immediately triggered.

If DREQ\_MODE is 1, a DMA channel can be triggered by a HW request coming from a selected peripheral. All DMA channels support either level (default) or edge-sensitive requests via the bit-field REQ\_SENSE of DMAx\_CTRL\_REG (x = 0, 1, 2, 3). If this bit-field is set (recommended for Memoryto-UART/UART2 and Memory-to-I2C transfers), the channel detects a positive edge on the request signal of the selected peripheral in order to start up a new transfer cycle. The edge-sensitive requests can be used globally, if desired, for all the peripherals interfacing with the DMA.

When DMA starts, data is transferred from address DMAx\_A\_START\_REG to address DMAx\_B\_START\_REG for a length of DMAx\_LEN\_REG, which can be eight, 16, or 32 bits wide. The address increment is realized with an internal 16-bit counter DMAx\_IDX\_REG, which is set to 0 when the DMA transfer starts and is compared with the DMAx\_LEN\_REG after each transfer. The register value is multiplied by the values of the automatic increment of source address (AINC), the automatic increment of destination address (BINC), and bus transfer width (BW) before it is added to DMAx\_A\_START\_REG and DMAx\_B\_START\_REG. AINC or BINC must be 0 for register access.

If at the end of a DMA cycle, the DMA start condition is still true, the DMA continues. The DMA stops if DREQ\_MODE is low or if DMAx\_LEN\_REG is equal to the internal index register. This condition also clears the DMA\_ON bit if DREQ\_MODE is 0 or if DREQ\_MODE is set to 1 and CIRCULAR bit is not set.

If a hand shaking is attached to the specific DMA channel at the end of a DMA cycle, the channel will be blocked for as long as the peripheral is not ready for the next transaction.

If the bit CIRCULAR is set to 1, the DMA controller automatically resets the internal index registers and continues from its starting address without intervention of the Arm Cortex-M0+. If the DMA controller is started with DREQ\_MODE = 0, the DMA will always stop, regardless of the state of CIRCULAR.

**Final** 



Figure 32: DMA Channel Diagram

Each DMA channel can generate an interrupt if the index counter DMAx\_IDX\_REG reaches the value of the channel's interrupt transfer length register, DMAx\_INT\_REG. After the transfer and before DMAx\_IDX\_REG is incremented, the interrupt is generated.

For example, if DMA\_x\_INT\_REG = 0 and DMA\_x\_LEN\_REG = 0, there will be one transfer and an interrupt.

# 13.2.4 DMA Arbitration

The priority level of a DMA channel can be set with bits DMA\_PRIO[2-0]. These bits determine which DMA channel will be activated if more than one DMA channel requests DMA. If two or more channels have the same priority, an inherent priority applies (see register description).

With DREQ\_MODE = 0, a DMA can be interrupted by a channel with a higher priority if the DMA\_IDLE bit is set.

When DMA\_INIT is set, however, the DMA channel currently performing the transfer locks the bus and cannot be interrupted by any other channels until the transfer is completed, regardless of whether DMA\_IDLE is set. The purpose of DMA\_INIT is to initialize a specific memory block with a certain value without any interruption from other active DMA channels that may request the bus at the same time. Consequently, DMA\_INIT should be used only for memory initialization. When the DMA transfers data to/from peripherals, DMA\_INIT should be set to 0.



**Final** 

### NOTE

When DMA\_INIT is enabled, AINC must be set to 0 and BINC to 1.

Memory initialization could also be performed by simply setting AINC to 0 and BINC to 1 without enabling the DMA\_INIT, provided that the source address of the memory will not change during the transfer. However, it is not guaranteed that the DMA transfer will not be interrupted by other channels of a higher priority, when they request access to the bus at the same time.

# 13.2.5 Freezing DMA Channels

Each channel of the DMA controller can be temporarily disabled by writing a 1 to bit 4 SET\_FREEZE\_REG[FRZ\_DMA] to freeze all channels.

To enable a frozen channel again, write a 1 to bit 4 RESET\_FREEZE\_REG[FRZ\_DMA].

There is no HW protection from erroneous programming of the DMA registers.

The on-going Memory-to-Memory transfers (DREQ\_MODE = 0) cannot be interrupted, therefore the corresponding DMA channels are frozen after a Memory-to-Memory transfer is completed.

# 13.3 Programming

# 13.3.1 Memory to Memory Transfers

- Set the length of data to be transferred (DMAx\_LEN\_REG).
- 2. Set the source address (DMAx\_A\_START\_REG).
- 3. Set the destination address (DMAx\_B\_START\_REG).
- Configure the number of transfers until an interrupt is generated (DMAx\_INT\_REG).
- 5. Configure transfer options:
  - a. DMAx\_CTRL\_REG[AINC]: Automatic increment of source address.
  - b. DMAx CTRL REG[BINC]: Automatic increment of destination address.
  - c. DMAx\_CTRL\_REG[BW]: Bus transfer width.
  - d. DMAx\_CTRL\_REG[IRQ\_ENABLE]: Enable the DMA interrupt generation for this channel.
- 6. Start the DMA transfer by setting the DMAx CTRL REG[DMA ON] bit.
- 7. Wait until the transfer is finished (DMAx\_CTRL\_REG[DMA\_ON] = 0).
- 8. Clear the IRQ status bit for channel x in DMA INT STATUS REG.

### 13.3.2 Peripheral to Memory Transfers

- 1. Set the length of data to be transferred (DMAx\_LEN\_REG).
- 2. Set the source address (DMAx\_A\_START\_REG) to the peripheral Rx register (for example, I2C\_DATA\_CMD\_REG).
- 3. Set the destination address (DMAx\_B\_START\_REG). This should point to a buffer in memory (for example, SYSRAM).
- Configure the number of transfers until an interrupt is generated (DMAx\_INT\_REG).
- 5. Map the peripheral to the selected channels pair (DMA\_REQ\_MUX\_REG[DMAxy\_SEL]).
- 6. Configure transfer options:
  - a. DMAx\_CTRL\_REG[AINC]: Disable automatic increment of source address.
  - b. DMAx\_CTRL\_REG[BINC]: Automatic increment of destination address.
  - c. DMAx CTRL REG[BW]: Bus transfer width.
  - d. DMAx\_CTRL\_REG[DREQ\_MODE]: Enable triggering by peripheral DMA request.
  - e. DMAx\_CTRL\_REG[DMA\_PRIO]: Set the channel's priority.
  - f. DMAx CTRL REG[IRQ ENABLE]: Enable the DMA interrupt generation for this channel.



**Final** 

- g. DMAx\_CTRL\_REG[REQ\_SENSE]: Enable edge-sensitive requests for this channel. This is recommended for Memory-to-UART/UART2/I2C transfers but can also be used globally for all the supported peripherals and for both directions (TX/RX).
- 7. Start the DMA transfer by setting the DMAx\_CTRL\_REG[DMA\_ON] bit.
- 8. Enable peripheral's DMA request (for example, I2C\_DMA\_CR\_REG[TDMAE]).
- 9. Clear the IRQ status bit for channel x in DMA\_INT\_STATUS\_REG.

**Final** 

# 14 I2C Interface

### 14.1 Introduction

The I2C Interface is a programmable control bus that provides support for the communications link between Integrated Circuits in a system. It is a simple two-wire bus with a software-defined protocol for system control, which is used in temperature sensors and voltage level translators to EEPROMs, general-purpose I/O, and A/D and D/A converters.

### **Features**

- Two-wire I2C serial interface consisting of a serial data line (SDA) and a serial clock (SCL)
- Two speeds are supported:
  - Standard mode (0 to 100 kbit/s)
  - Fast mode (≤ 400 kbit/s)
- Clock synchronization
- 32 locations deep transmit/receive FIFOs (32× 8-bit Rx and 32× 10-bit Tx)
- Master transmit and Master receive operation
- Slave transmit and Slave receive operation
- 7-bit or 10-bit addressing
- 7-bit or 10-bit combined format transfers
- Bulk transmit mode
- Default slave address of 0x055
- Interrupt or polled-mode operation
- Handles bit and byte waiting at both bus speeds
- Programmable SDA hold time
- DMA support



Figure 33: I2C Controller Block Diagram

### 14.2 Architecture

The I2C Controller block diagram is shown in Figure 33. It contains the following sub-blocks:

- AMBA Bus Interface Unit: it accesses the register file via the APB interface
- Register File: it contains configuration registers and is the interface with SW
- Master State Machine: it generates the I2C protocol for the master transfers

**Final** 

- Slave State Machine: it generates the I2C protocol for the slave transfers
- Clock Generator: it calculates the required time to do the following:
  - Generate the SCL clock when configured as a master
  - Check for bus idle
  - Generate a START and a STOP
  - Set up the data and hold the data
- Rx Shift: it takes data into the design and extracts it in byte format
- Tx Shift: it presents data supplied by CPU for transfer on the I2C bus
- Rx Filter: it detects the events in the bus, for example, start, stop, and arbitration lost
- Toggle: it generates pulses on both sides and toggles to transfer signals across clock domains
- Synchronizer: it transfers signals from one clock domain to another
- Interrupt Controller: it generates the raw interrupt and interrupt flags, allowing them to be set and cleared.
- RX FIFO/TX FIFO: it holds the RX FIFO and TX FIFO register banks and controllers along with their status levels.

### 14.2.1 I2C Bus Terms

The following terms relate to what the role of the I2C device is and how it interacts with other I2C devices on the bus.

- **Transmitter** is the device that sends data to the bus. A transmitter can either initiate the data transmission to the bus (a master-transmitter) or respond to a request from the master to send data back (a slave-transmitter)
- Receiver is the device that receives data from the bus. A receiver can either receive data on its
  own request (a master-receiver) or respond to a request from the master to receive data (a slavereceiver)
- Master is the component that initializes a transfer (START command), generates the clock (SCL) signal, and terminates the transfer (STOP command). A master can be either a transmitter or a receiver
- Slave is the device addressed by the master. A slave can be either a receiver or a transmitter

These concepts are illustrated in Figure 34.



Figure 34: Master/Slave and Transmitter/Receiver Relationships

- Multi-master means the ability for more than one master to co-exist on the bus at the same time without collision or data loss
- Arbitration is the predefined procedure that authorizes only one master at a time to take control of the bus. For more information, see Section 14.2.4
- Synchronization is the predefined procedure that synchronizes the clock signals provided by two
  or more masters. For more information, see Section 14.2.5

**Final** 

- SDA is the data signal line (Serial Data)
- SCL is the clock signal line (Serial Clock)

#### 14.2.1.1 Bus Transfer Terms

The following terms are specific to data transfers that occur to/from the I2C bus.

- START (RESTART). Data transfer begins with a START or RESTART condition. The level of the SDA data line changes from high to low, while the SCL clock line remains high. When this occurs, the bus becomes busy
- STOP. Data transfer is terminated by a STOP condition. This occurs when the level of the SDA
  data line changes from low to high, while the SCL clock line remains high. When the data transfer
  has been terminated, the bus is free or idle again. The bus stays busy if a RESTART is
  generated instead of a STOP condition

#### **NOTE**

START and RESTART conditions are functionally identical.

### 14.2.2 I2C Behavior

The I2C can only be controlled via SW to be an I2C master, communicating with other I2C slaves. The master is responsible for generating the clock and controlling the transfer of data. The I2C protocol also allows multiple masters to reside on the I2C bus and uses an arbitration procedure to determine the bus ownership. A slave is responsible for either transmitting or receiving data to/from the master. The acknowledgment of data is sent by the device that is receiving data, which can be either a master or a slave.

Each slave has a unique address that is determined by the system designer. When a master wants to communicate with a slave, the master transmits a START/RESTART condition that is then followed by the slave's address and a control bit (R/W) to determine whether the master wants to transmit data or receive data from the slave. The slave then sends an acknowledge pulse (ACK) after the address.

If a master-transmitter writes to a slave-receiver, the receiver gets one byte of data. This transaction continues until the master terminates the transmission with a STOP condition. If a master-receiver reads from a slave-transmitter, the slave transmits a byte of data to the master, and the master then acknowledges the transaction with an ACK pulse. This transaction continues until the master terminates the transmission by not acknowledging (NACK) the transaction after the last byte is received, and then the master issues a STOP condition or addresses another slave after issuing a RESTART condition. This behavior is illustrated in Figure 35.



Figure 35: Data Transfer on the I2C Bus

The I2C is a synchronous serial interface. The SDA line is a bidirectional signal and changes only when the SCL line is low, except for STOP, START, and RESTART conditions. The output drivers are open-drain or open-collector to perform wire-AND functions on the bus. The maximum number of devices on the bus is limited only by the maximum capacitance specification of 400 pF. Data is transmitted in byte packages.

**Final** 

#### 14.2.2.1 START and STOP Generation

When operating as an I2C master, putting data into the transmit FIFO causes the I2C Controller to generate a START condition on the I2C bus. Allowing the transmit FIFO to empty causes the I2C Controller to generate a STOP condition on the I2C bus.

When operating as a slave, the I2C Controller does not generate START or STOP conditions, as per the protocol. However, if a read request is made to the I2C Controller, it holds the SCL line low until read data has been supplied to it. This stalls the I2C bus until read data is provided to the slave I2C Controller, or the I2C Controller slave is disabled by writing a 0 to I2C\_ENABLE.

### 14.2.2.2 Combined Formats

The I2C Controller supports transactions in a read and write combined format in both 7-bit and 10-bit addressing modes.

The I2C Controller does not support mixed address and mixed address format, that is, a 7-bit address transaction followed by a 10-bit address transaction or vice versa.

To initiate combined format transfers, I2C\_CON\_REG[I2C\_RESTART\_EN] should be set to 1. With this value set and the I2C Controller operating as a master, when an I2C transfer is completed, the I2C Controller checks the transmit FIFO and executes the next transfer. If the direction of the new transfer differs from the previous one, the combined format is used to issue the transfer. If the transmit FIFO is empty when the current I2C transfer completes, a STOP is issued, and the next transfer is issued after a START condition.

### 14.2.3 I2C Protocols

The I2C Controller has the following protocols:

- START and STOP Conditions
- Addressing Slave Protocol
- Transmitting and Receiving Protocols
- START BYTE Transfer Protocol

#### 14.2.3.1 START and STOP Conditions

When the bus is idle, both SCL and SDA signals are pulled high through external pull-up resistors on the bus. When a master wants to start a transmission on the bus, it issues a START condition. This is defined to be a high-to-low transition of the SDA signal while SCL is 1. When the master wants to terminate the transmission, it issues a STOP condition. This is defined to be a low-to-high transition of the SDA line while SCL is 1. Figure 36 shows the timing of the START and STOP conditions. When data is being transmitted on the bus, the SDA line must be stable when SCL is 1.



Figure 36: START and STOP Conditions

### **NOTE**

The signal transitions for the START/STOP conditions (Figure 36) reflect those observed at the output signals of the master driving the I2C bus. Be careful with observing the SDA/SCL signals at the input signals of the slave(s), because unequal line delays may result in an incorrect SDA/SCL timing relationship.

**Final** 

### 14.2.3.2 Addressing Slave Protocol

There are two address formats: 7-bit address format and 10-bit address format.

#### 7-bit Address Format

In the 7-bit address format, the first seven bits (bits 7:1) of the first byte set the slave address and the LSB bit (bit 0) is the R/W bit (Figure 37). When bit 0 (R/W) is set to 0, the master writes to the slave. When bit 0 (R/W) is set to 1, the master reads from the slave.



Figure 37: 7-bit Address Format

### 10-bit Address Format

In the 10-bit address format, two bytes are transferred to set the 10-bit address. The transfer of the first byte contains the following bit definition: the first five bits (bits 7:3) notify the slaves that this is a 10-bit transfer, the next two bits (bits 2:1) set the slaves address bits 9:8, and the LSB bit (bit 0) is the R/W bit. The second byte transferred sets bits 7:0 of the slave address. Figure 38 shows the 10-bit address format and Table 46 defines the special purpose and the reserved first byte addresses.



Figure 38: 10-bit Address Format

Table 46: I2C Definition of Bits in First Byte in 10-bit Address Format

| Slave Address | R/W Bits | Description                                                                                                     |  |  |  |
|---------------|----------|-----------------------------------------------------------------------------------------------------------------|--|--|--|
| 0000 000      | 0        | General Call Address. I2C Controller places the data in the receive buffer and issues a General Call interrupt. |  |  |  |
| 0000 000      | 1        | START byte. For more details, refer to "START BYTE Transfer Protocol".                                          |  |  |  |
| 0000 001      | X        | CBUS address. I2C Controller ignores these accesses.                                                            |  |  |  |
| 0000 010      | X        | Reserved.                                                                                                       |  |  |  |
| 0000 011      | X        | Reserved.                                                                                                       |  |  |  |
| 0000 1XX      | Х        | Reserved                                                                                                        |  |  |  |
| 1111 1XX      | X        | Reserved.                                                                                                       |  |  |  |
| 1111 0XX      | Х        | 10-bit slave addressing.                                                                                        |  |  |  |



**Final** 

The I2C Controller does not restrict users from using these reserved addresses. However, if these reserved addresses are used, incompatibilities with other I2C components may occur.

# 14.2.3.3 Transmitting and Receiving Protocols

A master can initiate data transmission and reception to/from the bus, acting as either a master-transmitter or master-receiver. A slave responds to requests from a master to either transmit data or receive data to/from the bus, acting as either a slave-transmitter or slave-receiver.

### **Master-Transmitter and Slave-Receiver**

All data is transmitted in byte format with no limit on the number of bytes transferred per data transfer. After a master sends a slave address and an R/W bit or a master transmits a byte of data to a slave, the slave-receiver must respond with an acknowledge signal (ACK). When a slave-receiver does not respond with an ACK signal, the master aborts the transfer by issuing a STOP condition. The slave must leave the SDA line high so that the master can abort the transfer.

If a master-transmitter is transmitting data as shown in Figure 39, the slave-receiver responds to the master-transmitter with an ACK signal after every byte of data is received.



Figure 39: Master-Transmitter Protocol

# **Master-Receiver and Slave-Transmitter**

If a master is receiving data as shown in Figure 40, the master responds to the slave-transmitter with an ACK signal after a byte of data has been received except for the last byte. This is the way the master-receiver notifies the slave-transmitter that this is the last byte. The slave-transmitter relinquishes the SDA line after detecting the No Acknowledge (NACK) so that the master can issue a STOP condition.

When a master does not want to relinquish the bus with a STOP condition, the master can issue a RESTART condition. This is identical to a START condition except it occurs after the ACK signal. The master can then communicate with the same slave or a different slave.

**Final** 



Figure 40: Master-Receiver Protocol

### **START BYTE Transfer Protocol**

The START BYTE transfer protocol is set up for systems that do not have an on-board dedicated I2C hardware module. When the I2C Controller is addressed as a slave, it always samples the I2C bus at the highest speed supported so that it never requires a START BYTE transfer. However, when I2C Controller is a master, it supports the generation of START BYTE transfers at the beginning of every transfer in case a slave device requires it. This protocol consists of seven zeros followed by a 1 being transmitted (Figure 41). This allows the processor that is polling the bus to under-sample the address phase until 0 is detected. Once the microcontroller detects a 0, it switches from the under-sampling rate to the correct rate of the master.



Figure 41: START BYTE Transfer

The START BYTE procedure is as follows:

- 1. Master generates a START condition.
- 2. Master transmits the START byte (0000 0001).
- 3. Master transmits the ACK clock pulse. (Present only to conform with the byte handling format used on the bus)
- 4. No slave sets the ACK signal to 0.
- 5. Master generates a RESTART (R) condition.

A hardware receiver does not respond to the START BYTE because it is a reserved address and gets reset after the RESTART condition is generated.

# 14.2.4 Multiple Master Arbitration

The I2C Controller allows multiple masters to reside on the same bus. There is an arbitration procedure if two masters on the same I2C bus try to control the bus at the same time by generating a START condition simultaneously. Once a master (for example, a microcontroller) has control of the bus, no other master can take control until the first master sends a STOP condition and places the bus in an idle state.



**Final** 

Arbitration takes place on the SDA line while the SCL line is 1. The master which transmits a 1 while the other master transmits a 0 loses the arbitration and turns off its data output stage. The master that has lost the arbitration can continue to generate clocks until the end of the byte transfer. If both masters are addressing the same slave device, the arbitration could go into the data phase. Figure 42 illustrates the timing of an arbitration between two masters on the bus.

Control of the bus is determined by the address or master code and data sent by the competing masters, so there is no central master or any order of priority on the bus.

Arbitration is not allowed between the following conditions:

- A RESTART condition and a data bit
- A STOP condition and a data bit
- A RESTART condition and a STOP condition

Slaves are not involved in the arbitration process.



Figure 42: Multiple Master Arbitration

# 14.2.5 Clock Synchronization

All masters generate their own clock to transfer messages. Data is only valid during the HIGH period of the SCL clock. When two or more masters try to transfer information on the bus at the same time, they must synchronize the SCL clock. Clock synchronization is performed using the wired-AND connection to the SCL signal. When the master transitions the SCL clock to 0, the master starts counting the LOW period of the SCL clock and transitions the SCL clock signal to 1 at the beginning of the next clock period. However, if another master is holding the SCL line to 0, the first master goes into a HIGH wait state until the SCL clock line transitions to 1.

All masters then count out their HIGH time and the master with the shortest HIGH time transitions the SCL line to 0. The masters then count out their LOW time and the one with the longest LOW time forces the other master into a HIGH wait state. Therefore, a synchronized SCL clock is generated, which is illustrated in Figure 43. Optionally, slaves may hold the SCL line LOW to slow down the timing on the I2C bus.

**Final** 



Figure 43: Multiple Master Clock Synchronization

# 14.3 Programming

To configure and use the I2C Controller, follow the simple sequence of steps below:

- 1. Set up the GPIOs to be used for the I2C interface (P0x\_MODE\_REG[PID] = 9 or 10).
- 2. Enable the clock for the I2C Controller (CLK PER REG[I2C ENABLE] = 0x1).
- Disable the I2C Controller (I2C\_ENABLE\_REG = 0).
- 4. Configure the I2C clock frequency:
  - a. Standard mode (100 kbit/s): I2C\_CON\_REG[I2C\_SPEED] = 1.
  - b. Full speed mode (400 kbit/s): I2C\_CON\_REG[I2C\_SPEED] = 2.
- 5. Setup the I2C Controller as:
  - a. Master: I2C\_CON\_REG[I2C\_MASTER\_MODE] = 1 and I2C\_CON\_REG[I2C\_SLAVE\_DISABLE] = 1.
  - b. Slave: I2C\_CON\_REG[I2C\_MASTER\_MODE] = 0 and I2C\_CON\_REG[I2C\_SLAVE\_DISABLE] = 0.
- Choose whether the controller starts its transfers in the 7-bit or 10-bit addressing format when acting as a master (I2C\_CON\_REG[I2C\_10BITADDR\_MASTER]) or whether the controller responds to the 7-bit or 10-bit addresses when acting as a slave (I2C\_CON\_REG[I2C\_10BITADDR\_SLAVE]).
- Set target slave address in:
  - a. Master mode (I2C\_TAR\_REG[IC\_TAR] = 0x55 (default)).
  - b. Slave mode (I2C\_SAR\_REG[IC\_SAR] = 0x55 (default)).
- Set the threshold levels on RX and TX FIFO (I2C\_RX\_TL\_REG and I2C\_TX\_TL\_REG).
- 9. Enable the required interrupts (I2C\_INTR\_MASK\_REG).
- 10. Enable the I2C Controller (I2C\_ENABLE\_REG = 0x1).
- 11. Read a byte:
  - a. Prepare to transmit the read command byte (I2C\_DATA\_CMD\_REG[I2C\_CMD] = 1).
  - b. Wait until TX FIFO is empty (I2C\_STATUS\_REG[TFE] = 1).
  - c. Wait until master has finished reading the byte from the slave device (I2C\_STATUS\_REG[MST\_ACTIVITY] = 0).
- 12. Write a byte:
  - a. Prepare to transmit the write command byte (I2C\_DATA\_CMD\_REG[I2C\_CMD] = 0 and I2C\_DATA\_CMD\_REG[I2C\_DAT] = command byte).
  - b. Wait until TX FIFO is empty (I2C\_STATUS\_REG[TFE] = 1).
  - Wait until master has finished reading the response byte from the slave device (I2C\_STATUS\_REG[MST\_ACTIVITY] = 0).

**Final** 

## **15 UART**

### 15.1 Introduction

The DA14531 contains two instances of the UART block, that is, UART and UART2.

The UART is compliant to the industry-standard 16550 and is used for serial communication with a peripheral. Data is written from a master (CPU) over the APB bus to the UART and it is converted to the serial form and transmitted to the destination device. Serial data is also received by the UART and stored for the master (CPU) to read back.

There is also DMA support on the UART block, thus the internal FIFOs can be used. Only UART supports the hardware flow control signals (RTS and CTS) and the 9-bit mode.



Figure 44: UART Block Diagram

### **Features**

- 16-byte transmit and receive FIFOs
- Hardware flow control (CTS/RTS) (UART only)
- Shadow registers to reduce software overhead and a software programmable reset is included
- Transmitter Holding Register Empty (THRE) interrupt mode

**Final** 

- Functionality based on the 16550 industry standard:
  - Programmable character properties, such as number of data bits per character (5-8) (optional)
  - o Parity bit (with odd or even select) and number of stop bits (1, 1.5, or 2)
  - Line break generation and detection
  - Prioritized interrupt identification
- Programmable serial data baud rate

## 15.2 Architecture

# 15.2.1 UART (RS232) Serial Protocol

Because the serial communication between the UART and the selected device is asynchronous, additional bits (start and stop) are added to the serial data to indicate the beginning and end. Utilizing these bits allows two devices to be synchronized. This structure of serial data accompanied by the start and stop bits is referred to as a character (Figure 45).



Figure 45: Serial Data Format

An additional parity bit may be added to the serial character. This bit appears after the last data bit and before the stop bit(s) in the character structure to provide the UART with the ability to perform simple error checking on the received data.

The UART Line Control Register (UART\_LCR\_REG) is used to control the serial character characteristics. The individual bits of the data word are sent after the start bit, starting with the least-significant bit (LSB). These are followed by the optional parity bit and then by the stop bit(s), which can be of 1, 1.5, or 2 bits.

All the bits in the transmission (except the half stop bit when the 1.5 stop bits are used) are transmitted for the same time duration. This is referred to as a Bit Period or Bit Time. One Bit Time equals to 16 baud clocks. To ensure stability on the line, the receiver samples the serial input data at approximately the mid-point of the Bit Time once the start bit has been detected. As the exact number of baud clocks that each bit has been transmitted for is known, the mid-point for sampling is every 16 baud clocks after the mid-point sample of the start bit. Figure 46 shows the sampling points of the first couple of bits in a serial character.



Figure 46: Receiver Serial Data Sampling Points

As part of the 16550 standards, an optional baud clock reference output signal (baudout\_n) is supplied to provide timing information to the receiving devices that require it. The baud rate of the UART is controlled by the serial clock (*sclk* or *pclk* in a single clock implementation) and the Divisor Latch Register (DLH and DLL) in the following equation:



**Final** 

(2)

baud rate = (serial clock frequency)/(16 
$$\times$$
 divisor)

where the divisor is a 16-bit integer value plus 4-bit fractional value. The divisor range is 0 to 65535,9375 with steps of 1/16. Divisor High 8-bit integer part is in the DLH register. Divisor Low 8-bit integer part is in the DLL register. Divisor 4-bit fractional port is in the DLF register.

The registers settings for the common baud rate values are presented in Table 47.

**Table 47: UART Baud Rate Generation** 

| Baud Rate | Divider | Divisor<br>Latch | DLH Reg | DLL Reg | DLF Reg | Actual BR | Error (%) |
|-----------|---------|------------------|---------|---------|---------|-----------|-----------|
| 1200      | 833,333 | 833,3125         | 3       | 65      | 5       | 1200,03   | 0,00      |
| 2400      | 416,667 | 416,6875         | 1       | 160     | 11      | 2399,88   | 0,00      |
| 4800      | 208,333 | 208,3125         | 0       | 208     | 5       | 4800,48   | 0,01      |
| 9600      | 104,167 | 104,1875         | 0       | 104     | 3       | 9598,08   | 0,02      |
| 19200     | 52,083  | 52,0625          | 0       | 52      | 1       | 19207,68  | 0,04      |
| 38400     | 26,042  | 26,0625          | 0       | 26      | 1       | 38369,30  | 0,08      |
| 57600     | 17,361  | 17,375           | 0       | 17      | 6       | 57553,96  | 0,08      |
| 115200    | 8,681   | 8,6875           | 0       | 8       | 11      | 115107,91 | 0,08      |
| 230400    | 4,340   | 4,3125           | 0       | 4       | 5       | 231884,06 | 0,64      |
| 460800    | 2,170   | 2,1875           | 0       | 2       | 3       | 457142,86 | 0,79      |
| 921600    | 1,085   | 1,0625           | 0       | 1       | 1       | 941176,47 | 2,12      |
| 1000000   | 1       | 1                | 0       | 1       | 0       | 1000000   | 0,00      |

## 15.2.2 Clock Support

The UART has two system clocks (*pclk* and *sclk*). Having a second asynchronous serial clock (sclk) allows for accurate serial baud rate settings and meeting APB bus interface requirements.

With the two-clock design, a synchronization module is implemented to synchronize all controls and data across the two system clock boundaries.

Although a serial clock faster than four-times the *pclk* does not leave enough time for a complete incoming character to be received and pushed into the receiver FIFO, in most cases the *pclk* signal is faster than the serial clock and this should never be an issue.

The serial clock modules must have time to see new register values and reset their respective state machines. This total time is guaranteed to be no more than eight clock cycles of the slower of the two system clocks. Therefore, no data should be transmitted or received before this maximum time expires after the initial configuration of the UART.

# 15.2.3 Interrupts

The assertion of the UART interrupt (UART\_INT) occurs whenever one of the several prioritized interrupt types are enabled and active. The following interrupt types can be enabled with the IER register:

- Receiver Error
- Receiver Data Available
- Character Timeout (in FIFO mode only)
- Transmitter Holding Register Empty at/below threshold (in Programmable THRE interrupt mode)



**Final** 

When an interrupt occurs, the master accesses the UART\_IIR\_REG to determine the source of the interrupt before dealing with it accordingly. These interrupt types are described in more detail in Table 48.

**Table 48: UART Interrupt Priorities** 

| Interrupt ID | Interrupt Set and Reset Functions |                                    |                                                                                                                                           |                                                                                                                                                                                                                                     |  |  |
|--------------|-----------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits [3-0]   | Priority Interrupt Type           |                                    | Interrupt Source                                                                                                                          | Interrupt Reset Control                                                                                                                                                                                                             |  |  |
| 0001         | -                                 | None                               |                                                                                                                                           |                                                                                                                                                                                                                                     |  |  |
| 0110         | Highest                           | Receiver Line status               | Overrun/parity/framing errors or break interrupt                                                                                          | Reading the line status register                                                                                                                                                                                                    |  |  |
| 0100         | 1                                 | Receiver Data<br>Available         | Receiver data available (non-<br>FIFO mode or FIFOs<br>disabled) or RCVR FIFO<br>trigger level reached (FIFO<br>mode and FIFOs enabled)   | Reading the receiver<br>buffer register (non-FIFO<br>mode or FIFOs disabled)<br>or the FIFO drops below<br>the trigger level (FIFO<br>mode and FIFOs<br>enabled)                                                                    |  |  |
| 1100         | 2                                 | Character timeout indication       | No characters in or out of the RCVR FIFO during the last four-character times and there is at least one character in it during this time. | Reading the receiver buffer register                                                                                                                                                                                                |  |  |
| 0010         | 3                                 | Transmitter holding register empty | Transmitter holding register empty (Prog. THRE Mode disabled) or XMIT FIFO at or below threshold (Prog. THRE Mode enabled).               | Reading the IIR register to check whether there is an interrupt and what its source is; or, writing into THR (FIFOs or THRE Mode not selected or disabled) or XMIT FIFO above threshold (FIFOs and THRE Mode selected and enabled). |  |  |
| 0000         | 4                                 | Reserved                           |                                                                                                                                           |                                                                                                                                                                                                                                     |  |  |
| 0111         | Lowest                            | Reserved                           | -                                                                                                                                         | -                                                                                                                                                                                                                                   |  |  |

### 15.2.4 Programmable THRE Interrupt

The UART can be configured to have a Programmable THRE Interrupt mode available to increase system performance.

When Programmable THRE Interrupt mode is selected, it can be enabled via the Interrupt Enable Register (IER[7]). When FIFOs and the THRE Mode are implemented and enabled, THRE Interrupts are active at and below a programmed transmitter FIFO empty threshold level, as shown in the flowchart in Figure 47. Figure 48 shows the programmed transmitter FIFO empty threshold level, where THRE Interrupts are active when the FIFO is empty. In this case the programmable THRE interrupt mode is disabled.

This threshold level is programmed into FCR[5:4]. The available empty thresholds are: empty, 2,  $\frac{1}{4}$ , and  $\frac{1}{2}$ . See UART\_FCR\_REG for threshold setting details. Selection of the best threshold value depends on the system's ability to begin a new transmission sequence in a timely manner. However, one of these thresholds should prove optimum in increasing system performance by preventing the transmitter FIFO from running empty.

In addition to the interrupt change, Line Status Register (LSR[5]) also switches its function from indicating transmitter FIFO empty to FIFO full. This allows software to fill the FIFO in each transmit sequence by polling LSR[5] before writing another character. Instead of waiting until the FIFO is completely empty, the flow becomes "fill transmitter FIFO whenever an interrupt occurs and there is



**Final** 

data to transmit". Waiting until the FIFO is empty causes a performance hit whenever the system is too busy to respond immediately.

Even if everything else is selected and enabled, if the FIFOs are disabled via FCR[0], the Programmable THRE Interrupt mode is also disabled. When not selected or disabled, THRE interrupts and LSR[5] function normally (both reflecting an empty THR or FIFO). The flowchart of THRE interrupt generation when not in programmable THRE interrupt mode is shown in Figure 48.



Figure 47: Flowchart of Interrupt Generation for Programmable THRE Interrupt Mode

**Final** 



Figure 48: Flowchart of Interrupt Generation When Not in Programmable THRE Interrupt Mode

## 15.2.5 Shadow Registers

The shadow registers shadow some of the existing register bits that are regularly modified by software. These can be used to reduce the software overhead that is introduced by having to perform read-modify-writes.

- UART\_SRBR\_REG support a host burst mode where the host increments its address but still accesses the same receive buffer register
- UART\_STHR support a host burst mode where the host increments its address but still accesses the same transmit holding register
- UART\_SFE\_REG accesses the FCR[0] register without accessing the other UART\_FCR\_REG bits
- UART\_SRT\_REG accesses the FCR[7-6] register without accessing the other UART\_FCR\_REG bits
- UART\_STER\_REG accesses the FCR[5-4] register without accessing the other UART\_FCR\_REG bits

## 15.2.6 Direct Test Mode

The on-chip UARTs can be used for the Direct Test Mode required for the final product PHY layer testing. It can be done either over the HCI layer, which engages a full CTS/RTS UART, or by using a 2-wire UART directly as described in the *Bluetooth Low Energy Specification (Volume 6, Part F)*.

## 15.3 Programming

To configure and use the UART controllers, follow the simple sequence of steps below:

- 1. Set up the GPIOs to be used for the UART interface (P0x\_MODE\_REG[PID] = 1 to 4 and/or 19-20).
- 2. Enable the selected UART by setting the CLK\_PER\_REG[UARTx\_ENABLE] bit.



**Final** 

- 3. Enable access to Divisor Latch Registers (DLL and DLH) by setting the UARTx\_LCR\_REG[UART\_DLAB] bit.
- 4. Set the desired baud rate. To calculate the registers values for the desired baud rate, use the following equation:

Divisor = UART CLK/(16 
$$\times$$
 Baud rate) (3)

- a. UARTx\_IER\_DLH\_REG: High byte of the Divisor integer part.
- b. UARTx\_RBR\_THR\_DLL\_REG: Low byte of the Divisor integer part.
- c. UARTx\_DLF\_REG: The fractional part of the Divisor.
- 5. Configure the break control bit, parity, number of stop bits, and data length (UARTx\_LCR\_REG).
- 6. Enable and configure the FIFO (UARTx\_IIR\_FCR\_REG).
- 7. Configure the generated interrupts, if needed (UARTx\_IER\_DLH\_REG).
- 8. Send a byte:
  - a. Check if Transmit Hold Register (THR) is empty (UARTx\_LSR\_REG[UART\_THRE]).
  - b. Load the byte to THR (UARTx\_RBR\_THR\_DLL\_REG).
  - c. Check if the byte has been transmitted (UARTx\_LSR\_REG[UART\_TEMT]).
- 9. Receive a byte:
  - a. Wait until serial data is ready (UARTx\_LSR\_REG[UART\_DR]).
  - b. Read the incoming byte from the THR (UARTx\_RBR\_THR\_DLL\_REG).

**Final** 

## 16 SPI Interface

### 16.1 Introduction

This controller implements the Serial Peripheral Interface (SPI™)¹ for master and slave modes. The serial interface can transmit and receive from four bits to up to 32 bits in master/slave mode. The controller comprises separate TX and RX FIFOs and DMA handshake support. Slave mode clock speed is independent from the system clock speed. Moreover, master's clock speed can be as fast as the system's clock speed. The controller can generate an interrupt upon data threshold reached in the TX or RX FIFOs.

#### **Features**

- Slave and master mode
- From 4-bit to up to 32-bit operation
- SPI Master clock line speed up to 32 MHz, SPI Slave clock line speed up to 16 MHz
- SPI mode 0, 1, 2, and 3 support (clock edge and phase)
- Built-in separate 8-bit wide and 4-byte deep RX/TX FIFOs for continuous SPI bursts
- Maskable interrupt generation based on TX or RX FIFO thresholds
- DMA support



Figure 49: SPI Block Diagram

-

<sup>1</sup> SPI is a trademark of Motorola, Inc.

**Final** 

### 16.2 Architecture

The SPI controller is an APB peripheral operating on the apb\_clk clock. It contains a front end which is clocked by the spi\_clk clock and is responsible for the serialization/deserialization of the data in the RX and TX streams.

Two separate FIFOs, each of eight bits wide and four bytes deep, are used to store data for RX and TX streams. Since a SPI word can be configured to be from four bits to up to 32 bits, one to four FIFO positions can be written/read at the same time. FIFOs contain logic implementing programmable thresholds comparison.

The SPI controller supports DMA requests and interrupt generation based on the FIFO thresholds. If enabled, a DMA request and/or interrupt will be asserted with whether TX\_FIFO level is low or RX\_FIFO level is high.

The SPI interface supports all four modes of operation and the corresponding polarity (CPOL) and phase (CPHA) of the SPI clock (SPI\_CLK) are defined in Table 49.

| SPI Mode | CPOL | CHPA | TX SPI_CLK   | RX SPI_CLK   | Idle SPI_CLK |
|----------|------|------|--------------|--------------|--------------|
| 0        | 0    | 0    | Falling edge | Rising edge  | Low          |
| 1        | 0    | 1    | Rising edge  | Falling edge | Low          |
| 2        | 1    | 0    | Rising edge  | Falling edge | High         |
| 3        | 1    | 1    | Falling edge | Risina edae  | High         |

**Table 49: SPI Modes Configuration and SCK States** 

To read from or to write to an external single byte FLASH device in the SPI master mode, a byte swap mechanism is implemented to allow for a proper placement of the bytes in a 16-bit word for the DMA to write to/read from the internal RAM. More specifically, when the SPI controller is configured as a master with DMA support and a 16-bit word width so that the bus utilization is increased compared to reading from an 8-bit device, the byte swap mechanism brings the least significant byte read and place it in the most significant byte in the 16-bit word. The controller automatically swaps the bytes to allow for placing the first byte read in the least significant byte of the 16-bit word. This feature is programmable via SPI CTRL REGISPI SWAP BYTESI.

The SPI controller can operate at the highest speed (32 MHz on the SPI\_CLK line) in a special master mode. The clock of the controller is then either the XTAL32M or the RC32M and can be used for fast booting from external FLASH devices that support this frequency.

### **16.2.1 SPI Timing**

The timing of the SPI interface when the SPI controller is in slave mode is presented in Figure 50.



Figure 50: SPI Slave Mode Timing (CPOL = 0, CPHA = 0)

**Final** 

### **Table 50: SPI Timing Parameters**

| Parameter | Description                                       | Тур             | Unit |
|-----------|---------------------------------------------------|-----------------|------|
| tckper    | spi_clk clock period                              | 60              | ns   |
| tcsst     | CS active time before the first edge of spi_clk   | 1 spi_clk cycle |      |
| tcshold   | CS non-active time after the last edge of spi_clk | 1 spi_clk cycle |      |
| tмоsт     | Master input data latching setup time             | (spi_clk/2) - 5 | ns   |
| tmohold   | Master input data hold time                       | 0               | ns   |
| tsodel    | Slave output data delay                           | 25              | ns   |

# 16.3 Programming

#### 16.3.1 Master Mode

To configure the SPI controller in master mode, follow the steps below:

- 1. Set the appropriate GPIO ports in SPI clock mode (output), SPI Chip Select mode (output), SPI Data Out mode (output), and SPI Data In mode (input).
- 2. Enable the SPI clock by setting CLK\_PER\_REG[SPI\_ENABLE] = 1.
- 3. Reset SPI FIFO by setting SPI\_CTRL\_REG[SPI\_FIFO\_RESET] = 1.
- 4. Set the SPI clock mode (synchronous or asynchronous with APB clock) by programming SPI\_CLOCK\_REG[SPI\_MASTER\_CLK\_MODE].
- 5. Set the SPI clock frequency by programming SPI\_CLOCK\_REG[SPI\_CLK\_DIV]. If SPI\_CLK\_DIV is not 0x7F, SPI\_CLK = module\_clk/2 × (SPI\_CLK\_DIV + 1). If SPI\_CLK\_DIV = 0x7F, SPI\_CLK = module\_clk.
- 6. Set the SPI mode (CPOL or CPHA) by programming SPI\_CONFIG\_REG[SPI\_MODE].
- 7. Set the SPI controller in master mode by setting SPI CONFIG REG[SPI SLAVE EN] = 0.
- 8. Define the SPI word length (from 4-bit to 32-bit) by programming SPI\_CONFIG\_REG[SPI\_WORD\_LENGTH]. SPI\_WORD\_LENGTH = word length 1.

To read/write the following sequence should be performed:

- If a slave device is slow and does not give the data at the correct clock edge, configure the SPI module to capture data at the next clock edge by setting SPI\_CTRL\_REG[SPI\_CAPTURE\_AT\_NEXT\_EDGE] = 1. Otherwise, set SPI\_CTRL\_REG[SPI\_CAPTURE\_AT\_NEXT\_EDGE] = 0.
- 2. Release the FIFO reset by setting SPI\_CTRL\_REG[SPI\_FIFO\_RESET] = 0.
- 3. Enable the SPI TX path by setting SPI\_CTRL\_REG[SPI\_TX\_EN] = 1.
- 4. Enable the SPI RX path by setting SPI\_CTRL\_REG[SPI\_RX\_EN] = 1.
- 5. Enable the SPI chip select by programming the SPI\_CS\_CONFIG\_REG[SPI\_CS\_SELECT] = 1 or 2. This option allows the master to select the slave that is connected to the GPIO that has the function of SPI\_CS0 or SPI\_CS1.
- 6. Enable the SPI controller by setting SPI CTRL REG[SPI EN] = 1.
- 7. Write to TX FIFO by programming SPI\_FIFO\_WRITE\_REG[SPI\_FIFO\_WRITE]. Write access is permitted only when SPI\_FIFO\_STATUS\_REG[SPI\_TX\_FIFO\_FULL] = 0.
- 8. Read from RX FIFO by programming SPI\_FIFO\_READ\_REG[SPI\_FIFO\_READ]. Read is permitted only when SPI\_FIFO\_STATUS\_REG[SPI\_RX\_FIFO\_EMPTY] = 0.
- 9. To disable the SPI chip select, set SPI\_CS\_CONFIG\_REG[SPI\_CS\_SELECT] = 0 to deselect the slave and set SPI\_CTRL\_REG[SPI\_FIFO\_RESET] = 1 to reset the SPI FIFO.



**Final** 

### 16.3.2 Slave Mode

- 1. Set the appropriate GPIO ports in SPI clock mode (input), SPI Chip Select mode (input), SPI Data Out mode (output), and SPI Data In mode (input).
- 2. Enable the SPI clock by setting CLK\_PER\_REG[SPI\_ENABLE] = 1.
- 3. Reset the SPI FIFO by setting SPI\_CTRL\_REG[SPI\_FIFO\_RESET] = 1.
- 4. Set the SPI mode (CPOL or CPHA) by programming SPI CONFIG REG[SPI MODE].
- 5. Set the SPI module in slave controller by setting SPI\_CONFIG\_REG[SPI\_SLAVE\_EN] = 1.
- 6. Define the SPI word length (from 4-bit to 32-bit) by programming SPI\_CONFIG\_REG[SPI\_WORD\_LENGTH]. SPI\_WORD\_LENGTH = word length 1.

To read/write the following sequence has to be performed:

- 1. Set SPI FIFO in normal operation by setting SPI CTRL REG[SPI FIFO RESET] = 0.
- Enable the SPI TX path by setting SPI\_CTRL\_REG[SPI\_TX\_EN] = 1.
- 3. Enable the SPI RX path by setting SPI\_CTRL\_REG[SPI\_RX\_EN] = 1.
- 4. Enable the SPI controller by setting SPI\_CTRL\_REG[SPI\_EN] = 1.
- Write the first data byte directly to TX buffer by programming the SPI\_TXBUFFER\_FORCE\_L\_REG[SPI\_TXBUFFER\_FORCE\_L].
- Write the rest of the data to TX FIFO by programming SPI\_FIFO\_WRITE\_REG[SPI\_FIFO\_WRITE]. Write access is permitted only if SPI\_FIFO\_STATUS\_REG[SPI\_TX\_FIFO\_FULL] = 0.
- 7. Read from RX FIFO by programming SPI\_FIFO\_READ\_REG[SPI\_FIFO\_READ]. Read is permitted only if SPI\_FIFO\_STATUS\_REG[SPI\_RX\_FIFO\_EMPTY] = 0.

**Final** 

# 17 Quadrature Decoder

### 17.1 Introduction

The DA14531 has an integrated Quadrature decoder that can automatically decode the signals for the X, Y, and Z axes of a HID input device, reporting step count and direction. It can also be programmed to simply count rising/falling edges on any of the channel pairs. This block can be used to wake up the chip as soon as there is a movement from the connected external device. The block diagram of the quadrature decoder is presented in Figure 51.

### **Features**

- Three 16-bit signed counters that provide the step count and direction on each of the axes (X, Y, and Z) and one 8-bit counter counting the overall edges from all the three counters
- Programmable system clock sampling at a maximum of 16 MHz
- APB interface for control and programming
- Programmable source from the GPIOs
- Digital filter on the channel inputs to avoid spikes



Figure 51: Quadrature Decoder Block Diagram

## 17.2 Architecture

Channels are expected to provide a pulse train with 90 degrees rotation as displayed in Figure 52 and Figure 53.

**Final** 



Figure 52: Moving Forward on Axis X



Figure 53: Moving Backwards on Axis X

Depending on whether channel A or channel B is leading in phase, the quadrature decoding block calculates the direction on the related axis. Furthermore, the signed counter value represents the number of steps moved.

Users can choose which GPIOs to use for the channels by programming the QDEC\_CTRL2\_REG register. The block supports two modes of operation: quadrature counting and edges counting. The quadrature counting mode reads the patterns of successive pulses as in Figure 52 and Figure 53, while the edges counting mode simply counts all positive and negative edges on any of the two channels of a pair.

#### **NOTE**

If two edges happen at the same time, the counter will only count one.

The digital filter eliminates the spikes shorter than three clock periods. It is followed by an edge detection circuitry and they are shown in Figure 54.



Figure 54: Digital Filtering and Edge Detection Circuit

A counter for its dedicated axis holds the movement events of the channels. When a channel is disabled, the counter is reset. The counters are accessible via the APB bus.

The QDEC\_EVENT\_CNT gathers all edges on all channels regardless of the mode of operation. If two edges happen at the same time, this counter will only be increased by one.



**Final** 

The quadrature decoder operates on the system clock. The QDEC\_CLOCKDIV register defines the number of clock cycles during which the decoding logic samples the data on the channel inputs. The division is automatically disabled when the lp\_clk is used as the system clock.

# 17.3 Programming

To program the quadrature decoder for actual quadrature counting or edge counting, follow the simple sequence of steps below:

- Configure the clock frequency by configuring the QDEC\_CLOCKDIV register. The value in this
  register will be dividing the sys\_clk. However, if sys\_clk = lp\_clk, this divider is completely
  bypassed.
- 2. Define which pin pairs represent the different channels for the X, Y, and Z axes or the GPIOs from which the edges are counted. Configure such information at QDEC\_CHX\_PORT\_SEL, QDEC\_CHY\_PORT\_SEL, and QDEC\_CHZ\_PORT\_SEL registers.
- Configure the interrupt threshold upon which an interrupt will be generated at QDEC\_CTRL\_REG[QDEC\_IRQ\_THRES]. Note that the interrupt threshold is based on the value of QDEC\_EVENT\_CNT\_REG which keeps on counting after the interrupt is generated.
- 4. Define the mode of operation by configuring the respective QDEC\_CHx\_EVENT\_MODE field in the QDEC\_CTRL2\_REG.
- 5. Enable the clock of the block by writing at CLK\_PER\_REG[QUAD\_ENABLE].
- 6. Wait for the interrupt and then read X, Y, and Z values at QDEC\_XCNT\_REG, QDEC\_YCNT\_REG, and QDEC\_ZCNT\_REG (in the quadrature counting case) or the QDEC\_EVENT\_CNT\_REG (in the edges counting case).
- 7. Clear the interrupt (by writing at QDEC\_CTRL\_REG[QDEC\_IRQ\_STATUS]) and the edge counter (by writing at QDEC\_CTRL\_REG[QDEC\_EVENT\_CNT\_CLR) if needed.

**Final** 

# 18 Clockless Wake-Up Controller

### 18.1 Introduction

The Clockless Wake-up Controller implements a circuit that enables the RC32K clock which in turn triggers the HW Startup FSM to allow the system to be woken up by an external event (a GPIO toggle). This controller is only used when the system is in hibernation mode, that is, when all clocks are stopped.

### **Features**

- Wake up the system from specific GPIOs (P0\_1, P0\_2, P0\_3, P0\_4, and P0\_5)
- Configurable polarity of the GPIO signals (single configuration for all GPIOs)
- Special RC filtered inputs feeding the wakeup control circuit (Type B pads)
- Always powered



Figure 55: Clockless Wake-Up Controller Circuit

## 18.2 Architecture

The Clockless Wake-up Controller automatically enables the RC32K oscillator when a toggle is identified in one of the five specific GPIOs (P0\_1, P0\_2, P0\_3, P0\_4, and P0\_5). These GPIO signals are connected to the Type B pads, which provide two outputs to the digital domain. One output goes through a Schmitt trigger and the other one goes through an RC filter with a cutoff frequency of 100 kHz and a Schmitt trigger. The output going through the RC filter and a Schmitt trigger feeds the clockless wakeup controller circuitry. Hence, any spikes larger than 100 kHz will be filtered out without waking up the system.

The triggering GPIO can be defined by means of a masking register. If no GPIO is masked out, any toggle in any of these GPIOs will create an edge which serves as a clock for a Flip-Flop to lock and enable the oscillator. The polarity of the edge is also programmable, but it is common for the GPIOs and not a dedicated bit per GPIO.

Note that, if two opposite edges occur exactly at the same time on two GPIOs that are allowed to wake up the system, the XOR output will not change its value and no wake up occurs. However, even if the GPIO signal events have a couple of ns difference, the circuit will still understand it and the clock will be started.



**Final** 

# 18.3 Programming

To program the clockless wakeup controller before setting the system into hibernation mode, follow the simple sequence of steps below:

- 1. Define which pins are allowed to wake up the system from hibernation by configuring the HIBERN\_CTRL\_REG[HIBERN\_WKUP\_MASK].
- 2. Define the polarity of the waking up events at HIBERN\_CTRL\_REG[HIBERN\_WKUP\_POLARITY]. This should be done by reading the value of the unmasked GPIOs and programming the polarity register with their XOR'ed state.
- 3. Enable the hibernation mode by programming the HIBERN\_CTRL\_REG[HIBERNATION\_ENABLE] bit field. Note that this action stops all clocks when the system drops to sleep.
- 4. Allow RAM to be retained by programming the RAM\_PWR\_CTRL\_REG accordingly.
- 5. Define where address 0 is to be mapped at SYS\_CTRL\_REG[REMAP\_ADR0] so that the CPU can execute code right after waking up. If RAM is retained, REMAP\_ADR0 should point to 0x2 or 0x3.
- 6. Clear RESET\_STAT\_REG. Clear this register means that the system wakes up from the hibernation mode.
- 7. Put the system to sleep by executing the WFI command with the SCR bit set.

**Final** 

# 19 Clocked Wake-Up Controller

### 19.1 Introduction

The Clocked Wake-Up Controller can be programmed to wake up the DA14531 from deep sleep mode and extended sleep mode upon a pre-programmed number of GPIO events on a maximum of two pins in parallel. This wakeup controller resides in the PD\_SLP power domain and operates on the LP CLK.

The block diagram illustrating the wakeup function is shown in Figure 56.

#### **Features**

- Monitors GPIO state changes
- Implements debouncing time from 0 ms up to 63 ms on two GPIOs in parallel
- Accumulates external events and compares the number to a programmed value
- Generates an interrupt to the CPU's WIC



Figure 56: Clocked Wake-Up Controller Block Diagram

# 19.2 Architecture

The controller comprises two identical circuits that implement the edge detection, debouncing, and event counting before generating a wakeup interrupt towards the CPU.

A LOW to HIGH level transition on the selected input port sets internal signal "key\_hit" to 1, while WKUP\_POL\_GPIO\_REG[y] = 0. This signal triggers the event counter state machine as shown in Figure 57. The debounce counter is loaded with the value of

WKUP\_CTRL\_REG[WKUP\_DEB\_VALUE]. The timer counts down every 1 ms. The signal state is constantly monitored. If the debounce counter reaches 0, it means that the key\_hit signal state has been stable over the amount of clock cycles counted by the debounce counter.

**Final** 



Figure 57: Event Counter State Machine for the Wake-Up Interrupt Generator

The event counter is edge sensitive. After an active edge is detected, a reverse edge must be detected first before the event counter goes back to the IDLE state and from there starts waiting for a new active edge.

If the event counter is equal to the value set in the WKUP\_COMPARE\_REG register, the counter will be reset and an interrupt will be generated, if the interrupt generation has been enabled by WKUP\_ENABLE\_IRQ and WKUP2\_ENABLE\_IRQ in the WKUP\_CTRL\_REG.

#### **NOTE**

There is only one register for both circuits that contains the number of events before an interrupt is issued.

The interrupt can be cleared by writing a value to the register WKUP\_RESET\_IRQ\_REG. The event counter can be reset by writing a value to the register WKUP\_RESET\_CNTR\_REG. The value of the event counter can be read at any time by reading register WKUP\_COUNTER\_REG.

Any of the GPIO inputs can be selected to generate an event by programming the corresponding WKUP/WKUP2\_SELECT\_GPIO\_REG register. When both WKUP/WKUP2\_SELECT\_GPIO\_REG registers are configured to generate a wakeup interrupt, a toggle on any GPIO will wake up the system.

The input signal edge can be selected by programming the WKUP/WKUP2\_POL\_GPIO\_REG registers.

#### NOTE

A minimum of 2 low power clocks pulse is required on a GPIO in order to be correctly identified as a wake-up edge trigger

## 19.3 Programming

To configure the clocked wakeup controller, follow the simple sequence of steps below:

- 1. Define the polarity of the triggering GPIOs at WKUP/WKUP2\_POL\_GPIO\_REG.
- 2. Configure the debouncing counters by programming WKUP\_CTRL\_REG[WKUP\_DEB\_VALUE] with the amount of time (ms) during which the signal should be re-sampled before its state is decided. Note that there is a single bit field for both debouncing counters.
- 3. Define the number of events that are needed to trigger the wakeup interrupt by programming the WKUP\_COMPARE\_REG. Note there is only one register for both circuits.
- 4. Allow the interrupt generation by configuring the WKUP\_ENABLE\_IRQ and WKUP2\_ENABLE\_IRQ bit fields, respectively, in the WKUP\_CTRL\_REG.
- 5. Define which GPIOs are allowed to trigger a wakeup event at WKUP/WKUP2\_SELECT\_GPIO\_REG.

# **DA14531**



# **Ultra Low Power Bluetooth 5.1 SoC**

**Final** 

6. Set the system to deep sleep mode or extended sleep mode by executing the WFI command with the SCR bit set.

**Final** 

# **20** Timer **0**

### 20.1 Introduction

Timer 0 is a 16-bit general purpose software programmable timer, which has the ability of generating Pulse Width Modulated (PWM) signals PWM0 and PWM1. It also generates the SWTIM\_IRQ interrupt to the Arm Cortex-M0+. It can be configured in various modes regarding output frequency, duty cycle, and the modulation of the PWM signals. Figure 58 shows the block diagram of Timer 0.

### **Features**

- 16-bit general purpose timer
- Ability to generate two PWM signals (PWM0 and PWM1)
- Programmable output frequency (f) with N = 0 to  $(2^{16}-1)$  and M = 0 to  $(2^{16}-1)$

$$f = \frac{(16, 8, 4, 2 \text{ MHz or } 32 \text{ kHz})}{(M+1) + (N+1)}$$

Programmable duty cycle (δ):

$$\delta = \frac{M+1}{(M+1)+(N+1)} \times 100 \%$$

Separately programmable interrupt timer:

$$T = \frac{(16, 8, 4, 2 \text{ MHz or } 32 \text{ kHz})}{(ON+1)}$$



Figure 58: Timer 0 Block Diagram

## 20.2 Architecture

The 16-bit Timer 0 consists of two counters, that is, T0-counter and ON-counter, and three registers, that is, TIMER0\_RELOAD\_M\_REG, TIMER0\_RELOAD\_N\_REG, and TIMER0\_ON\_REG. Upon



**Final** 

reset, the counter and register values are 0x0000. Timer 0 generates a PWM signal PWM0, of which the frequency and duty cycle are determined by the contents of the TIMER0\_RELOAD\_N\_REG and the TIMER0\_RELOAD\_M\_REG registers. The PWM1 signal is the inverted version of PWM0.

Timer 0 can run at five different clocks: 16 MHz, 8 MHz, 4 MHz, 2 MHz, or 32 kHz. The 32 kHz clock is selected by default with bit TIM0\_CLK\_SEL in the TIMER0\_CTRL\_REG register. This slow clock has no enabling bit. The other four options can be selected by setting the TIM0\_CLK\_SEL bit and the TMR\_ENABLE bit in the CLK\_PER\_REG (by default the TMR\_ENABLE bit is disabled). This register also controls the four higher clock frequency on which Timer 0 runs via the TMR\_DIV bits. An extra clock divider is available and can be activated via bit TIM0\_CLK\_DIV of the timer control register TIMER0\_CTRL\_REG. This clock divider is only used for the ON-counter and always divides the clock for the ON-counter by 10.

#### NOTE

If the LP clock is selected as system clock, the CLK\_AMBA\_REG[HCLK] bit field should always be 0 to ensure the proper operation of the timer.

Timer 0 operates in PWM mode. The signals PWM0 and PWM1 can be mapped to any GPIOs.

#### **Timer 0 PWM Mode**

If bit TIM0\_CTRL in the TIMER0\_CTRL\_REG is set, Timer 0 will start running. SWTIM\_IRQ will be generated and the T0-counter will load its start value from the TIMER0\_RELOAD\_M\_REG register and will decrement on each clock cycle. The ON-counter also loads its start value from the TIMER0\_ON\_REG register and decrements with the selected clock.

When the T0-counter reaches zero, the internal signal T0-toggle will be toggled to select the TIMER0\_RELOAD\_N\_REG whose value will be loaded in the T0-counter. Each time the T0-counter reaches zero, it will alternately be reloaded with the values of the M0- and N0-shadow registers. PWM0 will be high when the M0-value decrements and low when the N0-value decrements. For PWM1 the opposite is applicable since it is inverted. If bit PWM\_MODE in the TIMER0\_CTRL\_REG register is set, the PWM signals are not HIGH during the "high time" but output a clock in that stage. The frequency is based on the clock settings defined in the CLK\_PER\_REG register (also when the 32-kHz clock is used), but the selected clock frequency is divided by two to get a 50 % duty cycle.

If the ON-counter reaches zero, it will remain zero until the T0-counter also reaches zero, while decrementing the value loaded from the TIMER0\_RELOAD\_N\_REG register (PWM0 is low). The counter will then generate an interrupt (SWTIM\_IRQ). The ON-counter will be reloaded with the value of the TIMER0\_ON\_REG register. The T0-counter as well as the M0-shadow register will be loaded with the value of the TIMER0\_RELOAD\_M\_REG register. At the same time, the N0-shadow register will be loaded with the value of TIMER0\_RELOAD\_N\_REG register. Both counters will be decremented on the next clock again and the sequence will be repeated.

## **NOTE**

It is possible to generate interrupts at a high rate by selecting a high clock frequency and low counter values. This could result in missed interrupt events.

During the time when the ON-counter is non-zero, new values for the ON-register, M0-register, and N0-register can be written, but they are not used by the T0-counter until a full cycle is finished. More specifically, the newly written values in the TIMER0\_RELOAD\_M\_REG and TIMER0\_RELOAD\_N\_REG registers are only stored into the shadow registers when the ON-counter and the T0-counter have both reached zero and the T0-counter is decrementing the value loaded from the TIMER0\_RELOAD\_N\_REG register (Figure 59).

**Final** 



TIM0580-01

Figure 59: Timer 0 PWM Mode

At start-up both counters and the PWM0 signal are LOW, so at start-up an interrupt is also generated. If Timer 0 is disabled, all flip-flops, counters, and outputs are in reset state except the ON-register, the TIMER0\_RELOAD\_N\_REG register, and the TIMER0\_RELOAD\_M\_REG register.

The timer input registers, that is, ON-register, TIMER0\_RELOAD\_N\_REG, and TIMER0\_RELOAD\_M\_REG can be written, and the counter registers ON-counter and T0-counter can be read. When reading from the address of the ON-register, the value of the ON-counter is returned. Reading from the address of either the TIMER0\_RELOAD\_N\_REG or the TIMER0\_RELOAD\_M\_REG register returns the value of the T0-counter.

It is possible to freeze Timer 0 with bit FRZ\_SWTIM of the register SET\_FREEZE\_REG. When the timer is frozen, the timer counters are not decremented. This will freeze all the timer registers at their last value. The timer will continue its operation again when bit FRZ\_SWTIM is cleared via register RESET\_FREEZE\_REG.

## 20.3 Programming

When LP clock is selected as system clock,  $CLK\_AMBA\_REG[HCLK\_DIV]$  should be set to 0.

When LP clock is selected as Timer clock, CLK\_PER\_REG[TMR\_DIV] should be set to 0

## 20.3.1 Timer Functionality

Timer 0 supports the functionality of a timer for generating interrupts after specific time intervals. To configure the timer operation, follow the steps below:

- 1. Select the timer clock by programming TIMER0\_CTRL\_REG[TIM0\_CLK\_SEL]. The system or the LP clock can be selected using this option.
- 2. Select the clock division scaler by programming CLK\_PER\_REG[TMR\_DIV]. Note that this setting only applies to the system clock.
- 3. Define whether Timer 0 will use the clock frequency as is or divided by 10 by programming TIMERO\_CLK\_REG[TIMO\_CLK\_DIV].
- 4. Enable Timer 0 clock by programming CLK PER REG[TMR ENABLE].
- 5. For 16-bit counting, program TIMER0\_ON\_REG with the expired time in timer 0 clock cycles TIMER0\_RELOAD\_M\_REG and TIMER0\_RELOAD\_N\_REG must be set to 0.
- 6. For 17-bit counting, load 65535 to TIMER0\_RELOAD\_M\_REG and the rest to TIMER0\_RELOAD\_N\_REG. TIMER0\_ON\_REG must be set to 0.
- 7. Enable Timer 0 by programming TIMER0 CTRL REGITIM0 CTRL1.

**Final** 

### 20.3.2 PWM Generation

Timer 0 also supports PWM generation. To configure the PWM generation functionality, follow the steps below:

- 1. Select the timer clock by programming TIMER0\_CTRL\_REG[TIM0\_CLK\_SEL]. The system or the LP clock can be selected by this option.
- Select the clock division scaler by programming CLK\_PER\_REG[TMR\_DIV]. Note that this setting only applies to the system clock.
- 3. Select the PWM mode by programming the TIMER0\_CTRL\_REG[PWM\_MODE]. There are two modes supported. In the first one, the PWM signals are '1' during high time. In the second one, the PWM signals send out the (fast) clock divided by two during high time, so the clock frequency will be in the range of 1 to 8 MHz.
- 4. Enable Timer 0 clock by programming CLK PER REG[TMR ENABLE].
- 5. Load the "high" value of the duty cycle in TIMER0\_RELOAD\_M\_REG and the "low" value of the duty cycle in TIMER0\_RELOAD\_N\_REG.
- 6. Set the desired GPIOs in PWM0/PWM1 and output mode.
- 7. Enable Timer 0 by programming TIMER0 CTRL REG[TIM0 CTRL].

## 21 Timer 1

## 21.1 Introduction

Timer 1 is an 11-bit timer that can count up or down. It supports a free-running mode with an interrupt generated when zero is reached (also by wrapping around). It can be configured to use the system clock (sys\_clk) or the LP clock (lp\_clk) as the clock source. It supports capturing events on two GPIO channels when the number of clock cycles between these events is known. It can also generate an interrupt after a programmable number of clock cycles after an event. Figure 60 shows the block diagram of Timer 1.

## **Features**

- 11-bit up/down counter with free running mode
- Selectable system or LP clock as source
- Two channels for capture input triggered by GPIOs
- Capture capability from two GPIO events with programmable polarity
- Programmable number of events between the two GPIOs for capturing
- Timer 1 or RTC snapshot on capture events
- Interrupt generation

**Final** 



Figure 60: Timer 1 Block Diagram

### 21.2 Architecture

Timer 1 is placed in the PD\_TIM power domain which can be kept powered even when the system power domain (containing the CPU) is shut down.

The main operation of Timer 1 is to count up or down, generating an interrupt when it reaches the maximum/minimum value or the threshold that has been programed as the reload value.

Moreover, Timer 1 comes with a sense block that allows for sensing positive or negative edges on two GPIOs (configurable). The sense block operates in two modes:

- Counting mode: Timer1 will generate an interrupt upon a configurable amount of edges on a
  GPIO has been detected. The number of clock cycles was counted between timer start and
  captured the N events is stored to CAPCNTx\_VALUE register. When timer detects the first Nevents, automatically starts to detect the next N-events until timer is disabled
- Capture mode: Timer 1 saves a snapshot of either its own counter (11 bits) or the RTC port (22 bits) after an edge on a GPIO has been detected. If there is a pending interrupt, a new snapshot is not saved and the TIMER1\_STATUS\_REG[TIMER1\_INx\_OVRFLW] bit is set. This bit is cleared together with the TIMER1\_STATUS\_REG[TIMER1\_Inx\_EVENT] bit

The same GPIO can be used for both modes.

If Timer 1 is used in the counting mode, it can measure the frequency applied to a GPIO port (see section 21.3.3).

## 21.3 Programming

When LP clock is selected as system clock, CLK\_AMBA\_REG[HCLK\_DIV] should be set to 0.

## 21.3.1 Timer Functionality

Timer 1 supports the functionality of a timer for generating interrupts after specific time intervals. To configure the timer functionality, follow the steps below:

1. Select the timer clock by programming TIMER1\_CTRL\_REG[TIMER1\_USE\_SYS\_CLK]. The system or the LP clock can be selected by this option.

## **NOTE**

If the LP clock is selected as system clock, the CLK\_AMBA\_REG[HCLK] bit field should always be 0 to ensure the proper operation of the timer.



**Final** 

- Enable or disable the free run mode by programming TIMER1\_CTRL\_REG[TIMER1\_FREE\_RUN\_MODE\_EN]. The free run mode can only be used when Timer 1 counts up.
- 3. Enable Timer 1 interrupt by programming TIMER1 CTRL REG[TIMER1 IRQ EN].
- 4. Set Timer 1 to count up or down by programming TIMER1\_CTRL\_REG[TIMER1\_COUNT\_DOWN\_EN].
- 5. Specify the reload value by programming TIMER1\_CTRL\_REG[TIMER1\_RELOAD].
- 6. Enable the Timer 1 clock by programming TIMER1\_CTRL\_REG[TIMER1\_CLK\_EN].
- 7. Enable Timer 1 by programming TIMER1\_CTRL\_REG[TIMER1\_ENABLE].

# 21.3.2 Capture Functionality

Timer 1 can capture a snapshot of the value of RTC or Timer1 counts after a GPIO edge is detected. To configure the capture functionality, follow the steps below:

- 1. Depending on the source of the snapshot value, configure and enable RTC or Timer 1 or both in the capture mode.
- 2. Set the edge type (rising or falling edge) by programming TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_EVENT\_FALL\_EN] or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_EVENT\_FALL\_EN], depending on the channel that is used.
- 3. Set the timer in capture mode by setting TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_COUNT\_EN]=0 or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_COUNT\_EN]=0, depending on the channel that is used.
- 4. Enable capture interrupt by setting TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_IRQ\_EN] = 1 or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_IRQ\_EN] = 1, depending on the channel that is used.
- 5. Set the source of the snapshot value (RTC or Timer 1 count) by setting TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_STAMP\_TYPE] or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_STAMP\_TYPE], depending on the channel that is used.
- Set the GPIO that will be used to trigger the capture by setting
   TIMER1\_CAPTURE\_REG[TIMER1\_GPIO1\_CONF] or
   TIMER1\_CAPTURE\_REG[TIMER1\_GPIO1\_CONF], depending on the channel that is used.
   Note that the values from 1 to 12 define the P0 pins from 0 to 11.
- 7. When an interrupt is generated, the capture value will be saved in TIMER1\_CAPCNT1\_VALUE\_REG[TIMER1\_CAPCNT1\_VALUE] or TIMER1\_CAPCNT2\_VALUE\_REG[TIMER1\_CAPCNT2\_VALUE], depending on the channel that is used.
- 8. Write 1 to TIMER1 CLR EVENT REG[TIMER CLR Inx EVENT] to clear the event.

# 21.3.3 Frequency Measuring Functionality

Timer 1 can measure the frequency applied to a GPIO port. To configure the frequency measure functionality, follow the steps below:

- 1. Configure and enable Timer 1 in count up free mode using the system clock.
- 2. Set Timer 1 in count mode by setting TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_COUNT\_EN] = 1 or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_COUNT\_EN] = 1, depending on the channel that is used.
- 3. Enable capture interrupt by setting TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_IRQ\_EN] = 1 or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_IRQ\_EN] = 1, depending on the channel that is used.
- 4. Set the rising edge by programming TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_EVENT\_FALL\_EN] = 0 or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_EVENT\_FALL\_EN] = 0, depending on the channel that is used.



**Final** 

- Set the number of periods plus one, in which Timer 1 counts, by setting TIMER1\_CAPTURE\_REG[TIMER1\_IN1\_PERIOD\_MAX] or TIMER1\_CAPTURE\_REG[TIMER1\_IN2\_PERIOD\_MAX], depending on the channel that is used.
- 6. Set the GPIO that will be used to trigger the capture by setting TIMER1\_CAPTURE\_REG[TIMER1\_GPIO1\_CONF] or TIMER1\_CAPTURE\_REG[TIMER1\_GPIO1\_CONF], depending on the channel that is used. Note that the values from 1 to 12 define the P0 pins from 0 to 11.
- After the interrupt is triggered, read the value in TIMER1\_CAPCNT1\_VALUE\_REG[TIMER1\_CAPCNT1\_VALUE] or TIMER1\_CAPCNT2\_VALUE\_REG[TIMER1\_CAPCNT2\_VALUE], depending on the channel that is used. This value indicates the number of cycles that has passed during the period defined in step 5.
- 8. To calculate the frequency applied to the GPIO, divide the number of periods (step 5) by the cycles (step 7) and multiply the result with the frequency of Timer 1 clock.
- 9. Write 1 to TIMER1\_CLR\_EVENT\_REG[TIMER\_CLR\_Inx\_EVENT] to clear the event.

**Final** 

## **22 Timer 2**

## 22.1 Introduction

Timer 2 is basically a PWM generator. It has six PWM outputs. The block diagram is shown in Figure 61.



Figure 61: Timer 2 Block Diagram

#### **Features**

- 14-bit general purpose timer
- Ability to generate six PWM signals (PWM2, PWM3, PWM4, PWM5, PWM6, and PWM7,)
- Input clock frequency (f<sub>IN</sub>) with N = 1, 2, 4, or 8 and sys\_clk = 16 MHz or 32 kHz:

$$f_{IN} = \frac{sys\_clk}{N}$$

Programmable output frequency (fout):

$$f_{OUT} = \left(\frac{f_{IN}}{2}\right) to \left(\frac{f_{IN}}{2^{14}-1}\right)$$

- Six outputs with a programmable duty cycle from 0 % to 100 %
- Used for white LED intensity (on/off) control or motor control

Datasheet Revision 3.6 26-Sep-2022

© 2022 Renesas Electronics

**Final** 

### 22.2 Architecture

Timer 2 is clocked with the system clock divided by TMR\_DIV (1, 2, 4, or 8) and can be enabled with TRIPLE PWM CTRL REGITRIPLE PWM ENABLE].

TRIPLE PWM FREQUENCY determines the output frequency of the PWM outputs.

### **NOTE**

There is a single frequency register for all six PWM outputs.

DUTY CNTR is an up-counter counting from 0 up to TRIPLE PWM FREQUENCY.

If DUTY\_CNTR is equal to the value stored in the respective PWMn\_END\_CYCLE register, it resets the PWMn output to 0.

If DUTY\_CNTR is equal to the value stored in the respective PWMn\_START\_CYCLE register, it sets the PWMn output to 1.

Note that the value of PWMn\_END\_CYCLE and PWMn\_START\_CYCLE must be less than or equal to TRIPLE PWM FREQUENCY.

The Timer 2 is enabled/disabled by programming the TRIPLE\_PWM\_CTRL\_REG[TRIPLE\_PWM\_EN] bit.

The timing diagram of Timer 2 is shown in Figure 62.

### Freeze function

During RF activity it may be desirable to temporarily suppress the PWM switching noise. This can be done by setting TRIPLE\_PWM\_CTRL\_REG[HW\_PAUSE\_EN] = 1. The effect is that whenever there is a transmission or a reception process from the Radio, DUTY\_CNTR is frozen and PWMx output is switched to 0 to disable the selected PWMn. As soon as the Radio is idle, that is, RX\_EN or TX\_EN signals are zero, DUTY\_CNTR resumes counting and finalizes the remaining part of the PWM duty cycle.

TRIPLE\_PWM\_CTRL\_REG[SW\_PAUSE\_EN] can be set to 0 to disable the automatic, hardware driven freeze function of the duty counter and keep the duty cycle constant.

Note that the RX\_EN and TX\_EN signals are not software driven but controlled by the Bluetooth® LE core hardware.



Figure 62: Timer 2 Timing Diagram

## 22.3 Programming

When LP clock is selected as system clock, CLK\_AMBA\_REG[HCLK\_DIV] should be set to 0.

When LP clock is selected as Timer clock, CLK\_PER\_REG[TMR\_DIV] should be set to 0

#### 22.3.1 PWM Generation

Timer 2 only supports PWM generation and does not support a normal, interrupt generating, timer functionality as the previous timers do. To configure the PWM generation functionality, follow the steps below:



**Final** 

- 1. Select the clock source for Timer 2 by programming TRIPLE\_PWM\_CTRL\_REG[TRIPLE\_PWM\_CLK\_SEL]. System clock or LP clock can be selected. Please note that if the (fast) system clock is selected, the division scaler is the same as the one for Timer 0.
- 2. Define the GPIOs to which the PWM signals are mapped by programming the respective PID number.
- 3. Define the frequency of Timer 2 that feeds the PWM waveforms by programming the TRIPLE\_PWM\_FREQUENCY with a value that conforms to the following equation. For example, if Timer 2 clock is 32000 Hz (lp\_clk) and the required frequency for the PWM is 16 kHz, this register should be written with 0x1.

Timer2\_clk\_freq\_Hz/Required\_freq\_Hz -1 (4)

#### NOTE

There is a single frequency register for all six PWM outputs.

- 4. Define the duty cycle of each PWM signal. Program the start and end cycle of the pulse at PWMx\_START\_CYCLE and PWMx\_END\_CYCLE, respectively. The available amount of cycles is depicted in the contents of TRIPLE\_PWM\_FREQUENCY register. For example, if the TRIPLE\_PWM\_FREQUENCY has a value of 0x8 and the START/END\_CYCLE bit fields have a value of 3 and 5, respectively, the PWM signals will rise after three Timer 2 clock cycles and fall after five clock cycles. Every PWM signal has its own register to configure its duty cycle.
- 5. Enable the PWM signals by programming TRIPLE\_PWM\_CTRL\_REG[TRIPLE\_PWM\_ENABLE] = 1.

# 22.3.2 Freeze Functionality

There is provision to allow hardware to pause PWM signals while RF is active. This can be done by programming TRIPLE\_PWM\_CTRL\_REG[HW\_PAUSE\_EN] = 1. It can also be done via SW control by programming TRIPLE\_PWM\_CTRL\_REG[SW\_PAUSE\_EN] = 1.

**Final** 

# 23 Watchdog Timer

### 23.1 Introduction

The Watchdog Timer is an 8-bit timer with a sign bit that can be used to detect an unexpected execution sequence caused by a software run-away and can generate a full system reset (WDOG reset) or a Non-Maskable Interrupt (NMI). Figure 63 shows the block diagram of the Watchdog Timer.

### **Features**

- 8-bit down counter with a sign bit, clocked with a 10.24 ms clock for a maximum 2.6 s time-out
- Non-Maskable Interrupt (NMI) or WDOG reset
- Optional automatic WDOG reset if NMI handler fails to update the Watchdog register
- Non-maskable Watchdog freeze of the Cortex-M0+ Debug module when the Cortex-M0+ is halted in Debug state. Maskable Watchdog freeze by user program



Figure 63: Watchdog Timer Block Diagram

## 23.2 Architecture

The 8-bit watchdog timer is decremented by 1 every 10.24 ms. The timer value can be accessed through the WATCHDOG\_REG register which is set to 255 (FF $_{16}$ ) at reset. This results in a maximum watchdog time-out of ~2.6 s. During write access, the WATCHDOG\_REG[WDOG\_WEN] bit must be 0. This provides extra filtering for a software run-away by writing ones to all the bits in the WATCHDOG\_REG. If the watchdog timer reaches 0, its value will get a negative value by setting bit 8. The counter sequence becomes 1, 0, 1FF $_{16}$  (-1), 1FE $_{16}$ (-2), till 1FO $_{16}$  (-16).

If WATCHDOG\_CTRL\_REG[NMI\_RST] = 0, the watchdog timer will generate an NMI when it reaches 0 and a WDOG reset when it becomes less or equal to -16 (1F0<sub>16</sub>). The NMI handler must write a value that is larger than -16 to the WATCHDOG\_REG to prevent the generation of a WDOG reset when the watchdog timer reaches the value -16 after  $16 \times 10.24 = 163.8$  ms.

If WATCHDOG\_CTRL\_REG[NMI\_RST] = 1, the watchdog timer generates a WDOG reset when it becomes less than or equal to 0.

The WDOG reset is one of the system (SYS) reset sources and resets almost the whole device, including resetting the WATCHDOG\_REG register to 255. Refer to the POR, HW, and SW Reset section for an overview of the complete reset circuit and conditions.

For debugging purposes, the Cortex-M0+ Debug module can always freeze the watchdog by setting the DHCSR[DBGKEY | C HALT | C DEBUGEN] control bits (reflected by the status bit S HALT, see



**Final** 

Table 42). This is automatically done by the debugging tool, for example, during step-by-step debugging. Note that this bit also freezes the Wake-up Timer, the Software Timer, and the BLE master clock. For additional information see the DEBUG\_REG[DEBUGS\_FREEZE\_EN] mask register. The C\_DEBUGEN bit cannot be accessed by the user software so that freezing the watchdog is prevented.

In addition to the S\_HALT bit, the watchdog timer can also be frozen if NMI\_RST = 0 and SET\_FREEZE\_REG[FRZ\_WDOG] is set to 1. The watchdog timer resumes counting when RESET\_FREEZE\_REG[FRZ\_WDOG] is set to 1. The WATCHDOG\_CTRL\_REG[NMI\_RST] bit can only be set by software and will only be reset on a SYS reset. Note that if the system is not remapped, that is, the SysRAM is at address 0x07FC0000, a watchdog fire will trigger the BootROM code to be executed again.

# 23.3 Programming

To program the Watchdog Timer, follow the simple sequence of steps below:

- 1. Freeze watchdog by setting the SET\_FREEZE\_REG[FRZ\_WDOG] bit (optional).
- 2. Select NMI and reset events (WATCHDOG\_CTRL\_REG[NMI\_RST]).
- 3. Enable writing of the watchdog timer (WATCHDOG\_REG[WDOG\_WEN] = 0]).
- 4. Write the reload value of the watchdog timer (WATCHDOG\_REG[WDOG\_VAL], see the register description).
- 5. Resume watchdog (RESET\_FREEZE\_REG[FRZ \_WDOG] = 1), if frozen.

**Final** 

# 24 Temperature Sensor

### 24.1 Introduction

The DA14531 features a built-in temperature sensor.

### **Features**

- Temperature range -40 °C to 105 °C
- Absolute accuracy after one-point calibration +/- 4 °C (assuming 25 °C reference temperature)
- 25 °C single point calibration reference value provided in OTP memory

## 24.2 Architecture

The temperature sensor can be read out via the GP\_ADC.

Figure 64 illustrates the relationship between the actual ambient temperature and the calculated temperature from the GP\_ADC readout, including possible inaccuracies in Tsense\_acc\_otp (offset) and TCsense (angle).



Figure 64: Temperature Sensor Behavior



**Final** 

The recommended formula for single point calibrated temperature reading is as follows:

 $T_x = 25 + (ADC_x - ADC_{OTP CAL 25C})/(TC_{SENSE} \times 64)$ 

Where:

- T<sub>x</sub> = calculated single point calibrated die temperature in [°C]
- ADC<sub>x</sub> = 16-bit GP\_ADC\_VAL readout (converted to decimal) at temperature T<sub>x</sub>
- ADC<sub>OTP\_CAL\_25C</sub> = 25 °C OTP calibration value recorded during production testing (based on the 16-bit readout)
- TC<sub>SENSE</sub> = temperature coefficient in [LSB/°C], typical value is 1.45 LSB/°C
- 25 = reference base value in [°C]
- 64 = correction for 16-bit to 10-bit ADC values

For uncalibrated temperature sensor measurements, ADCotp\_CAL25C can be replaced by the default value using the formula below:

 $T_x = 25 + (ADC_x - 30272)/(TC_{SENSE} \times 64)$ 

Note that this is not recommended since it can result in large offsets.

### **NOTE**

While measuring and/or calibration, the system's power dissipation should be kept the same, otherwise, the measurement is affected by the internal thermal gradient.

## 24.2.1 Programming

There is a certain programming sequence required to read the temperature sensor. There are two reading options available:

- absolute temperature (single-point calibration)
- relative temperature

## 24.2.1.1 Absolute Temperature

A calibration value at 25 °C is stored in OTP for absolute temperature measurements. When the calibration value from OTP is used, the default GP\_ADC offset calibration settings should be used.

- To enable OTP in normal read mode:
  - CLK\_AMBA\_REG[OTP\_ENABLE] = 1
  - OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 2
- To read the calibration value at 25°C:
  - Read ADC<sub>OTP\_CAL\_25C</sub>: the content of ADC<sub>OTP\_CAL\_25C</sub> is at the address 0x7F87F28 of the OTP
- To disable OTP:
  - OTPC\_MODE\_REG[OTPC\_MODE\_MODE] = 0
  - CLK\_AMBA\_REG[OTP\_ENABLE] = 0
- To read back the offset calibration:
  - Offp = GP\_ADC\_OFFP\_REG[GP\_ADC\_OFFP]
  - Offn = GP ADC OFFN REG[GP ADC OFFN]

(Store the data if the original values are needed later for the application)

- To overwrite the defaults (the settings during factory calibration) with the ADC offset values
  - GP\_ADC\_OFFP\_REG[GP\_ADC\_OFFP] = 200
  - GP\_ADC\_OFFN\_REG[GP\_ADC\_OFFN] = 200
- To enable the temperature sensor:



**Final** 

- GP ADC CTRL REG[DIE TEMP EN] = 1
- Wait 25 µs for the temperature sensor to start up
- To set the advised ADC settings:
  - o GP\_ADC\_TRIM\_REG[GP\_ADC\_LDO\_LEVEL] = 4
  - o GP\_ADC\_CTRL\_REG[GP\_ADC\_CHOP] = 1
  - GP\_ADC\_CTRL\_REG[GP\_ADC\_SE] = 1
  - GP ADC CTRL REG[GP ADC EN] = 1
  - GP\_ADC\_CTRL2\_REG[GP\_ADC\_I20U] = 1
  - o GP\_ADC\_SEL\_REG[GP\_ADC\_SEL\_P] = 4
  - o GP\_ADC\_CTRL2\_REG[GP\_ADC\_STORE\_DEL] = 0
- To set sample time and averaging of the ADC sampling
  - GP\_ADC\_CTRL2\_REG[GP\_ADC\_SMPL\_TIME] = F
  - GP\_ADC\_CTRL2\_REG[GP\_ADC\_CONV\_NRS] = 6
- To perform ADC conversion:
  - GP ADC CTRL REG[GP ADC START] = 1
- To wait for the conversion to finish, read the register
  - GP\_ADC\_RESULT\_REG[GP\_ADC\_VAL]
- To write back the original offset values
  - GP ADC OFFP REG[GP ADC OFFP] = Offp
  - GP\_ADC\_OFFN\_REG[GP\_ADC\_OFFN] = Offn

(Restore the original data if needed by the application)

### 24.2.1.2 Relative Temperature

For relative temperature measurements, the single-point calibration is not needed. The programming sequence is presented below.

- To enable GP ADC:
  - GP\_ADC\_CTRL\_REG[DIE\_TEMP\_EN] = 1
- Wait 25 µs for the temperature sensor to start up
- To set the advised ADC settings:
  - GP\_ADC\_TRIM\_REG[GP\_ADC\_LDO\_LEVEL] = 4
  - GP\_ADC\_CTRL\_REG[GP\_ADC\_CHOP] = 1
  - o GP\_ADC\_CTRL\_REG[GP\_ADC\_SE] = 1
  - GP\_ADC\_CTRL\_REG[GP\_ADC\_EN] = 1
  - GP\_ADC\_CTRL2\_REG[GP\_ADC\_I20U] = 1
  - GP\_ADC\_SEL\_REG[GP\_ADC\_SEL\_P] = 4
  - GP\_ADC\_CTRL2\_REG[GP\_ADC\_STORE\_DEL] = 0
- To set sample time and averaging of the ADC sampling
  - o GP\_ADC\_CTRL2\_REG[GP\_ADC\_SMPL\_TIME] = F
  - GP\_ADC\_CTRL2\_REG[GP\_ADC\_CONV\_NRS] = 6
- To perform ADC conversion:
  - GP\_ADC\_CTRL\_REG[GP\_ADC\_START] = 1
- To wait for the conversion to finish, read the register
  - GP\_ADC\_RESULT\_REG[GP\_ADC\_VAL]

**Final** 

# 25 Keyboard Controller

### 25.1 Introduction

The Keyboard controller can be used for debouncing the incoming GPIO signals when implementing a keyboard scanning engine. It generates an interrupt to the CPU (KEYBR\_IRQ).

In parallel, five extra interrupt lines can be triggered by a state change on up to 12 selectable GPIOs (GPIO\_IRQx).

### **Features**

- Monitors the 12 available GPIOs (6 in the WLCSP17 package and 12 in the FCGQFN24 package)
- Generates a keyboard interrupt on key press or key release
- Implements debouncing time from 0 up to 63 ms
- Supports five separate interrupt generation lines from GPIO toggling

The block diagram of the Keyboard Controller is presented in the Figure 65.



Figure 65: Keyboard Controller Block Diagram

### 25.2 Architecture

## 25.2.1 Keyboard Scanner

A HIGH-to-LOW transition on one of the GPIO inputs sets the internal signal "key\_hit" to 1, while KBRD\_IRQ\_IN\_SEL0\_REG[KBRD\_LEVEL] = 0 and KBRD\_IRQ\_IN\_SELx\_REG[KBRD\_Pyy\_EN] = 1. This signal triggers the state machine of the keyboard interface shown in Figure 66. The debounce timer is loaded with the value of GPIO\_DEBOUNCE\_REG[DEB\_VALUE]. The timer counts down every 1 ms. When the timer reaches 0 and the "key\_hit" signal is still 1, the timer is loaded with the value of KBRD\_IRQ\_IN\_SEL0\_REG[KEY\_REPEAT], generating a repeating sequence of interrupts every time when the timer reaches 0.

When the key is released (key\_hit = 0) and the bit KBRD\_REL (key release) is set to 1, a new debounce sequence is started and a KEYBR\_IRQ interrupt is generated after the debounce time.



**Final** 

The debounce timer can be disabled with GPIO\_DEBOUNCE\_REG[DEB\_ENABLE\_KBRD] = 0. The key repeat function can be disabled by setting KEY\_REPEAT to 0.

The level for generating an interrupt is programmable via bit KBRD\_IRQ\_IN\_SEL0\_REG[KBRD\_LEVEL]. The key release function can be disabled by setting bit KBRD\_IRQ\_IN\_SEL0\_REG[KBRD\_REL] to 0. The inputs for the keyboard interface can be selected by setting the corresponding bits KBRD\_IRQ\_IN\_SEL0\_REG[KBRD\_Pxx\_EN] to 1.

The keyboard interrupt service routine can distinguish which input has caused the interrupt by reading the Px\_DATA\_REG registers.



Figure 66: Keyboard Scanner State Machine

## 25.2.2 **GPIO** Interrupt Generator

Five identical GPIO interrupt generators support the generation of up to five interrupts (GPIO0\_IRQ to GPIO4\_IRQ). One of the GPIO inputs can be selected to generate an interrupt by programming the corresponding GPIO\_IRQx\_IN\_SEL\_REG register. The input level can be selected by GPIO\_INT\_LEVEL\_CTRL\_REG[INPUT\_LEVELx].

A LOW-to-HIGH level transition on one of the GPIO inputs sets the internal signal "key\_hit" to 1, while the bit INPUT\_LEVELx = 0. This signal triggers the state machine of the GPIO Interrupt Generator shown in Figure 67. The debounce timer is loaded with the value of GPIO\_DEBOUNCE\_REG[DEB\_VALUE]. The timer counts down every 1 ms. If the timer reaches 0 and the "key\_hit" signal is still 1, an interrupt will be generated. The debounce timer for each interrupt can be disabled with GPIO\_DEBOUNCE\_REG[DEB\_ENABLEx].

The interrupt flag will remain set until it is reset by writing to the corresponding bit in the GPIO\_RESET\_IRQ\_REG register. If the GPIO interrupt is edge sensitive selected with bit GPIO\_INT\_LEVEL\_CTRL\_REG[EDGE\_LEVELNx], the state machine will progress to the state WAIT\_FOR\_RELEASE when the interrupt is reset. It will progress to the IDLE state only after the non-active edge is detected.

To detect both signal edges, the edge polarity INPUT\_LEVELx must be inverted in the WAIT\_FOR\_RELEASE state. This will result in "key\_hit" = 0 and will advance the state machine to the IDLE state, allowing the next inverted edge to be detected.

**Final** 



Figure 67: GPIO Interrupt Generator State Machine

# 25.3 Programming

To configure and use the Keyboard controller, follow the steps under each subsection.

# 25.3.1 Keyboard Scanner

- 1. Enable a keyboard interrupt for the P0\_x by setting the KBRD\_IRQ\_IN\_SEL0\_REG[KBRD\_Px\_EN] bit.
- 2. Select the logic level by which the interrupt is generated (KBRD\_CTRL\_REG[KBRD\_LEVEL]).
- 3. Select whether a key release also generates an interrupt (KBRD\_CTRL\_REG[KBRD\_REL]).
- Select whether repeated interrupts will be generated when a key is held pressed (KBRD\_CTRL\_REG[KEY\_REPEAT]).
- 5. Set up the debounce time for each key stroke (GPIO\_DEBOUNCE\_REG[DEB\_VALUE]).
- 6. Enable the debounce timer (GPIO DEBOUNCE REG[DEB ENABLE KBRD]).

## 25.3.2 **GPIO** Interrupts

- Enable a GPIO interrupt for the P0\_x by setting the GPIO\_IRQx\_IN\_SEL\_REG[KBRD\_IRQ0\_SEL] bit.
- 2. Select the logic level by which the interrupt is generated (GPIO\_INT\_LEVEL\_CTRL\_REG[INPUT\_LEVELx]).
- 3. Select whether a key release is needed for an interrupt to be generated after a generated IRQ is cleared (GPIO\_INT\_LEVEL\_CTRL\_REG[EDGE\_LEVELNx]).
- 4. Set up the debounce time for GPIO trigger (GPIO\_DEBOUNCE\_REG[DEB\_VALUE]).
- 5. Enable the debounce timer for the selected IRQ (GPIO DEBOUNCE REGIDEB ENABLEX)).

**Final** 

# **26 Input/Output Ports**

### 26.1 Introduction

The DA14531 has an I/O pin assignment that can be configured by the SW and is organized into the Port 0. Pins from P0\_0 to P0\_5 are available for input/output on the WLCSP17 package, whereas the full Port 0 (P0\_0 to P0\_11) is available on the FCGQFN24 package. Figure 68 shows the block diagram of the IO and its programmability options.

## **Features**

- Six GPIOs on WLCSP17 and 12 GPIOs on FCGQFN24 (including RST, SW\_CLK, SWDIO, XTAL32Km, and XTAL32Kp)
- Fully programmable pin assignment
- Selectable 25 kΩ pull-up and pull-down resistors per pin
- Programmable driving strength outputs
- Fixed assignment for analog pin ADC[3:0]
- Pins can retain their last state when system enters a Sleep mode



Figure 68: Port P0 with Programmable Pin Assignment and Driving Strength

### 26.2 Architecture

## **26.2.1** Programmable Pin Assignment

The Programmable Pin Assignment (PPA) provides a multiplexing function to the I/O pins of on-chip peripherals. Any peripheral input or output signal can be freely mapped to any I/O port bit by setting Pxy\_MODE\_REG[4-0]:

0x00 to 0x1F: Peripheral IO ID (PID)

Refer to the registers of Px\_MODE\_REG (x = 00, 01, 02, to 11) for an overview of the available PIDs. The analog ADC has a fixed pin assignment so that the interference with the digital domain is limited. The SWD interface (JTAG) is mapped on P0\_5 (or P0\_1 or P0\_10, see Section 3) for the SWDIO and on P0\_2 for the SWCLK.

**Final** 

### **26.2.1.1** Priority

The firmware can assign the same peripheral output to more than one pin. It is the users' responsibility to make a unique assignment.

If more than one input signal is assigned to a peripheral input, the left most pin in the lowest port pin number has priority.

#### 26.2.1.2 Direction Control

The port direction is controlled by setting Pxy\_MODE\_REG[9-8] to:

- 00 = Input, no resistors selected
- 01 = Input, pull-up resistors selected
- 10 = Input, pull-down resistors selected
- 11 = Output, no resistors selected

In output mode and analog mode, the pull-up/down resistors are automatically disabled.

## 26.2.2 General Purpose Port Registers

The general-purpose ports are selected with PID = 0. The port function is accessible through registers:

- Px\_DATA\_REG: Port data input/output register
- Px\_SET\_OUTPUT\_DATA\_REG: Port set output register
- Px\_RESET\_OUTPUT\_DATA\_REG: Port reset output register

# 26.2.2.1 Port Data Register

The registers input Px\_DATA\_REG and output Px\_DATA\_REG are mapped on the same address.

The data input register (Px\_DATA\_REG) is a read-only register that returns the current state on each port pin, even if the output direction is selected, regardless of the programmed PID, unless the analog function is selected (in this case it reads 0). The Cortex CPU can read this register at any time, even when the pin is configured as an output.

The data output register (Px\_DATA\_REG) holds the data to be driven on the output port pins. In this configuration, writing to this register changes the output value.

# 26.2.2.2 Port Set Data Output Register

Writing a 1 in the set data output register (Px\_SET\_DATA\_REG) sets the corresponding output pin. Writing a 0 is ignored.

# 26.2.2.3 Port Reset Data Output Register

Writing a 1 in the reset data output register (Px\_RESET\_DATA\_REG) resets the corresponding output pin. Writing a 0 is ignored.

# 26.2.3 Fixed Assignment Functionality

Certain signals have a fixed mapping on specific general purpose IOs. This assignment is illustrated in Table 51.

## **Table 51: Fixed Assignment of Specific Signals**

| GPIO | Reset/SWD (Note 1) | QUADRATURE DECODER (Note 2) | ADC (Note 3) |
|------|--------------------|-----------------------------|--------------|
| P0_0 | RST                | CH6_A                       |              |

**Final** 

| GPIO  | Reset/SWD (Note 1)  | QUADRATURE DECODER (Note 2) | ADC (Note 3) |
|-------|---------------------|-----------------------------|--------------|
| P0_1  | SWDIO (alternative) | CH1_A                       | ADC_0        |
| P0_2  | SWCLK               | CH1_B                       | ADC_1        |
| P0_3  |                     | CH2_A                       |              |
| P0_4  |                     | CH2_B                       |              |
| P0_5  | SWDIO               | CH3_A                       |              |
| P0_6  |                     | CH3_B                       | ADC_2        |
| P0_7  |                     | CH4_A                       | ADC_3        |
| P0_8  |                     | CH6_B                       |              |
| P0_9  |                     | CH5_A                       |              |
| P0_10 | SWDIO (alternative) | CH5_B                       |              |
| P0_11 |                     | CH4_B                       |              |

- Note 1 The SWD signal mapping is defined by SYS\_CTRL\_REG[DEBUGGER\_ENABLE]. However, these signals are mapped on the ports by default. The alternative SWD mapping is selected by the SYS\_CTRL\_REG[DEBUGGER\_ENABLE] bit field. The RST default functionality can be disable by the HWR\_CTRL\_REG[DISABLE\_HWR] bit.
- **Note 2** The mapping of the quadrature decoder signals on the respective pins is overruled by the QDEC\_CTRL2\_REG[CHx\_PORT\_SEL] register.
- Note 3 The ADC function can be selected by the PID bit field on the respective Px port.

### 26.2.4 Types of GPIO Pads

There are two different types for the GPIO pads, namely, type A and type B. Their block diagrams are presented in Figure 69 and Figure 70.



Figure 69: Type A GPIO Pad - GPIO with Schmitt Trigger on Input

**Final** 



Figure 70: Type B GPIO Pad - GPIO with Schmitt Trigger and RC Filter on Input

Red signals are latched when the system enters a Sleep mode.

# 26.2.5 Driving Strength

Pads can be configured regarding their driving capability using PAD\_WEAK\_CTRL\_REG. There are only 2 levels available for the load that the pad can support, namely normal = 3.5 mA typical, and reduced = 0.35 mA typical.

**Final** 

## 27 General Purpose ADC

### 27.1 Introduction

The DA14531 is equipped with a high-speed ultra-low-power 10-bit general purpose Analog-to-Digital Converter (GPADC). It can operate in unipolar (single ended) mode as well as in bipolar (differential) mode. The ADC has its own voltage regulator (LDO) of 0.9 V, which represents the full-scale reference voltage. Figure 71 shows the block diagram of the GPADC.

#### **Features**

- 10-bit dynamic ADC with 125 ns typical conversion time
- Maximum sampling rate 1 Msample/s
- 128× averaging; conversion time 1 ms, up to 11b ENOB
- Ultra-low power (20 µA typical supply current at 100 ksample/s)
- Four single-ended or two differential external input channels (GPIOs)
- Battery, DCDC outputs, and the internal V<sub>DD</sub> monitoring channels
- Chopper function
- Offset adjust
- Common-mode input level adjust
- Configurable attenuator: 1×, 2×, 3× and 4×
- Input shifter



Figure 71: Block Diagram of GPADC

**Final** 

#### 27.2 Architecture

The ADC architecture shown in Figure 71 has the following sub-blocks:

- Analog to Digital converter (ADC)
  - ADC analog part internally clocked with 100 MHz
  - ADC logic part clocked with the ADC\_CLK which is the 16 MHz system clock (sys\_clk)
- 0.9 V LDO for the ADC supply with a high PSRR enabled with GP\_ADC\_CTRL\_REG[GP\_ADC\_EN]
- Configurable attenuator with 1×, 2×, 3×, and 4× attenuation controlled by GP\_ADC\_CTRL2\_REG[GP\_ADC\_ATTN]
- Input shifter which shifts the battery voltage range from 0.85 V to 1.75 V (with a common mode adjustment) to the ADC input range from 0 V to 0.9 V controlled by GP\_ADC\_CTRL2\_REG[GP\_ADC\_OFFS\_SH\_EN] and GP\_ADC\_CTRL2\_REG[GP\_ADC\_OFFS\_CM]
- APB Bus interface clocked with the APB clock. Control and status registers are available through registers GP\_ADC\_\*
- Maskable Interrupt (ADC\_IRQ) and DMA request (ADC\_DMA\_REQ)
- ADC input channel selector. Up to four GPIO ports, the battery and DCDC output (VBAT\_HIGH and VBAT\_LOW), the internal VDD, and the analog ground level (AVS) can be measured.

### 27.2.1 Input Channels

Table 52 summarizes the ADC input channels. The GPIO signals at the channels [3:0] can be monitored both single-ended and differentially. The signals at the 4-7 inputs can be monitored single-ended or differentially with respect to the GPIOs.

**Table 52: ADC Input Channels** 

| Channel | Signal                         | Description                                       |
|---------|--------------------------------|---------------------------------------------------|
| 3:0     | GPIO [P0_1, P0_,2, P0_6, P0_7] | General Purpose Inputs                            |
| 4       | Temperature Sensor             | Temperature Sensor                                |
| 5       | V <sub>BAT_</sub> HIGH         | V <sub>BAT_HIGH</sub> rail                        |
| 6       | V <sub>BAT_LOW</sub>           | V <sub>BAT_LOW</sub> rail                         |
| 7       | V <sub>DD</sub>                | V <sub>DD</sub> rail for the digital power domain |

Table 53 summarizes the voltage ranges which can be handled with the single-ended or differential operation for different attenuation values. The single-ended/differential mode is controlled by the bit GP\_ADC\_CTRL\_REG[GP\_ADC\_SE], and the attenuation is handled by the bit GP\_ADC\_CTRL2\_REG[GP\_ADC\_ATTN].

Table 53: GPADC External Input Channels and Voltage Range

| GP_ADC_ATTN | GP_ADC_SE | Input Scale      | Input Limits     |
|-------------|-----------|------------------|------------------|
| 0 (4)       | 0         | -0.9 V to +0.9 V | -1 V to +1 V     |
| 0 (1 ×)     | 1         | 0 V to +0.9 V    | -0.1 V to 1V     |
| 1 (2 ×)     | 0         | -1.8 V to +1.8 V | -1.9 V to +1.9 V |
|             | 1         | 0 V to +1.8 V    | -0.1 V to 1.9 V  |
| 2 (3 ×)     | 0         | -2.7 V to +2.7 V | -2.8 V to +2.8 V |
|             | 1         | 0 V to +2.7 V    | -0.1 V to 2.8 V  |



Final

| GP_ADC_ATTN | GP_ADC_SE | Input Scale      | Input Limits       |
|-------------|-----------|------------------|--------------------|
| 3 (4 ×)     | 0         | -3.6 V to +3.6 V | -3.45 V to +3.45 V |
|             | 1         | 0 V to +3.6 V    | -0.1 V to 3.45 V   |

# 27.2.2 Operating Modes

The GPADC operation flow diagram is shown in Figure 72.

**Final** 



Figure 72: GPADC Operation Flow Diagram

## 27.2.2.1 Enabling the ADC

Enabling/disabling of the ADC is triggered by configuring bit GP\_ADC\_CTRL\_REG[GP\_ADC\_EN]. When the bit is set to 1, first the LDO is enabled. Then after the delay value set in



**Final** 

GP\_ADC\_CTRL3\_REG[GP\_ADC\_EN\_DEL] (typically 16 µs to account for the LDO settling time), the ADC will be enabled, and an AD conversion can be started. See Table 54 for recommended values.

Table 54: ADC\_LDO Start-Up Delay

| fadc_clk | GP_ADC_EN_DEL | TADC_EN_DEL |
|----------|---------------|-------------|
| 16 MHz   | 0x40          | 16 µs       |

#### Formula:

GP\_ADC\_EN\_DEL = TADC\_EN\_DEL × fADC\_CLK / 4

This value must be rounded up to the nearest integer.

The GPADC is a dynamic ADC and consumes no static power, except for the **ADC\_LDO** which consumes approximately 20 µA. Therefore, GP ADC EN must be set to 0 if the ADC is not used.

#### 27.2.2.2 Manual Mode

An AD conversion can be started by setting GP\_ADC\_START to 1. While a conversion is active, GP\_ADC\_START remains 1. When a conversion is finished, the hardware sets GP\_ADC\_START to 0 and GP\_ADC\_INT to 1 (interrupt), and GP\_ADC\_RESULT\_REG contains the valid ADC value. While a conversion is active, writing 1 to GP\_ADC\_START will not start a new conversion. SW should always check that bit GP\_ADC\_START = 0 before starting a new conversion.

#### 27.2.2.3 Continuous Mode

Setting GP\_ADC\_CTRL\_REG[GP\_ADC\_CONT] to 1 enables the continuous mode, which automatically starts a new AD conversion when the current conversion has been completed. The GP\_ADC\_START bit is only needed once to trigger the first conversion. As long as the continuous mode is active, GP\_ADC\_RESULT\_REG always contains the latest ADC value.

To correctly terminate the continuous mode, it is required to disable the GP\_ADC\_CONT bit first and then wait until the GP\_ADC\_START bit is cleared to 0, so the ADC is in a defined state.

#### NOTE

Before making any changes to the ADC settings, users must disable the continuous mode by setting bit GP\_ADC\_CONT to 0 and waiting until bit GP\_ADC\_START = 0.

At full speed the ADC consumes approximately 50 to 60  $\mu$ A. If the data rate is less than 100 ksample/s, the current consumption will be in the order of 25  $\mu$ A.

The time interval between two successive AD conversions is programmable with GP\_ADC\_CTRL3\_REG[GP\_ADC\_INTERVAL] in steps of 1.024 ms. If GP\_ADC\_INTERVAL = 0, the conversion will restart immediately. If GP\_ADC\_INTERVAL is not zero, the ADC first synchronizes to the delay clock before starting the conversion. This can take up to 1 ms.

### 27.2.3 Conversion Modes

### 27.2.3.1 AD Conversion

Each AD conversion has three phases:

- Sampling
- Conversion
- Storage

The AD conversion starts with the sampling phase. This phase ends after the time set in GP\_ADC\_CTRL2\_REG[GP\_ADC\_SMPL\_TIME] and triggers the conversion phase. If GP\_ADC\_CTRL2\_REG[GP\_ADC\_STORE\_DEL] = 0, handshaking is used, that is, the ADC result is



**Final** 

stored when a conversion is finished. Otherwise, a fixed (programmable) delay is used, and the result is stored regardless of whether the conversion is finished or not.

The total conversion time of an AD conversion depends on various settings. In short, it is as follows.

$$T_{ADC} = \frac{N_{CONV} \cdot \left(N_{CYCL\_SMPL} + N_{CYLC\_STORE}\right)}{f_{ADC\ CLK}}$$
(5)

#### Where

- NCONV = the number of conversions. This is related to the value programmed in GP\_ADC\_CTRL2\_REG[GP\_ADC\_CONV\_NRS], following 2GP\_ADC\_CONV\_NRS. When GP\_ADC\_CTRL\_REG[GP\_ADC\_CHOP] is set, the minimum value for NCONV is always 2.
- NCYLC\_SMPL = the number of ADC\_CLK cycles used for sampling, which is 8 × GP\_ADC\_CTRL2\_REG[GP\_ADC\_SMPL\_TIME].
- NCYCL\_STORE = the number of ADC\_CLK cycles until the result is stored. When GP\_ADC\_CTRL2\_REG[GP\_ADC\_STORE\_DEL] = 0, handshaking is used. With handshaking, the number of ADC\_CLK cycles is typically three. This value may spread from sample to sample and over temperature, otherwise the number of ADC\_CLK cycles is GP\_ADC\_CTRL2\_REG[GP\_ADC\_STORE\_DEL] + 1.

### **Sampling Phase**

The sampling time can be programmed via GP\_ADC\_CTRL2\_REG[GP\_ADC\_SMPL\_TIME] and depends on the sampling time constant in combination with the desired sampling accuracy. This sampling time constant, TADC\_SMPL (Table 55), then depends on the output impedance of the source, the internal resistive dividers, and the internal sampling capacitor. And the number of required time constants is given by the natural logarithm of the desired accuracy, that is, In(2^NBIT). For NBIT = 10-bit accuracy, 7-time constants are required.

Table 55: ADC Sampling Time Constant (TADC\_SMPL)

| ADC Input                        | TADC_SMPL                                                                                                                                                  |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPADC0, GPADC1 (GP_ADC_ATTN = 0) | R <sub>OUT</sub> × 0.5 pF (Differential Input)<br>R <sub>OUT</sub> × 1 pF (Single-Ended Input)                                                             |
| GPADC0, GPADC1 (GP_ADC_ATTN = 1) | $(R_{OUT} + 120 \text{ k}\Omega) \times 0.5 \text{ pF (Differential Input)}$<br>$(R_{OUT} + 120 \text{ k}\Omega) \times 1 \text{ pF (Single-Ended Input)}$ |

### Formula:

GP ADC SMPL TIME = In(2^NBIT) × TADC SMPL × fADC CLK / 8

This value must be rounded up to the nearest integer.

## **Conversion and Storage Phase**

One AD conversion typically takes around 125 ns with a 100 MHz clock. The result can be stored either by handshaking or after a fixed number of cycles (programmable).

• Handshake mode (GP ADC STORE DEL = 0):

In handshake mode the conversion result is available in GP\_ADC\_RESULT\_REG after two sampling ADC\_CLK cycles plus two conversion ADC\_CLK cycles plus two ADC\_CLK cycles for synchronization.

Fixed delay mode (GP\_ADC\_STORE\_DEL > 0):

In fixed delay mode the conversion result is available in GP\_ADC\_RESULT\_REG after the programmed storage delay, regardless of whether the conversion is ready or not. Note that when the delay is too short (that is, the conversion is not finished in the allocated time), the old (previous) ADC result is stored.

**Final** 

#### 27.2.3.2 Averaging

In order to reduce noise and improve performance, multiple samples can be averaged out (assuming the time average of noise equals zero). This is handled by HW and can be controlled by setting GP\_ADC\_CTRL2\_REG[GP\_ADC\_CONV\_NRS] to a non-zero value. The actual number of the consecutive samples taken is by  $2^{\text{GP\_ADC\_CONV\_NRS}}$ .

Because the internal noise also acts as a form of dither, the actual accuracy can be improved. Therefore, the ADC result is not truncated to 10-bit but stored as 16-bit left aligned, and truncation is left for the user. The expected Effective Number of Bits (ENOB) is shown in Table 56.

Table 56: ENOB in Oversampling Mode

| GP_ADC_CONV_NRS | ENOB (Left Aligned) in GP_ADC_RESULT_REG |
|-----------------|------------------------------------------|
| 0               | > 9                                      |
| 1               | > 9                                      |
| 2               | > 9                                      |
| 3               | > 10                                     |
| 4               | > 10                                     |
| 5               | > 10                                     |
| 6               | > 11                                     |
| 7               | > 11                                     |

### 27.2.3.3 Chopper Mode

Inherently, the ADC has a DC offset (EOFS). When GP\_ADC\_CTRL\_REG[GP\_ADC\_CHOP] is set to 1, the hardware triggers two consecutive AD conversions and flips the sign of the offset inbetween. Summing the two samples effectively cancels out the inherent ADC offset. This method also smooths other non-ideal effects and is recommended for DC and the slowly changing signals.

When combined with averaging, every other AD conversion is taken with opposite sign. Without averaging two AD conversions are always triggered.

Note that a DC offset causes saturation effects at zero scale or full scale. When chopping is used without offset calibration, non-linear behavior is introduced towards zero scale and full scale.

#### 27.2.4 Additional Settings

The hardware also supports pre-ADC attenuation via GP ADC CTRL2 REGIGP ADC ATTNI:

- Setting 0 disables the attenuator
- Setting 1 scales the input range by a factor of two
- Setting 2 scales the input range by a factor of three
- Setting 3 scales the input range by a factor of four

With bit  $GP\_ADC\_CTRL\_REG[GP\_ADC\_MUTE] = 1$ , the input is connected to  $0.5 \times ADC$  reference. So, the ideal ADC result should be 511.5. Any deviation from this is the ADC offset.

With bit GP\_ADC\_CTRL\_REG[GP\_ADC\_SIGN] = 1, the sign of the offset is inverted. When chopper is used, the hardware alternates GP\_ADC\_SIGN = 0 and 1. This bit is typically only used for the offset calibration routine described in Section 27.2.6 and has no specific use to the end user.

### 27.2.5 Non-Ideal Effects

Besides Differential Non-Linearity (DNL) and Integral Non-Linearity (INL), each ADC has a gain error (linear) and an offset error (linear). The gain error (E<sub>G</sub>) of the GPADC affects the effective input



**Final** 

range. The offset error (E<sub>OFS</sub>) causes the effective input scale to become non-centered. The offset error can be reduced by chopping and/or by offset calibration.

The ADC result will also include some noise. If the input signal itself is noise free (inductive effects included), the average noise level will be ±1 LSB. Reducing noise effects can be done by taking more samples and calculating the average value. This can be done by programming GP\_ADC\_CTRL2\_REG[GP\_ADC\_CONV\_NRS] to a non-zero value.

With a "perfect" input signal (for example, if a filter capacitor is placed close to the input pin), most of the noise comes from the low-power voltage regulator (LDO) of the ADC. Since the DA14531 is targeted for ultra-compact applications, there is no pin available to add a capacitor at this voltage regulator output.

The dynamic current of the ADC causes extra noise at the regulator output. This noise can be reduced by setting bits GP\_ADC\_CTRL2\_REG[GP\_ADC\_I20U]. Bit GP\_ADC\_I20U enables a constant 20  $\mu$ A load current at the regulator output so that the current will not drop to zero. This, obviously, increases power consumption by 20  $\mu$ A.

#### 27.2.6 Offset Calibration

A relative high offset error (E<sub>OFS</sub>, up to 30 mV, so approximately 30 LSB) is caused by a very small dynamic comparator. This offset error can be cancelled with the chopping function, but it still causes unwanted saturation effects at zero scale or full scale. With GP\_ADC\_OFFP\_REG and GP\_ADC\_OFFN\_REG, the offset error can be compensated in the ADC network itself. To calibrate the ADC, follow the steps in Table 57. In this routine, 0x200 is the target mid-scale of the ADC.

Table 57: GPADC Calibration Procedure for Single-Ended and Differential Modes

| Step | Single-Ended Mode (GP_ADC_SE = 1)                                               | Differential Mode (GP_ADC_SE = 0)                                               |
|------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| 1    | Set GP_ADC_OFFP = GP_ADC_OFFN = 0x200;<br>GP_ADC_MUTE = 0x1; GP_ADC_SIGN = 0x0. | Set GP_ADC_OFFP = GP_ADC_OFFN = 0x200;<br>GP_ADC_MUTE = 0x1; GP_ADC_SIGN = 0x0. |
| 2    | Start conversion.                                                               | Start conversion.                                                               |
| 3    | adc_off_p = GP_ADC_RESULT - 0x200                                               | adc_off_p = GP_ADC_RESULT - 0x200                                               |
| 4    | Set GP_ADC_SIGN = 0x1.                                                          | Set GP_ADC_SIGN = 0x1.                                                          |
| 5    | Start conversion.                                                               | Start conversion.                                                               |
| 6    | adc_off_n = GP_ADC_RESULT - 0x200                                               | adc_off_n = GP_ADC_RESULT - 0x200                                               |
| 7    | GP_ADC_OFFP = 0x200 - 2 × adc_off_p<br>GP_ADC_OFFN = 0x200 - 2 × adc_off_n      | GP_ADC_OFFP = 0x200 - adc_off_p<br>GP_ADC_OFFN = 0x200 - adc_off_n              |

To increase the accuracy, it is recommended to set the GP\_ADC\_CTRL2\_REG[GP\_ADC\_SMPL\_TIME] = 2 or 3 and GP\_ADC\_CTRL2\_REG[GP\_ADC\_CONV\_NRS] = 3 or 4 prior to this routine.

It is recommended to implement the above calibration routine during the initialization phase of DA14531. To verify the calibration results, check whether the GP\_ADC\_RESULT value is close to 0x200 while bit GP\_ADC\_CTRL\_REG[GP\_ADC\_MUTE] = 1.

### 27.2.7 Zero-Scale Adjustment

The GP\_ADC\_OFFP and GP\_ADC\_OFFN registers can also be used to set the zero-scale or full-scale input level at a certain target value. For instance, they can be used to calibrate GP\_ADC\_RESULT to 0x000 at an input voltage of exactly 0.0 V, or to calibrate the zero scale of a sensor.

**Final** 

### 27.2.8 Common Mode Adjustment

The common mode level of the differential signal must be 0.45 V = Full Scale/2 (or 1.35 V with GP\_ADC\_ATTN = 2, that is,  $3\times$  attenuation). If the common mode input level of 0.45 V cannot be achieved, the common mode level of the GPADC can be adjusted via GP\_ADC\_OFFP\_REG and GP\_ADC\_OFFN\_REG according to Table 58. The GPADC can tolerate a common mode margin of up to 50 mV.

**Table 58: Common Mode Adjustment** 

| CM Voltage (Vccm) | GP_ADC_OFFP = GP_ADC_OFFN |
|-------------------|---------------------------|
| 0.225 V           | 0x300                     |
| 0.450 V           | 0x200                     |
| 0.675 V           | 0x100                     |

Any other common mode levels between 0.0 V and 0.9 V can be calculated from Table 58. Offset calibration can be combined with common mode adjustment by replacing the 0x200 value in the offset calibration routine with the value required to get the appropriate common mode level.

### 27.2.9 Input Impedance, Inductance, and Input Settling

The GPADC has no input buffer stage. During the sampling phase, a capacitor of 0.5 pF in differential mode or 1 pF in single-ended mode is switched to the input line(s). The pre-charge of this capacitor is at midscale level, so the input impedance is infinite.

During the sampling phase, a certain settling time is required. A 10-bit accuracy requires at least seven-time constants TADC\_SMPL, determined by the output impedance of the input signal source, the internal resistive dividers, and the 0.5 pF or 1 pF sampling capacitor. See Table 55.

The inductance from the signal source to the ADC input pin must be very small. Otherwise filter capacitors are required from the input pins to ground (single-ended mode) or from pin to pin (differential mode).

## 27.3 Programming

To program and use the GPADC, follow the simple sequence of steps below:

- 1. Enable the GPADC by setting the GP ADC CTRL REG[GP ADC EN] bit.
- 2. Set up the GPIO input (P0\_x\_MODE\_REG[PID] = 15).
- 3. Select the input channel (GP\_ADC\_SEL\_REG).
- 4. Select the sampling mode (differential or single ended) by writing the GP\_ADC\_CTRL\_REG[GP\_ADC\_SE] bit.
- Select between the manual mode and the continuous mode of sampling (GP ADC CTRL REG[GP ADC CONT].
- 6. Set up extra options (see GP ADC CTRLx REG description)
- 7. Start the conversion by setting GP\_ADC\_CTRL\_REG[GP\_ADC\_START] bit.
- 8. Wait for GP\_ADC\_CTRL\_REG[GP\_ADC\_START] to become 0 or interrupt being triggered (when used).
- 9. Clear the ADC interrupt by writing any value to GP\_ADC\_CLEAR\_INT\_REG.
- 10. Get the ADC result from the GP\_ADC\_RESULT\_REG.

**Final** 

## 28 Real Time Clock (RTC)

#### 28.1 Introduction

The DA14531 is equipped with a Real Time Clock (RTC) which provides the complete clock and calendar information with automatic time units adjustment and easy configuration.

#### **Features**

- Complete time of day clock: 12/24 hour, hours, minutes, seconds, and hundredths of a second
- Calendar function: day of week, date of month, month, year, century, leap year compensation, and year 2000 compliant
- Alarm function: month, date, hour, minute, second, and hundredths of a second
- Event interrupt on any calendar or time unit
- Available during sleep if the power domain PD\_TIM is kept alive
- Granularity of 10 ms (RTC\_CLK)
- Provides 22 LSB to Timer 1 upon a capture trigger



Figure 73: Real Time Clock Block Diagram

### 28.2 Architecture

The architecture of the RTC is depicted in Figure 73.

The RTC supports a year range from 1900 to 2999 as well as full month, date, minute, second, and hundredth of second ranges. It also supports hour ranges of 0 to 23 (24-hour format) or 1 to 12 with a.m./p.m. flag (12-hour format).

Alarms can be generated in two ways, as a one-time alarm or as a recurring alarm. In addition to alarms, the RTC can detect when a particular event occurs. Each field of the calendar and time counter can generate an event when it rolls over. For example, an event can be generated every new month, new week, new day, new half day (12-hour mode), new minute, or new second. Both alarms



**Final** 

and events can generate an interrupt. All the interrupts can be set, enabled, disabled, or masked at any time.

The LSB (22) of the port showing a full of 32-bit information on the current time is latched by Timer 1 (TIMER1\_CAPCNT1/2\_VALUE\_REG) if instructed by Timer 1 configuration. This allows for storing an RTC based snapshot upon an event on a GPIO.

## 28.3 Programming

To configure the RTC, follow the simple sequence of steps below:

- 1. Configure the 100 Hz RTC granularity if needed:
  - a. Based on the selected LP clock (for example, 32768 kHz), set the CLK\_RTCDIV\_REG[RTC\_DIV\_INT] = 327 (= 0x147). This values should be equal to the integer divisor part of the formula  $F_{LP\_CLK}/100 = 327.680$ .
  - b. Based on the selected LP clock (for example, 32768 kHz), set the CLK\_RTCDIV\_REG[RTC\_DIV\_FRAC] = 680 (= 0x2A8). This values should be equal to the fractional divisor part of the formula FLP CLK/100 = 327.680.
  - c. To achieve a better accuracy of the divisor, configure the denominator for the fractional division accordingly (CLK\_RTCDIV\_REG[RTC\_DIV\_DENOM]).
  - d. Enable the 100 Hz RTC granularity by setting the CLK\_RTCDIV\_REG [RTC\_DIV\_ENABLE] bit.
- 2. Enable the time functionality by clearing the RTC\_CONTROL\_REG[RTC\_TIME\_DISABLE].
- 3. Enable the calendar functionality by clearing the RTC\_CONTROL\_REG[RTC\_CAL\_DISABLE].
- 4. Choose between 12-hour or 24-hour mode (RTC\_HOUR\_MODE\_REG[RTC\_HMS]).
- 5. Configure the time (RTC\_TIME\_REG).
- 6. Configure the date (RTC\_CALENDAR\_REG).
- 7. Set up a time alarm if needed (RTC\_ALARM\_ENABLE\_REG).
- 8. Set up a calendar alarm if needed (RTC\_CALENDAR\_ALARM\_REG).
- 9. Enable the configured alarms (RTC ALARM ENABLE REG[RTC ALARM xxxx EN]).
- 10. Configure the interrupt generation when an alarm happens (RTC\_INTERRUPT\_ENABLE\_REG). Disable the interrupt generation with RTC\_INTERRUPT\_DISABLE\_REG.
- 11. Configure the event flag generation when an alarm happens (RTC EVENT FLAGS REG).
- 12. Define whether a SW reset resets the RTC (RTC\_KEEP\_RTC\_REG[RTC\_KEEP]).

**Final** 

### 29 Power

As discussed in Section 4.2, the integrated power management unit (PMU) comprises the DCDC converter and various LDOs, the V<sub>DD</sub> Clamp, and the POR circuitry. The details of these blocks are discussed in the following sections.

### 29.1 DCDC Converter

The DA14531 can be configured in three configurations: buck, boost, and DCDC bypass. The integrated part of the DCDC is the same for all three configurations, that is, the black building blocks in Figure 74 and Figure 75. The buck configuration and the boost configuration are configured on the PCB, distinguished with the red external components in Figure 74 and Figure 75, respectively. In the bypass configuration the  $V_{BAT\_HIGH}$  and  $V_{BAT\_LOW}$  rails are connected, so the DCDC is bypassed.



Figure 74: DCDC Block Diagram - Buck Configuration



Figure 75: DCDC Block Diagram - Boost Configuration

- In buck configuration the battery is connected to V<sub>BAT\_HIGH</sub>, and DCDC supplies power to V<sub>BAT\_LOW</sub> rail
- In boost configuration the battery is connected to V<sub>BAT\_LOW</sub>, and DCDC supplies power to V<sub>BAT\_HIGH</sub> rail
- In DCDC bypass configuration V<sub>BAT\_HIGH</sub> is connected to V<sub>BAT\_LOW</sub> and the battery is connected to both rails



**Final** 

The DCDC level can be programmed by POWER\_LEVEL\_REG[DCDC\_LEVEL] and a fine trimming is available by POWER\_LEVEL\_REG[DCDC\_TRIM].

When the system is allowed to go to sleep, the HW FSM is activated and the DCDC controller is automatically turned off. Upon a wakeup, the DCDC will be enabled by programming DCDC\_CTRL\_REG[DCDC\_ENABLE]. If DCDC\_ENABLE is kept set before the system goes to sleep, the DCDC will be started by the HW FSM while waking up. If DCDC\_ENABLE is reset before the system goes to sleep, the DCDC can only be started by SW setting this bit after wakeup.

For Buck configuration, a typical DCDC efficiency at 25 °C as a function of the load current for different battery voltages (V<sub>BAT</sub> = V<sub>BAT</sub> HIGH) is shown in Figure 76.



Figure 76: DCDC Efficiency in Buck Configuration

For Boost configuration, a typical DCDC efficiency at 25 °C as a function of the load current for different battery voltages (VBAT = VBAT\_LOW) is shown in Figure 77.

**Final** 



Figure 77: DCDC Efficiency in Boost Configuration

#### 29.2 LDOs

Several LDOs are used in the DA14531 to provide a stable power supply to the rails and the building blocks.

- V<sub>DD</sub>\_Clamp generates a trimmable ~0.75 V V<sub>DD</sub> supply voltage for the AON (always on) DCORE power domain from V<sub>BAT</sub>\_HIGH or V<sub>BAT</sub>\_Low when the system is in the hibernation mode
- LDO\_LOW provides power to the V<sub>BAT\_LOW</sub> rail in the buck configuration with a typical output voltage of 1.1 V. This LDO is used during start-up and can also be used after start-up.
   Alternatively, it can be disabled and the V<sub>BAT\_LOW</sub> rail can be supplied by the DCDC converter. The LDO has a low power setting which is used to maintain the V<sub>BAT\_LOW</sub> rail during sleep mode. See Section 4.2.3 for more details.
- LDO\_CORE supplies the internal V<sub>DD</sub> from V<sub>BAT\_LOW</sub>. In the active mode it generates 0.9 V and in the sleep mode 0.75 V
- LDOs for the RF and the analog building blocks generate 0.9 V when the particular blocks are active. When the blocks are switched off, the LDOs are disabled.

### 29.3 POR Circuit

The POR\_LOW circuit issues a POR when the VBAT\_LOW voltage is below the threshold voltage  $V_{IL}$  for more than 50  $\mu$ s. The POR is cleared when the battery voltage is above  $V_{IH}$  for at least 25  $\mu$ s. The threshold levels of the POR circuit are summarized in Section 3.12.

The POR\_HIGH circuit issues a POR when the VBAT\_HIGH voltage is below the  $V_{IL}$  for more than 50  $\mu$ s. The POR is cleared when the battery voltage is above  $V_{IH}$  for at least 25  $\mu$ s. The threshold levels of the POR circuit are summarized in Section 3.12.

**Final** 

## 30 Bluetooth® LE Core

The Bluetooth® Low Energy (BLE) core used in the DA14531 is a qualified Bluetooth® 5.1 baseband controller compatible with the Bluetooth® LE specification and it is in charge of packet encoding/decoding and frame scheduling.

The block diagram of Bluetooth® LE core is presented in Figure 78.

#### **Features**

- Compliant with Bluetooth<sup>®</sup> Core Specification, v5.1, Bluetooth<sup>®</sup> SIG
  - Dual topology
  - Low duty cycle advertising
  - L2CAP connection-oriented channels
- All device classes support (Broadcaster, Central, Observer, and Peripheral)
- All packet types (Advertising, Data, and Control)
- Dedicated Encryption (AES/CCM)
- Bit stream processing (CRC and Whitening)
- FDMA/TDMA/events formatting and synchronization
- Frequency hopping calculation
- Operating clock 16 MHz or 8 MHz
- Low power modes supporting 32.0 kHz, 32.768 kHz, or 15 kHz
- Supports powerdown of the baseband during the protocol's idle periods



Figure 78: Bluetooth® LE Core Block Diagram

### 30.1 Architecture

### 30.1.1 Exchange Memory

The Bluetooth®LE Core requires access to a memory space named "Exchange Memory" to store control structures and frame buffers. The access to Exchange Memory is performed via the AHB Master interface. The base address of the Exchange Memory is programmable by means of the BLE\_EM\_BASE register.

**Final** 

## 30.2 Programming

### 30.2.1 Wake-Up IRQ

Once the Bluetooth® LE core switches to "BLE Deep Sleep mode", the only way to correctly exit from this state is by generating initially the BLE\_WAKEUP\_LP\_IRQ and consecutively the BLE\_SLP\_IRQ. This sequence must be followed regardless of the cause of the termination of the "BLE Deep Sleep mode", that is, regardless of whether the BLE Timer has expired or BLE Timer has been stopped due to the assertion of BLE WAKEUP REQ.

The assertion and de-assertion of BLE\_WAKEUP\_LP\_IRQ is fully controlled via the BLE\_ENBPRESET\_REG bit fields. A detailed description is as follows:

- TWIRQ\_SET: it defines the number of "ble\_lp\_clk" cycles before the expiration of the Bluetooth® LE Timer when the BLE\_WAKEUP\_LP\_IRQ must be asserted. It is recommended to select a TWIRQ\_SET value larger than the amount of time that is required to finish trimming the XTAL 32 MHz (refer to XTAL32M\_TRIM\_READY) plus the execution time of the IRQ Handler. If the programmed value of TWIRQ\_SET is less than the minimum recommended value, the system will wake up but the actual BLE sleep duration (refer to BLE\_DEEPSLSTAT\_REG) will be larger than the programmed sleep duration (refer to BLE\_DEEPSLWKUP\_REG)
- TWIRQ\_RESET: it defines the number of "ble\_lp\_clk" cycles before the expiration of the sleep period when the BLE\_WAKEUP\_LP\_IRQ will be de-asserted. It is recommended to always set its value to "1"
- TWEXT: it determines the high period of BLE\_WAKEUP\_LP\_IRQ, if an external wake-up event (refer to GP\_CONTROL\_REG[BLE\_WAKEUP\_REQ]) occurs. Its minimum value is "TWIRQ\_RESET + X", where X is the number of "ble\_lp\_clk" clock cycles that BLE\_WAKEUP\_LP\_IRQ will be held high. The recommended value is "TWIRQ\_RESET + 1". Note that as soon as GP\_CONTROL\_REG[BLE\_WAKEUP\_REQ] is set to "1", the BLE\_WAKEUP\_LP\_IRQ will be asserted
- Minimum Bluetooth® LE Sleep Duration: The minimum value of BLE\_DEEPSLWKUP\_REG[DEEPSLTIME] bit, measured in "ble\_lp\_clk" cycles, is the higher value between (a) "TWIRQ\_SET + 1" and (b) the SW execution time from setting BLE\_DEEPSLCNTL\_REG[DEEP\_SLEEP\_ON] up to preparing CPU to accept the BLE\_WAKEUP\_LP\_IRQ (for example, to call the Cortex instruction WFI). If the programmed DEEPSLTIME is less than the minimum value of BLE\_DEEPSLWKUP\_REG[DEEPSLTIME], the BLE\_WAKEUP\_LP\_IRQ Handler may execute sooner than the call of the Cortex WFI instruction in the example and cause SW instability

### 30.2.2 Switch from Bluetooth® LE Active Mode to Bluetooth® LE Deep Sleep Mode

Software can set the Bluetooth® LE core into the "BLE Deep Sleep mode" by first programming the timing of BLE\_WAKEUP\_LP\_IRQ generation, then programming the desired sleep duration at BLE\_DEEPSLWKUP\_REG, and finally set the register bit BLE\_DEEPSLCNTL\_REG[DEEP\_SLEEP\_ON].

During the "BLE Deep Sleep mode", the BLE Core will switch to the "ble\_lp\_clk" (15 kHz, 32.0 kHz, or 32.768 kHz) in order to maintain its internal 625 µs timing reference. SW must poll the state of BLE\_CNTL2\_REG[RADIO\_PWRDN\_ALLOW] to detect the completion of this mode transition. Once the "ble\_lp\_clk" is used for base time reference, SW must disable the Bluetooth® LE clocks ("ble\_master1\_clk", "ble\_master2\_clk", and "ble\_crypt\_clk") by setting the CLK\_RADIO\_REG[BLE\_ENABLE] register bit to "0".

Finally, SW can optionally power down the Radio Subsystem by using the PMU\_CTRL\_REG[RADIO\_SLEEP] and the Peripheral and System power domains as well.

Figure 79 presents the waveforms when the Bluetooth® LE Deep Sleep mode is entered. In this case, as soon as the SW detects that RADIO\_PWRDOWN\_ALLOW is "1", it sets the PMU\_CTRL\_REG[RADIO\_SLEEP] to power down the Radio Subsystem. In Figure 79, Figure 80, Figure 81, Figure 82, and Figure 83, the corresponding Bluetooth® LE Core signals are marked with

**Final** 

red while Radio Subsystem is in power-down state and they remain red-marked during the period when RADIO\_SLEEP is set.



Figure 79: Entering Bluetooth® LE Deep Sleep mode

### 30.2.3 Switch from Bluetooth® LE Deep Sleep Mode to Bluetooth® LE Active Mode

There are two possibilities for the Bluetooth® LE Core to terminate the Bluetooth® LE Deep Sleep mode:

- Termination at the end of a predetermined time
- Termination on SW wake-up request due to an external event

### 30.2.3.1 Switching at an Anchor Point

Figure 82 shows a typical BLE deep sleep phase that is terminated at a predetermined time. After a configurable time before the scheduled wake-up time (configured via BLE\_ENBPRESET\_REG register bit fields), the BLE Timer asserts the BLE\_WAKEUP\_LP\_IRQ to wake up the CPU (powering up the System Power Domain). The BLE\_WAKEUP\_LP\_IRQ Interrupt Handler will prepare the code environment and the XTAL32M oscillator stabilization (refer to

SYS\_STAT\_REG[XTAL32\_SETTLED]) and will decide when the BLE Core is ready to exit the BLE Deep Sleep mode.

Once the SW decides that the BLE Core can wake up, it must enable the BLE clocks (via CLK\_RADIO\_REG[BLE\_ENABLE]) and power up the Radio Power Domain (refer to PMU\_CTRL\_REG[RADIO\_SLEEP] and SYS\_STAT\_REG[RAD\_IS\_UP]).

After the sleep period is expired (as specified in BLE\_DEEPSLWKUP\_REG[DEEPSLTIME]), the BLE Timer will not exit the BLE Deep Sleep mode until it detects that the BLE Core is powered up. That means, if the SW requires more time to power up the BLE Core, the final sleep duration (provided by BLE\_DEEPSLSTAT\_REG) will be longer than the preprogrammed value.

When the BLE Timer is expired, BLE clocks are enabled, and the BLE Core (Radio Subsystem) is powered up, the BLE Core exists the "BLE Core Deep Sleep mode" and asserts the BLE SLP IRQ.

**Final** 



Figure 80: Exit BLE Deep Sleep Mode at Predetermined Time (Zoom In)



Figure 81: Exit BLE Deep Sleep Mode after Predetermined Time (Zoom In)



Figure 82: Exit BLE Deep Sleep Mode at Predetermined Time (Zoom Out)

**Final** 

#### 30.2.3.2 Switching Due to an External Event

Figure 83 shows a wakeup from a BLE deep sleep period forced by the assertion of register bit GP\_CONTROL\_REG[BLE\_WAKEUP\_REQ].

Assume that the system is in Extended Sleep state with all power domains switched off and both the wake-up timer and wake-up controller programmed appropriately. Then assume that an event is detected at one of the GPIOs, causing the System Power Domain to wake up due to WKUP\_QUADDEC\_IRQ. In that case, the SW will decide to wake up the BLE core, then it sets the GP\_CONTROL\_REG[BLE\_WAKEUP\_REQ] to 1 to force the wake-up sequence.

In Figure 83 the BLE\_WAKEUP\_REQ is raised by the SW as soon as possible, causing BLE\_WAKEUP\_LP\_IRQ Handler to be executed as soon as possible. It is also possible to raise BLE\_WAKEUP\_REQ after the detection of XTAL32\_TRIM\_READY, causing both BLE\_WAKEUP\_LP\_IRQ and BLE\_SLP\_IRQ Handlers to be executed sequentially. The decision depends on the SW structure and the application.



Figure 83: Exit BLE Deep Sleep Mode Due to External Event

As soon as the bit field BLE\_WAKEUP\_REQ is set to 1, the BLE\_WAKEUP\_LP\_IRQ will be asserted. In that case, the high period of BLE\_WAKEUP\_LP\_IRQ is controlled via TWEXT. The recommended value of TWEXT is "TWIRQ\_RESET + 1", meaning that BLE\_WAKEUP\_LP\_IRQ will remain high for one "ble\_lp\_clk" period.

If the BLE\_WAKEUP\_REQ is high, entering the sleep mode is prohibited. Please note that BLE\_WAKEUP\_REQ event can be disabled by setting BLE\_DEEPSLCNTL\_REG[EXTWKUPDSB].

**Final** 

### 31 Radio

#### 31.1 Introduction

The Radio Transceiver implements the RF part of the Bluetooth® LE protocol. Together with the Bluetooth® 5.1 PHY layer, it provides up to 93 dB RF link budget for a reliable wireless communication. All RF blocks are supplied by on-chip low-drop out-regulators (LDOs). The bias scheme is programmable per block and optimized for minimum power consumption. The radio block diagram is given in Figure 84. It comprises the Receiver, Transmitter, Synthesizer, Rx/Tx combiner block, and Biasing LDOs.

#### **Features**

- Single ended RFIO interface, 50 Ω matched
- Alignment free operation
- -90 dBm receiver sensitivity
- Configurable transmit output power from -19.5 dBm up to +2.5 dBm
- Ultra-low power consumption
- Fast frequency tuning minimizes overhead



Figure 84: Bluetooth® Radio Block Diagram

### 31.2 Architecture

#### 31.2.1 Receiver

The RX frontend consists of a selective matching network, a low noise amplifier (LNA), and an image rejection down conversion mixer. The intermediate frequency (IF) part of the receiver comprises a filter with a programmable gain. The LNA and IF Filter gains are controlled by the Automatic Gain Control (AGC). This provides the necessary signal conditioning prior to digitalization. The digital demodulator block (DEM) provides a synchronous bit stream.



**Final** 

#### 31.2.2 Synthesizer

The RF Synthesizer generates the quadrature LO signal for the mixer, but also generates the modulated TX output signal. The Digitally Controlled Oscillator (DCO) runs at twice the required frequency and a dedicated divide-by-2 circuit generates the 2.4 GHz signals in the required phase relations. The reference frequency is the 32 MHz crystal clock. The modulation of the TX frequency is performed by 2-point modulation.

### 31.2.3 Transmitter

The RF power amplifier (RFPA) is an extremely efficient Class-D structure, providing typically the power ranging from -19.5 dBm to +2.5 dBm to the antenna. It is fed by the DCO's divide-by-2 circuit and delivers its TX power to the antenna pin through the combined RX/TX matching circuit.

#### 31.2.4 RFIO

The RX/TX combiner block is a unique feature of the DA14531. It makes sure that the received power is applied to the LNA with minimum losses towards the RFPA. In TX mode, the LNA poses a minimal load for the RFPA and its input pins are protected from the RFPA. In both modes, the single ended RFIO port is matched to a resistor of 50  $\Omega$  to provide the simplest possible interfacing to the antenna on the printed circuit board.

### **31.2.5** Biasing

All RF blocks are supplied by on-chip LDOs. The bias scheme is programmable and optimized for minimum power consumption.

### 31.2.6 RF Monitoring

The Radio is equipped with a monitoring block whose responsibility is to acquire the data provided by the RF Unit and other analog resources, to combine them in words of 32 bits (when necessary), and to store them in system's memory. Data can be the output of the Demodulator (I and Q) or be provided by the GPADC. With the monitoring block, production tests of the corresponding block can be achieved.

**Final** 

# 32 Registers

This section contains a detailed view of the DA14531 registers. It is organized as follows: an overview table is presented initially, which depicts all register names, addresses, and descriptions. A detailed bit level description of each register follows.

The register file of the Arm Cortex-M0+ can be found in the following documents available on the website:

### **Devices Generic User Guide:**

https://developer.arm.com/docs/238818831/10/getting-started-with-cortex-m0-cortex-m0-cortex-m3-and-cortex-m4-full-licensee-bundles

#### **Technical Reference Manual:**

https://developer.arm.com/docs/ddi0484/c/preface

These documents contain the register descriptions for the Nested Vectored Interrupt Controller (NVIC), the System Control Block (SCB), and the System Timer (SysTick).

## 32.1 Analog Miscellaneous Registers

### Table 59: Register map ANAMISC

| Address    | Register              | Description                              |
|------------|-----------------------|------------------------------------------|
| 0x50001600 | CLK_REF_SEL_REG       | Select clock for oscillator calibration  |
| 0x50001602 | CLK_REF_CNT_REG       | Count value for oscillator calibration   |
| 0x50001604 | CLK_REF_VAL_L_RE<br>G | XTAL32M reference cycles, lower 16 bits  |
| 0x50001606 | CLK_REF_VAL_H_RE<br>G | XTAL32M reference cycles, higher 16 bits |

### Table 60: CLK\_REF\_SEL\_REG (0x50001600)

| Bit | Mode | Symbol         | Description                                                                                                                                                           | Reset |
|-----|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 3   | R/W  | EXT_CNT_EN_SEL | 0 : Enable XTAL_CNT counter by the REF_CLK selected by REF_CLK_SEL.     1 : Enable XTAL_CNT counter from an external input.                                           | 0x0   |
| 2   | R/W  | REF_CAL_START  | Writing a "1" starts a calibration of the clock selected by CLK_REF_SEL_REG[REF_CLK_SEL]. This bit is cleared when calibration is finished, and CLK_REF_VAL is ready. | 0x0   |
| 1:0 | R/W  | REF_CLK_SEL    | Select clock input for calibration:  0x0 : RC32K  0x1 : RC32M  0x2 : XTAL32K  0x3 : RCX                                                                               | 0x0   |



**Final** 

## Table 61: CLK\_REF\_CNT\_REG (0x50001602)

| Bit  | Mode | Symbol      | Description                                                    | Reset |
|------|------|-------------|----------------------------------------------------------------|-------|
| 15:0 | R/W  | REF_CNT_VAL | Indicates the calibration time, with a decrement counter to 1. | 0x0   |

## Table 62: CLK\_REF\_VAL\_L\_REG (0x50001604)

| Bit  | Mode | Symbol       | Description                                                                                               | Reset |
|------|------|--------------|-----------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | XTAL_CNT_VAL | Returns the number of the DIVN clock cycles counted during the calibration time, defined with REF_CNT_VAL | 0x0   |

## Table 63: CLK\_REF\_VAL\_H\_REG (0x50001606)

| Bit  | Mode | Symbol       | Description                                                                                               | Reset |
|------|------|--------------|-----------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | XTAL_CNT_VAL | Returns the number of the DIVN clock cycles counted during the calibration time, defined with REF_CNT_VAL | 0x0   |

**Final** 

# 32.2 Bluetooth® LE Core Registers

## Table 64: Register map BLE

| Address    | Register                     | Description                                                                                 |
|------------|------------------------------|---------------------------------------------------------------------------------------------|
| 0x4000000  | BLE_RWBLECNTL_R<br>EG        | BLE Control register                                                                        |
| 0x40000004 | BLE_VERSION_REG              | Version register                                                                            |
| 0x40000008 | BLE_RWBLECONF_R<br>EG        | Configuration register                                                                      |
| 0x400000C  | BLE_INTCNTL_REG              | Interrupt controller register                                                               |
| 0x40000010 | BLE_INTSTAT_REG              | Interrupt status register                                                                   |
| 0x40000014 | BLE_INTRAWSTAT_R<br>EG       | Interrupt raw status register                                                               |
| 0x40000018 | BLE_INTACK_REG               | Interrupt acknowledge register                                                              |
| 0x4000001C | BLE_BASETIMECNT_<br>REG      | Base time reference counter                                                                 |
| 0x40000020 | BLE_FINETIMECNT_<br>REG      | Fine time reference counter                                                                 |
| 0x40000024 | BLE_BDADDRL_REG              | BLE device address LSB register                                                             |
| 0x40000028 | BLE_BDADDRU_REG              | BLE device address MSB register                                                             |
| 0x4000002C | BLE_CURRENTRXDE<br>SCPTR_REG | Rx Descriptor Pointer for the Receive Buffer Chained List                                   |
| 0x40000030 | BLE_DEEPSLCNTL_R<br>EG       | Deep-Sleep control register                                                                 |
| 0x40000034 | BLE_DEEPSLWKUP_<br>REG       | Time (measured in Low Power clock cycles) in Deep Sleep<br>Mode before waking-up the device |
| 0x40000038 | BLE_DEEPSLSTAT_R<br>EG       | Duration of the last deep sleep phase register                                              |
| 0x4000003C | BLE_ENBPRESET_R<br>EG        | Time in low power oscillator cycles register                                                |
| 0x40000040 | BLE_FINECNTCORR_<br>REG      | Phase correction value register                                                             |
| 0x40000044 | BLE_BASETIMECNTC<br>ORR_REG  | Base Time Counter                                                                           |
| 0x40000050 | BLE_DIAGCNTL_REG             | Diagnostics Register                                                                        |
| 0x40000054 | BLE_DIAGSTAT_REG             | Debug use only                                                                              |
| 0x40000058 | BLE_DEBUGADDMAX<br>_REG      | Upper limit for the memory zone                                                             |
| 0x4000005C | BLE_DEBUGADDMIN _REG         | Lower limit for the memory zone                                                             |
| 0x40000060 | BLE_ERRORTYPEST<br>AT_REG    | Error Type Status registers                                                                 |
| 0x40000064 | BLE_SWPROFILING_<br>REG      | Software Profiling register                                                                 |
| 0x40000074 | BLE_RADIOCNTL1_R<br>EG       | Radio interface control register                                                            |



**Final** 

| Address    | Register                 | Description                               |
|------------|--------------------------|-------------------------------------------|
| 0x40000080 | BLE_RADIOPWRUPD<br>N_REG | RX/TX power up/down phase register        |
| 0x40000090 | BLE_ADVCHMAP_RE G        | Advertising Channel Map                   |
| 0x400000A0 | BLE_ADVTIM_REG           | Advertising Packet Interval               |
| 0x400000A4 | BLE_ACTSCANSTAT _REG     | Active scan register                      |
| 0x400000B0 | BLE_WLPUBADDPTR<br>_REG  | Start address of public devices list      |
| 0x400000B4 | BLE_WLPRIVADDPT<br>R_REG | Start address of private devices list     |
| 0x400000B8 | BLE_WLNBDEV_REG          | Devices in white list                     |
| 0x400000C0 | BLE_AESCNTL_REG          | Start AES register                        |
| 0x400000C4 | BLE_AESKEY31_0_R<br>EG   | AES encryption key                        |
| 0x400000C8 | BLE_AESKEY63_32_<br>REG  | AES encryption key                        |
| 0x400000CC | BLE_AESKEY95_64_<br>REG  | AES encryption key                        |
| 0x400000D0 | BLE_AESKEY127_96<br>_REG | AES encryption key                        |
| 0x400000D4 | BLE_AESPTR_REG           | Pointer to the block to encrypt/decrypt   |
| 0x400000D8 | BLE_TXMICVAL_REG         | AES / CCM plain MIC value                 |
| 0x400000DC | BLE_RXMICVAL_REG         | AES / CCM plain MIC value                 |
| 0x400000E0 | BLE_RFTESTCNTL_R<br>EG   | RF Testing Register                       |
| 0x400000E4 | BLE_RFTESTTXSTAT _REG    | RF Testing Register                       |
| 0x400000E8 | BLE_RFTESTRXSTAT _REG    | RF Testing Register                       |
| 0x400000F0 | BLE_TIMGENCNTL_R<br>EG   | Timing Generator Register                 |
| 0x400000F4 | BLE_GROSSTIMTGT<br>_REG  | Gross Timer Target value                  |
| 0x400000F8 | BLE_FINETIMTGT_R<br>EG   | Fine Timer Target value                   |
| 0x400000FC | BLE_SAMPLECLK_R<br>EG    | Samples the Base Time Counter             |
| 0x40000100 | BLE_COEXIFCNTL0_<br>REG  | Coexistence interface Control 0 Register  |
| 0x40000104 | BLE_COEXIFCNTL1_<br>REG  | Coexistence interface Control 1 Register  |
| 0x40000108 | BLE_BLEMPRIOO_RE<br>G    | Coexistence interface Priority 0 Register |
| 0x4000010C | BLE_BLEMPRIO1_RE<br>G    | Coexistence interface Priority 1 Register |



**Final** 

| Address    | Register           | Description                   |
|------------|--------------------|-------------------------------|
| 0x40000200 | BLE_CNTL2_REG      | BLE Control Register 2        |
| 0x40000208 | BLE_EM_BASE_REG    | Exchange Memory Base Register |
| 0x4000020C | BLE_DIAGCNTL2_RE G | Debug use only                |
| 0x40000210 | BLE_DIAGCNTL3_RE G | Debug use only                |

## Table 65: BLE\_RWBLECNTL\_REG (0x40000000)

| Bit | Mode | Symbol                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-----|------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31  | R0/W | MASTER_SOFT_R<br>ST   | Reset the complete BLE Core except registers and timing generator, when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0.                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 30  | R0/W | MASTER_TGSOFT<br>_RST | Reset the timing generator, when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x0   |
| 29  | R/W  | REG_SOFT_RST          | Reset the complete register block, when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0.  Note that INT STAT will not be cleared, so the user should also write to BLE_INTACK_REG after the SW Reset                                                                                                                                                                                                                                                                                                             | 0x0   |
| 28  | R0/W | SWINT_REQ             | Forces the generation of ble_sw_irq when written with a 1, and proper masking is set. Resets at 0 when action is performed. No action happens if it is written with 0.                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
| 26  | R0/W | RFTEST_ABORT          | Abort the current RF Testing defined as per CS-FORMAT when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0.  Note that when RFTEST_ABORT is requested:  1) In case of infinite Tx, the Packet Controller FSM stops at the end of the current byte in process, and processes accordingly the packet CRC.  2) In case of Infinite Rx, the Packet Controller FSM either stops as the end of the current Packet reception (if Access address has been detected), or simply stop the processing switching off the RF. | 0x0   |
| 25  | R0/W | ADVERT_ABORT          | Abort the current Advertising event when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 24  | R0/W | SCAN_ABORT            | Abort the current scan window when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 22  | R/W  | MD_DSB                | O: Normal operation of MD bits management  1: Allow a single Tx/Rx exchange whatever the MD bits are  value forced by SW from Tx Descriptor value just saved in Rx Descriptor during reception                                                                                                                                                                                                                                                                                                                                                                     | 0x0   |
| 21  | R/W  | SN_DSB                | 0: Normal operation of Sequence number                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |



**Final** 

| Bit   | Mode | Symbol        | Description                                                                                                                                                                                                            | Reset |
|-------|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|       |      |               | Sequence Number Management disabled:     value forced by SW from Tx Descriptor value ignored in Rx, where no SN error reported                                                                                         |       |
| 20    | R/W  | NESN_DSB      | O: Normal operation of Acknowledge     1: Acknowledge scheme disabled:     value forced by SW from Tx Descriptor value ignored in Rx, where no NESN error reported                                                     | 0x0   |
| 19    | R/W  | CRYPT_DSB     | O: Normal operation. Encryption/Decryption enabled  1: Encryption/Decryption disabled  Note that if CS-CRYPT_EN is set, then MIC is generated, and only data encryption is disabled, meaning data sent are plain data. | 0x0   |
| 18    | R/W  | WHIT_DSB      | Normal operation. Whitening enabled     Whitening disabled                                                                                                                                                             | 0x0   |
| 17    | R/W  | CRC_DSB       | O: Normal operation. CRC removed from data stream.     1: CRC stripping disabled on Rx packets, CRC replaced by 0x000 in Tx.                                                                                           | 0x0   |
| 16    | R/W  | HOP_REMAP_DSB | O: Normal operation. Frequency Hopping     Remapping algorithm enabled     1: Frequency Hopping Remapping algorithm disabled                                                                                           | 0x0   |
| 13:12 | R/W  | -             | Reserved                                                                                                                                                                                                               | 0x0   |
| 9     | R/W  | ADVERTFILT_EN | Advertising Channels Error Filtering Enable control  0: BLE Core reports all errors to RW-BLE Software  1: BLE Core reports only correctly received packet, without error to RW-BLE Software                           | 0x0   |
| 8     | R/W  | RWBLE_EN      | Disable BLE Core Exchange Table pre-fetch mechanism     Enable BLE Core Exchange table pre-fetch mechanism                                                                                                             | 0x0   |
| 7:4   | R/W  | RXWINSZDEF    | Default Rx Window size in µs. Used when device: is master connected performs its second receipt. 0 is not a valid value. Recommended value is 10 (in decimal).                                                         | 0x0   |
| 2:0   | R/W  | SYNCERR       | Indicates the maximum number of errors allowed to recognize the synchronization word                                                                                                                                   | 0x0   |

## Table 66: BLE\_VERSION\_REG (0x40000004)

| Bit   | Mode | Symbol | Description                           | Reset |
|-------|------|--------|---------------------------------------|-------|
| 31:24 | R    | TYP    | BLE Core Type                         | 0x7   |
| 23:16 | R    | REL    | BLE Core version Major release number | 0x1   |
| 15:8  | R    | UPG    | BLE Core Upgrade number               | 0x0   |
| 7:0   | R    | BUILD  | BLE Core Build number                 | 0x0   |

**Final** 

# Table 67: BLE\_RWBLECONF\_REG (0x40000008)

| Bit   | Mode | Symbol    | Description                                                                    | Reset |
|-------|------|-----------|--------------------------------------------------------------------------------|-------|
| 29:24 | R    | ADD_WIDTH | Value of the RW_BLE_ADDRESS_WIDTH parameter concerted into binary              | 0xF   |
| 22:16 | R    | RFIF      | Radio Interface ID                                                             | 0x2   |
| 13:8  | R    | CLK_SEL   | Operating Frequency (in MHz)                                                   | 0x0   |
| 6     | R    | DECIPHER  | 0: AES deciphering not present                                                 | 0x0   |
| 5     | R    | DMMODE    | 0: BLE Core is used as a standalone BLE device                                 | 0x0   |
| 4     | R    | INTMODE   | Interrupts are trigger level generated, stays active at 1 till acknowledgement | 0x1   |
| 3     | R    | COEX      | 1: WLAN Coexistence mechanism present                                          | 0x1   |
| 2     | R    | USEDBG    | 1: Diagnostic port instantiated                                                | 0x1   |
| 1     | R    | USECRYPT  | 1: AES-CCM Encryption block present                                            | 0x1   |
| 0     | R    | BUSWIDTH  | Processor bus width: 1: 32 bits                                                | 0x1   |

## Table 68: BLE\_INTCNTL\_REG (0x4000000C)

| Bit   | Mode | Symbol               | Description                                                                                                                                               | Reset |
|-------|------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15    | R/W  | CSCNTDEVMSK          | CSCNT interrupt mask during event. This bit allows to enable CSCNT interrupt generation during events (advertising, scanning, initiating, and connection) | 0x1   |
|       |      |                      | O: CSCNT Interrupt not generated during events     CSCNT Interrupt generated during events                                                                |       |
| 14:10 | R    | -                    | Reserved                                                                                                                                                  | 0x0   |
| 9     | R/W  | SWINTMSK             | SW triggered interrupt Mask 0: Interrupt not generated 1: Interrupt generated                                                                             | 0x0   |
| 8     | R/W  | EVENTAPFAINTMS<br>K  | End of event/anticipated pre-fetch abort interrupt Mask  0: Interrupt not generated  1: Interrupt generated                                               | 0x1   |
| 7     | R/W  | FINETGTIMINTMSK      | Fine Target Timer Mask 0: Interrupt not generated 1: Interrupt generated                                                                                  | 0x0   |
| 6     | R/W  | GROSSTGTIMINTM<br>SK | Gross Target Timer Mask 0: Interrupt not generated 1: Interrupt generated                                                                                 | 0x0   |
| 5     | R/W  | ERRORINTMSK          | Error Interrupt Mask 0: Interrupt not generated 1: Interrupt generated                                                                                    | 0x0   |
| 4     | R/W  | CRYPTINTMSK          | Encryption engine Interrupt Mask 0: Interrupt not generated                                                                                               | 0x1   |



**Final** 

| Bit | Mode | Symbol      | Description                                                                       | Reset |
|-----|------|-------------|-----------------------------------------------------------------------------------|-------|
|     |      |             | 1: Interrupt generated                                                            |       |
| 3   | R/W  | EVENTINTMSK | End of event Interrupt Mask  0: Interrupt not generated  1: Interrupt generated   | 0x1   |
| 2   | R/W  | SLPINTMSK   | Sleep Mode Interrupt Mask 0: Interrupt not generated 1: Interrupt generated       | 0x1   |
| 1   | R/W  | RXINTMSK    | Rx Interrupt Mask 0: Interrupt not generated 1: Interrupt generated               | 0x1   |
| 0   | R/W  | CSCNTINTMSK | 625 µs Base Time Interrupt Mask 0: Interrupt not generated 1: Interrupt generated | 0x1   |

## Table 69: BLE\_INTSTAT\_REG (0x40000010)

| Bit | Mode | Symbol                | Description                                                                                                                                                     | Reset |
|-----|------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9   | R    | SWINTSTAT             | SW triggered interrupt status 0: No SW triggered interrupt 1: A SW triggered interrupt is pending                                                               | 0x0   |
| 8   | R    | EVENTAPFAINTST<br>AT  | End of event/Anticipated Pre-Fetch Abort interrupt status  0: No End of Event interrupt  1: An End of Event interrupt is pending                                | 0x0   |
| 7   | R    | FINETGTIMINTSTA<br>T  | Masked Fine Target Timer Error interrupt status  0: No Fine Target Timer interrupt  1: A Fine Target Timer interrupt is pending                                 | 0x0   |
| 6   | R    | GROSSTGTIMINTS<br>TAT | Masked Gross Target Timer interrupt status 0: No Gross Target Timer interrupt 1: A Gross Target Timer interrupt is pending                                      | 0x0   |
| 5   | R    | ERRORINTSTAT          | Masked Error interrupt status 0: No Error interrupt 1: An Error interrupt is pending                                                                            | 0x0   |
| 4   | R    | CRYPTINTSTAT          | Masked Encryption engine interrupt status 0: No Encryption/Decryption interrupt 1: An Encryption/Decryption interrupt is pending                                | 0x0   |
| 3   | R    | EVENTINTSTAT          | Masked End of Event interrupt status  0: No End of Advertising/Scanning/Connection interrupt  1: An End of Advertising/Scanning/Connection interrupt is pending | 0x0   |
| 2   | R    | SLPINTSTAT            | Masked Sleep interrupt status  0: No End of Sleep Mode interrupt  1: An End of Sleep Mode interrupt is pending                                                  | 0x0   |
| 1   | R    | RXINTSTAT             | Masked Packet Reception interrupt status                                                                                                                        | 0x0   |



**Final** 

| Bit | Mode | Symbol       | Description                                        | Reset |
|-----|------|--------------|----------------------------------------------------|-------|
|     |      |              | 0: No Rx interrupt                                 |       |
|     |      |              | 1: An Rx interrupt is pending                      |       |
| 0   | R    | CSCNTINTSTAT | Masked 625 μs base time reference interrupt status | 0x0   |
|     |      |              | 0: No 625 μs Base Time interrupt                   |       |
|     |      |              | 1: A 625 µs Base Time interrupt is pending         |       |

## Table 70: BLE\_INTRAWSTAT\_REG (0x40000014)

| Bit | Mode | Symbol                   | Description                                                                                                                                                  | Reset |
|-----|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9   | R    | SWINTRAWSTAT             | SW triggered interrupt raw status  0: No SW triggered interrupt  1: A SW triggered interrupt is pending                                                      | 0x0   |
| 8   | R    | EVENTAPFAINTRA<br>WSTAT  | End of event/Anticipated Pre-Fetch Abort interrupt raw status  0: No End of Event interrupt  1: An End of Event interrupt is pending                         | 0x0   |
| 7   | R    | FINETGTIMINTRA<br>WSTAT  | Fine Target Timer Error interrupt raw status  0: No Fine Target Timer interrupt  1: A Fine Target Timer interrupt is pending                                 | 0x0   |
| 6   | R    | GROSSTGTIMINTR<br>AWSTAT | Gross Target Timer interrupt raw status  0: No Gross Target Timer interrupt  1: A Gross Target Timer interrupt is pending                                    | 0x0   |
| 5   | R    | ERRORINTRAWST<br>AT      | Error interrupt raw status  0: No Error interrupt  1: An Error interrupt is pending                                                                          | 0x0   |
| 4   | R    | CRYPTINTRAWST<br>AT      | Encryption engine interrupt raw status  0: No Encryption/Decryption interrupt  1: An Encryption/Decryption interrupt is pending                              | 0x0   |
| 3   | R    | EVENTINTRAWST<br>AT      | End of Event interrupt raw status  0: No End of Advertising/Scanning/Connection interrupt  1: An End of Advertising/Scanning/Connection interrupt is pending | 0x0   |
| 2   | R    | SLPINTRAWSTAT            | Sleep interrupt raw status  0: No End of Sleep Mode interrupt  1: An End of Sleep Mode interrupt is pending                                                  | 0x0   |
| 1   | R    | RXINTRAWSTAT             | Packet Reception interrupt raw status 0: No Rx interrupt 1: An Rx interrupt is pending                                                                       | 0x0   |
| 0   | R    | CSCNTINTRAWST<br>AT      | 625 μs base time reference interrupt raw status 0: No 625 μs Base Time interrupt 1: A 625 μs Base Time interrupt is pending                                  | 0x0   |

**Final** 

Table 71: **BLE\_INTACK\_REG** (0x40000018)

| Bit | Mode | Symbol              | Description                                                                                                                                                              | Reset |
|-----|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9   | R0/W | SWINTACK            | SW triggered interrupt acknowledgement bit                                                                                                                               | 0x0   |
|     |      |                     | Software writing 1 acknowledges the SW triggered interrupt. This bit resets SWINTSTAT and SWINTRAWSTAT flags.                                                            |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 8   | R0/W | EVENTAPFAINTAC<br>K | End of event/Anticipated Pre-Fetch Abort interrupt acknowledgement bit                                                                                                   | 0x0   |
|     |      |                     | Software writing 1 acknowledges the End of event/Anticipated Pre-Fetch Abort interrupt. This bit resets EVENTAPFAINTSTAT and EVENTAPFAINTRAWSTAT flags.                  |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 7   | R0/W | FINETGTIMINTACK     | Fine Target Timer interrupt acknowledgement bit                                                                                                                          | 0x0   |
|     |      |                     | Software writing 1 acknowledges the Fine Timer interrupt. This bit resets FINETGTIMINTSTAT and FINETGTIMINTRAWSTAT flags.                                                |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 6   | R0/W | GROSSTGTIMINTA      | Gross Target Timer interrupt acknowledgement bit                                                                                                                         | 0x0   |
|     |      | CK                  | Software writing 1 acknowledges the Gross Timer interrupt. This bit resets GROSSTGTIMINTSTAT and GROSSTGTIMINTRAWSTAT flags.                                             |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 5   | R0/W | ERRORINTACK         | Error interrupt acknowledgement bit                                                                                                                                      | 0x0   |
|     |      |                     | Software writing 1 acknowledges the Error interrupt. This bit resets ERRORINTSTAT and ERRORINTRAWSTAT flags.                                                             |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 4   | R0/W | CRYPTINTACK         | Encryption engine interrupt acknowledgement bit Software writing 1 acknowledges the Encryption engine interrupt. This bit resets CRYPTINTSTAT and CRYPTINTRAWSTAT flags. | 0x0   |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 3   | R0/W | EVENTINTACK         | End of Event interrupt acknowledgment bit                                                                                                                                | 0x0   |
|     |      |                     | Software writing 1 acknowledges the End of Advertising / Scanning / Connection interrupt. This bit resets SLPINTSTAT and SLPINTRAWSTAT flags.                            |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 2   | R0/W | SLPINTACK           | End of Deep Sleep interrupt acknowledgment bit                                                                                                                           | 0x0   |
|     |      |                     | Software writing 1 acknowledges the End of Sleep Mode interrupt. This bit resets SLPINTSTAT and SLPINTRAWSTAT flags.                                                     |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 1   | R0/W | RXINTACK            | Packet Reception interrupt acknowledgment bit                                                                                                                            | 0x0   |
|     |      |                     | Software writing 1 acknowledges the Rx interrupt. This bit resets RXINTSTAT and RXINTRAWSTAT flags.                                                                      |       |
|     |      |                     | Resets at 0 when action is performed                                                                                                                                     |       |
| 0   | R0/W | CSCNTINTACK         | 625 µs base time reference interrupt acknowledgment bit                                                                                                                  | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                             | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------|-------|
|     |      |        | Software writing 1 acknowledges the CLKN interrupt. This bit resets CLKINTSTAT and CLKINTRAWSTAT flags. |       |
|     |      |        | Resets at 0 when action is performed                                                                    |       |

## Table 72: BLE\_BASETIMECNT\_REG (0x4000001C)

| Bit  | Mode | Symbol      | Description                                                                                                                      | Reset |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 26:0 | R    | BASETIMECNT | Value of the 625 µs base time reference counter. Updated each time SAMPCLK is written. Used by the SW to synchronize with the HW | 0x0   |

### Table 73: BLE\_FINETIMECNT\_REG (0x40000020)

| Bit | Mode | Symbol  | Description                                                                                                                                                                             | Reset |
|-----|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9:0 | R    | FINECNT | Value of the current µs fine time reference counter. Updated each time SAMPCLK is written. Used by the SW in order to synchronize with the HW, and obtain a more precise sleep duration | 0x0   |

## Table 74: BLE\_BDADDRL\_REG (0x40000024)

| Bit  | Mode | Symbol  | Description                                    | Reset |
|------|------|---------|------------------------------------------------|-------|
| 31:0 | R/W  | BDADDRL | Bluetooth Low Energy Device Address. LSB part. | 0x0   |

### Table 75: **BLE\_BDADDRU\_REG** (0x40000028)

| Bit  | Mode | Symbol    | Description                                           | Reset |
|------|------|-----------|-------------------------------------------------------|-------|
| 16   | R/W  | PRIV_NPUB | Bluetooth Low Energy Device Address privacy indicator | 0x0   |
|      |      |           | 0: Public Bluetooth Device Address                    |       |
|      |      |           | 1: Private Bluetooth Device Address                   |       |
| 15:0 | R/W  | BDADDRU   | Bluetooth Low Energy Device Address. MSB part.        | 0x0   |

### Table 76: BLE\_CURRENTRXDESCPTR\_REG (0x4000002C)

| Bit   | Mode | Symbol               | Description                                                                                 | Reset |
|-------|------|----------------------|---------------------------------------------------------------------------------------------|-------|
| 31:16 | R/W  | ETPTR                | Exchange Table Pointer that determines the starting point of the Exchange Table             | 0x0   |
| 14:0  | R/W  | CURRENTRXDESC<br>PTR | Rx Descriptor Pointer that determines the starting point of the Receive Buffer Chained List | 0x0   |

## Table 77: BLE\_DEEPSLCNTL\_REG (0x40000030)

| Bit | Mode | Symbol     | Description              | Reset |
|-----|------|------------|--------------------------|-------|
| 31  | R/W  | EXTWKUPDSB | External Wake-Up disable | 0x0   |



**Final** 

| Bit | Mode | Symbol                 | Description                                                                                                                                                                                                                                                                          | Reset |
|-----|------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                        | O: RW-BLE Core can be woken by external wake-<br>up     1: RW-BLE Core cannot be woken up by external wake-up                                                                                                                                                                        |       |
| 15  | R    | DEEP_SLEEP_STA<br>T    | Indicator of current Deep Sleep clock mux status: 0: RW-BLE Core is not yet in Deep Sleep Mode 1: RW-BLE Core is in Deep Sleep Mode (only low_power_clk is running)                                                                                                                  | 0x0   |
| 4   | R/W  | SOFT_WAKEUP_R<br>EQ    | Wake Up Request from BLE Software. Applies when system is in Deep Sleep Mode. It wakes up the BLE Core when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0.                                                                       | 0x0   |
| 3   | R0/W | DEEP_SLEEP_CO<br>RR_EN | 625 µs base time reference integer and fractional part correction. Applies when system has been woken-up from Deep Sleep Mode. It enables Fine Counter and Base Time counter when written with a 1. Resets at 0 when action is performed. No action happens if it is written with 0. | 0x0   |
| 2   | R0/W | DEEP_SLEEP_ON          | O: BLE Core in normal active mode     1: Request RW-BLE Core to switch in deep sleep mode     This bit is reset on DEEP_SLEEP_STAT falling edge                                                                                                                                      | 0x0   |
| 1:0 | R/W  | DEEP_SLEEP_IRQ<br>_EN  | Always set to 3 when DEEP_SLEEP_ON is set to 1. It controls the generation of BLE_WAKEUP_LP_IRQ.                                                                                                                                                                                     | 0x0   |

## Table 78: BLE\_DEEPSLWKUP\_REG (0x40000034)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                  | Reset |
|------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:0 | R/W  | DEEPSLTIME | Determines the time in low_power_clk clock cycles to spend in Deep Sleep Mode before waking-up the device. This ensures a maximum of 37 hours and 16mn sleep mode capabilities at 32 kHz. This ensures a maximum of 36 hours and 16 mn sleep mode capabilities at 32.768 kHz | 0x0   |

## Table 79: BLE\_DEEPSLSTAT\_REG (0x40000038)

| Bit  | Mode | Symbol    | Description                                                                                                                                                                                                                                         | Reset |
|------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:0 | R    | DEEPSLDUR | Actual duration of the last deep sleep phase measured in low_power_clk clock cycle.  DEEPSLDUR is set to zero at the beginning of the deep sleep phase, and is incremented at each low_power_clk clock cycle until the end of the deep sleep phase. | 0x0   |

**Final** 

## Table 80: BLE\_ENBPRESET\_REG (0x4000003C)

| Bit   | Mode | Symbol      | Description                                                                                                                                             | Reset |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:21 | R/W  | TWEXT       | Minimum and recommended value is "TWIRQ_RESET + 1".                                                                                                     | 0x0   |
|       |      |             | In the case of wake-up due to an external wake-up request, TWEXT specifies the time delay in low power oscillator cycles to deassert BLE_WAKEUP_LP_IRQ. |       |
|       |      |             | See also GP CONTROL REGIBLE WAKEUP REQI.                                                                                                                |       |
|       |      |             | Range is [064 ms] for 32 kHz; [062.5 ms] for 32.768 kHz                                                                                                 |       |
| 20:10 | R/W  | TWIRQ_SET   | Minimum value is "TWIRQ_RESET + 1".                                                                                                                     | 0x0   |
|       |      |             | Time in low power oscillator cycles to set BLE_WAKEUP_LP_IRQ before the BLE sleep timer expiration.                                                     |       |
|       |      |             | Refer also to BLE_DEEPSLWKUP_REG[DEEPSLTIME].                                                                                                           |       |
|       |      |             | Range is [064 ms] for 32 kHz; [062.5 ms] for 32.768 kHz                                                                                                 |       |
| 9:0   | R/W  | TWIRQ_RESET | Recommended value is 1.                                                                                                                                 | 0x0   |
|       |      |             | Time in low power oscillator cycles to reset BLE_WAKEUP_LP_IRQ before the BLE sleep timer expiration.                                                   |       |
|       |      |             | Refer also to BLE_DEEPSLWKUP_REG[DEEPSLTIME].                                                                                                           |       |
|       |      |             | Range is [032 ms] for 32 kHz; [031.25 ms] for 32.768 kHz.                                                                                               |       |

## Table 81: BLE\_FINECNTCORR\_REG (0x40000040)

| Bit | Mode | Symbol      | Description                                                                  | Reset |
|-----|------|-------------|------------------------------------------------------------------------------|-------|
| 9:0 | R/W  | FINECNTCORR | Phase correction value for the 625 µs reference counter (Fine Counter) in µs | 0x0   |

## Table 82: BLE\_BASETIMECNTCORR\_REG (0x40000044)

| Bit  | Mode | Symbol              | Description                        | Reset |
|------|------|---------------------|------------------------------------|-------|
| 26:0 | R/W  | BASETIMECNTCO<br>RR | Base Time Counter correction value | 0x0   |

## Table 83: BLE\_DIAGCNTL\_REG (0x40000050)

| Bit   | Mode | Symbol   | Description                                                                                                     | Reset |
|-------|------|----------|-----------------------------------------------------------------------------------------------------------------|-------|
| 31    | R/W  | DIAG3_EN | 0: Disable diagnostic port 0 output. All outputs are set to 0x0.     1: Enable diagnostic port 0 output.        | 0x0   |
| 29:24 | R/W  | DIAG3    | Only relevant when DIAG3_EN = 1. Selection of the outputs that must be driven to the diagnostic port BLE_DIAG3. | 0x0   |



**Final** 

| Bit   | Mode | Symbol   | Description                                                                                                                    | Reset |
|-------|------|----------|--------------------------------------------------------------------------------------------------------------------------------|-------|
| 23    | R/W  | DIAG2_EN | <ul><li>0: Disable diagnostic port 0 output. All outputs are set to 0x0.</li><li>1: Enable diagnostic port 0 output.</li></ul> | 0x0   |
| 21:16 | R/W  | DIAG2    | Only relevant when DIAG2_EN = 1.  Selection of the outputs that must be driven to the diagnostic port BLE_DIAG2.               | 0x0   |
| 15    | R/W  | DIAG1_EN | <ul><li>0: Disable diagnostic port 0 output. All outputs are set to 0x0.</li><li>1: Enable diagnostic port 0 output.</li></ul> | 0x0   |
| 13:8  | R/W  | DIAG1    | Only relevant when DIAG1_EN = 1.  Selection of the outputs that must be driven to the diagnostic port BLE_DIAG1.               | 0x0   |
| 7     | R/W  | DIAG0_EN | O: Disable diagnostic port 0 output. All outputs are set to 0x0.  1: Enable diagnostic port 0 output.                          | 0x0   |
| 5:0   | R/W  | DIAG0    | Only relevant when DIAG0_EN = 1.  Selection of the outputs that must be driven to the diagnostic port BLE_DIAG0.               | 0x0   |

# Table 84: BLE\_DIAGSTAT\_REG (0x40000054)

| Bit   | Mode | Symbol    | Description                                                 | Reset |
|-------|------|-----------|-------------------------------------------------------------|-------|
| 31:24 | R    | DIAG3STAT | Directly connected to ble_dbg3[7:0] output. Debug use only. | 0x0   |
| 23:16 | R    | DIAG2STAT | Directly connected to ble_dbg2[7:0] output. Debug use only. | 0x0   |
| 15:8  | R    | DIAG1STAT | Directly connected to ble_dbg1[7:0] output. Debug use only. | 0x0   |
| 7:0   | R    | DIAG0STAT | Directly connected to ble_dbg0[7:0] output. Debug use only. | 0x0   |

### Table 85: BLE\_DEBUGADDMAX\_REG (0x40000058)

| Bit   | Mode | Symbol     | Description                                                              | Reset |
|-------|------|------------|--------------------------------------------------------------------------|-------|
| 31:16 | R/W  | REG_ADDMAX | Upper limit for the Register zone indicated by the reg_inzone flag       | 0x0   |
| 15:0  | R/W  | EM_ADDMAX  | Upper limit for the Exchange Memory zone indicated by the em_inzone flag | 0x0   |

### Table 86: BLE\_DEBUGADDMIN\_REG (0x4000005C)

| Bit   | Mode | Symbol     | Description                                                              | Reset |
|-------|------|------------|--------------------------------------------------------------------------|-------|
| 31:16 | R/W  | REG_ADDMIN | Lower limit for the Register zone indicated by the reg_inzone flag       | 0x0   |
| 15:0  | R/W  | EM_ADDMIN  | Lower limit for the Exchange Memory zone indicated by the em_inzone flag | 0x0   |

**Final** 

Table 87: BLE\_ERRORTYPESTAT\_REG (0x40000060)

| Bit | Mode | Symbol                 | Description                                                                                                                                                                                                                                          | Reset |
|-----|------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 17  | R    | CONCEVTIRQ_ER<br>ROR   | Indicates whether two consecutive and concurrent ble_event_irq have been generated, and not acknowledged in time by the BLE Software.  0: No error  1: Error occurred                                                                                | 0x0   |
| 16  | R    | RXDATA_PTR_ER<br>ROR   | Indicates whether Rx data buffer pointer value programmed is null: this is a major programming failure.  0: No error  1: Error occurred                                                                                                              | 0x0   |
| 15  | R    | TXDATA_PTR_ERR<br>OR   | Indicates whether Tx data buffer pointer value programmed is null during Advertising/Scanning/Initiating events, or during Master/Slave connections with non-null packet length: this is a major programming failure.  0: No error 1: Error occurred | 0x0   |
| 14  | R    | RXDESC_EMPTY_<br>ERROR | Indicates whether Rx Descriptor pointer value programmed in register is null: this is a major programming failure.  0: No error  1: Error occurred                                                                                                   | 0x0   |
| 13  | R    | TXDESC_EMPTY_<br>ERROR | Indicates whether Tx Descriptor pointer value programmed in Control Structure is null during Advertising/Scanning/Initiating events: this is a major programming failure.  0: No error  1: Error occurred                                            | 0x0   |
| 12  | R    | CSFORMAT_ERRO<br>R     | Indicates whether CS-FORMAT has been programmed with an invalid value: this is a major software programming failure.  0: No error  1: Error occurred                                                                                                 | 0x0   |
| 11  | R    | LLCHMAP_ERROR          | Indicates Link Layer Channel Map error, happens when actual number of CS-LLCHMAP bit set to one is different from CS-NBCHGOOD at the beginning of Frequency Hopping process  0: No error  1: Error occurred                                          | 0x0   |
| 10  | R    | ADV_UNDERRUN           | Indicates Advertising Interval Under run, occurs if time between two consecutive Advertising packet (in Advertising mode) is lower than the expected value.  0: No error 1: Error occurred                                                           | 0x0   |
| 9   | R    | IFS_UNDERRUN           | Indicates Inter Frame Space Under run, occurs if IFS time is not enough to update and read Control Structure/Descriptors, and/or White List parsing is not finished and/or Decryption time is too long to be finished on time  0: No error           | 0x0   |



Final

| Bit | Mode | Symbol                    | Description                                                                                                                                                                                                                           | Reset |
|-----|------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                           | 1: Error occurred                                                                                                                                                                                                                     |       |
| 8   | R    | WHITELIST_ERRO<br>R       | Indicates White List Timeout error, occurs if White List parsing is not finished on time  0: No error                                                                                                                                 | 0x0   |
|     |      |                           | 1: Error occurred                                                                                                                                                                                                                     |       |
| 7   | R    | EVT_CNTL_APFM_<br>ERROR   | Indicates Anticipated Pre-Fetch Mechanism error: happens when 2 consecutive events are programmed, and when the first event is not completely finished while second pre-fetch instant is reached.  0: No error                        | 0x0   |
|     |      |                           | 1: Error occured                                                                                                                                                                                                                      |       |
| 6   | R    | EVT_SCHDL_APF<br>M_ERROR  | Indicates Anticipated Pre-Fetch Mechanism error: happens when 2 consecutive events are programmed, and when the first event is not completely finished while second pre-fetch instant is reached.  0: No error  1: Error occured      | 0x0   |
|     |      |                           |                                                                                                                                                                                                                                       |       |
| 5   | R    | EVT_SCHDL_ENTR<br>Y_ERROR | Indicates Event Scheduler faced Invalid timing programing on two consecutive ET entries (for example, first one with 624s offset and second one with no offset)  0: No error                                                          | 0x0   |
|     |      |                           | 1: Error occurred                                                                                                                                                                                                                     |       |
|     |      | EVE COURT FAM             |                                                                                                                                                                                                                                       |       |
| 4   | R    | EVT_SCHDL_EMA<br>CC_ERROR | Indicates Event Scheduler Exchange Memory access error, happens when Exchange Memory accesses are not served in time, and blocks the Exchange Table entry read  0: No error  1: Error occurred                                        | 0x0   |
| 3   | R    | RADIO_EMACC_E<br>RROR     | Indicates Radio Controller Exchange Memory access error, happens when Exchange Memory accesses are not served in time and data are corrupted.  0: No error  1: Error occurred                                                         | 0x0   |
| 2   | R    | PKTCNTL_EMACC<br>_ERROR   | Indicates Packet Controller Exchange Memory access error, happens when Exchange Memory accesses are not served in time and Tx/Rx data are corrupted  0: No error  1: Error occurred                                                   | 0x0   |
| 1   | R    | RXCRYPT_ERROR             | Indicates real time decryption error, happens when AES-CCM decryption is too slow compared to Packet Controller requests. A 16-bytes block has to be decrypted prior the next block is received by the Packet Controller  0: No error | 0x0   |
|     |      |                           | 1: Error occurred                                                                                                                                                                                                                     |       |
| 0   | R    | TXCRYPT_ERROR             | Indicates Real Time encryption error, happens when AES-CCM encryption is too slow compared                                                                                                                                            | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                      | Reset |
|-----|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | to Packet Controller requests. A 16-bytes block has to be encrypted and prepared on Packet Controller request, and needs to be ready before the Packet Controller has to send ti |       |
|     |      |        | 0: No error                                                                                                                                                                      |       |
|     |      |        | 1: Error occurred                                                                                                                                                                |       |

# Table 88: BLE\_SWPROFILING\_REG (0x40000064)

| Bit  | Mode | Symbol    | Description                                                                                                      | Reset |
|------|------|-----------|------------------------------------------------------------------------------------------------------------------|-------|
| 31:0 | R/W  | SWPROFVAL | Software Profiling register: used by BLE Software for profiling purpose: this value is copied on Diagnostic port | 0x0   |

### Table 89: BLE\_RADIOCNTL1\_REG (0x40000074)

| Bit   | Mode | Symbol | Description                                         | Reset |
|-------|------|--------|-----------------------------------------------------|-------|
| 31:21 | -    | -      | Reserved                                            | 0x0   |
| 20:16 | R/W  | XRFSEL | Extended radio selection field, Must be set to "2". | 0x0   |

# Table 90: BLE\_RADIOPWRUPDN\_REG (0x40000080)

| Bit   | Mode | Symbol      | Description                                                                                                                                                                         | Reset |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 30:24 | R/W  | RTRIP_DELAY | Defines round trip delay value. This value correspond to the addition of data latency in Tx and data latency in Rx. Value is in µs.                                                 | 0x0   |
| 23:16 | R/W  | RXPWRUP     | This register holds the length in µs of the RX power up phase for the current radio device. Default value is 210 µs (reset value). Operating range depends on the selected radio.   | 0xD2  |
| 11:8  | R/W  | TXPWRDN     | This register extends the length in µs of the TX power down phase for the current radio device. Default value is 3 µs (reset value). Operating range depends on the selected radio. | 0x3   |
| 7:0   | R/W  | TXPWRUP     | This register holds the length in µs of the TX power up phase for the current radio device. Default value is 210 µs (reset value). Operating range depends on the selected radio.   | 0xD2  |

# Table 91: BLE\_ADVCHMAP\_REG (0x40000090)

| Bit | Mode | Symbol   | Description                                                                                                                                                                                                  | Reset |
|-----|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 2:0 | R/W  | ADVCHMAP | Advertising Channel Map, defined as per the advertising connection settings. Contains advertising channels index 37 to 39. If ADVCHMAP[i] equals:  0: Do not use data channel i+37  1: Use data channel i+37 | 0x7   |

**Final** 

### Table 92: BLE\_ADVTIM\_REG (0x400000A0)

| Bit  | Mode | Symbol | Description                                                                                               | Reset |
|------|------|--------|-----------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | ADVINT | Advertising Packet Interval defines the time interval in between two ADV_xxx packet sent. Value is in µs. | 0x0   |
|      |      |        | Value to program depends on the used Advertising Packet type and the device filtering policy.             |       |

### Table 93: BLE\_ACTSCANSTAT\_REG (0x400000A4)

| Bit   | Mode | Symbol     | Description                                             | Reset |
|-------|------|------------|---------------------------------------------------------|-------|
| 24:16 | R    | BACKOFF    | Active scan mode back-off counter initialization value. | 0x1   |
| 8:0   | R    | UPPERLIMIT | Active scan mode upper limit counter value.             | 0x1   |

#### Table 94: BLE\_WLPUBADDPTR\_REG (0x400000B0)

| Bit  | Mode | Symbol      | Description                                             | Reset |
|------|------|-------------|---------------------------------------------------------|-------|
| 15:0 | R/W  | WLPUBADDPTR | Start address pointer of the public devices white list. | 0x0   |

### Table 95: BLE\_WLPRIVADDPTR\_REG (0x400000B4)

| Bit  | Mode | Symbol       | Description                                              | Reset |
|------|------|--------------|----------------------------------------------------------|-------|
| 15:0 | R/W  | WLPRIVADDPTR | Start address pointer of the private devices white list. | 0x0   |

### Table 96: BLE\_WLNBDEV\_REG (0x400000B8)

| Bit  | Mode | Symbol    | Description                                  | Reset |
|------|------|-----------|----------------------------------------------|-------|
| 15:8 | R/W  | NBPRIVDEV | Number of private devices in the white list. | 0x0   |
| 7:0  | R/W  | NBPUBDEV  | Number of public devices in the white list.  | 0x0   |

### Table 97: BLE\_AESCNTL\_REG (0x400000C0)

| Bit | Mode | Symbol    | Description                                                                                                                                             | Reset |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 1   | R/W  | AES_MODE  | 0: Cipher mode 1: Decipher mode                                                                                                                         | 0x0   |
| 0   | R0/W | AES_START | Writing a 1 starts AES-128 ciphering/deciphering process.  This bit is reset once the process is finished (ble_crypt_irq interrupt occurs, even masked) | 0x0   |



**Final** 

#### Table 98: BLE\_AESKEY31\_0\_REG (0x400000C4)

| Bit  | Mode | Symbol     | Description                                  | Reset |
|------|------|------------|----------------------------------------------|-------|
| 31:0 | R/W  | AESKEY31_0 | AES encryption 128-bit key. Bit 31 down to 0 | 0x0   |

#### Table 99: BLE\_AESKEY63\_32\_REG (0x400000C8)

| Bit  | Mode | Symbol      | Description                                   | Reset |
|------|------|-------------|-----------------------------------------------|-------|
| 31:0 | R/W  | AESKEY63_32 | AES encryption 128-bit key. Bit 63 down to 32 | 0x0   |

### Table 100: BLE\_AESKEY95\_64\_REG (0x400000CC)

| Bit  | Mode | Symbol      | Description                                   | Reset |
|------|------|-------------|-----------------------------------------------|-------|
| 31:0 | R/W  | AESKEY95_64 | AES encryption 128-bit key. Bit 95 down to 64 | 0x0   |

#### Table 101: BLE\_AESKEY127\_96\_REG (0x400000D0)

| Bit  | Mode | Symbol       | Description                                    | Reset |
|------|------|--------------|------------------------------------------------|-------|
| 31:0 | R/W  | AESKEY127_96 | AES encryption 128-bit key. Bit 127 down to 96 | 0x0   |

#### Table 102: BLE\_AESPTR\_REG (0x400000D4)

| Bit  | Mode | Symbol | Description                                                                            | Reset |
|------|------|--------|----------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | AESPTR | Pointer to the memory zone where the block to cipher/decipher using AES-128 is stored. | 0x0   |

### Table 103: BLE\_TXMICVAL\_REG (0x400000D8)

| Bit  | Mode | Symbol   | Description                                                            | Reset |
|------|------|----------|------------------------------------------------------------------------|-------|
| 31:0 | R    | TXMICVAL | AES-CCM plain MIC value. Valid on when MIC has been calculated (in Tx) | 0x0   |

#### Table 104: BLE\_RXMICVAL\_REG (0x400000DC)

| Bit  | Mode | Symbol   | Description                                                                   | Reset |
|------|------|----------|-------------------------------------------------------------------------------|-------|
| 31:0 | R    | RXMICVAL | AES-CCM plain MIC value. Valid on once MIC has been extracted from Rx packet. | 0x0   |

### Table 105: BLE\_RFTESTCNTL\_REG (0x400000E0)

| Bit | Mode | Symbol     | Description                                                                       | Reset |
|-----|------|------------|-----------------------------------------------------------------------------------|-------|
| 31  | R/W  | INFINITERX | Applicable in RF Test Mode only 0: Normal mode of operation 1: Infinite Rx window | 0x0   |
| 27  | R/W  | RXPKTCNTEN | Applicable in RF Test Mode only 0: Rx packet count disabled                       | 0x0   |



**Final** 

| Bit | Mode | Symbol      | Description                                                                                                                                                                                                       | Reset |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |             | Rx packet count enabled, and reported in CS-RXCCMPKTCNT and     BLE_RFTESTRXSTAT_REG[RXPKTCNT] on RF abort command                                                                                                |       |
| 15  | R/W  | INFINITETX  | Applicable in RF Test Mode only 0: Normal mode of operation 1: Infinite Tx packet/Normal start of a packet but endless payload                                                                                    | 0x0   |
| 14  | R/W  | TXLENGTHSRC | Applicable only in Tx/Rx RF Test mode 0: Normal mode of operation: TxDESC- TXADVLEN controls the Tx packet payload size 1: Uses BLE_RFTESTCNTL_REG[TXLENGTH] packet length (can support up to 512 bytes transmit) | 0x0   |
| 13  | R/W  | PRBSTYPE    | Applicable only in Tx/Rx RF Test mode 0: Tx Packet Payload are PRBS9 type 1: Tx Packet Payload are PRBS15 type                                                                                                    | 0x0   |
| 12  | R/W  | TXPLDSRC    | Applicable only in Tx/Rx RF Test mode 0: Tx Packet Payload source is the Control Structure 1: Tx Packet Payload are PRBS generator                                                                                | 0x0   |
| 11  | R/W  | TXPKTCNTEN  | Applicable in RF Test Mode only 0: Tx packet count disabled 1: Tx packet count enabled, and reported in CS-TXCCMPKTCNT and BLE_RFTESTTXSTAT_REG[TXPKTCNT] on RF abort command                                     | 0x0   |
| 8:0 | R/W  | TXLENGTH    | Applicable only for Tx/Rx RF Test mode, and valid when BLE_RFTESTCNTL_REG[TXLENGTHSRC] = 1 Tx packet length in number of byte                                                                                     | 0x0   |

# Table 106: BLE\_RFTESTTXSTAT\_REG (0x400000E4)

| Bit  | Mode | Symbol   | Description                                             | Reset |
|------|------|----------|---------------------------------------------------------|-------|
| 31:0 | R    | TXPKTCNT | Reports number of transmitted packet during Test Modes. | 0x0   |
|      |      |          | Value is valid if BLE_RFTESTCNTL_REG[TXPKTCNTEN] is set |       |

# Table 107: BLE\_RFTESTRXSTAT\_REG (0x400000E8)

| Bit  | Mode | Symbol   | Description                                                                                                                                            | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:0 | R    | RXPKTCNT | Reports number of correctly received packet during Test Modes (no sync error, no CRC error).  Value is valid if  BLE_RFTESTCNTL_REG[RXPKTCNTEN] is set | 0x0   |

**Final** 

### Table 108: BLE\_TIMGENCNTL\_REG (0x400000F0)

| Bit   | Mode | Symbol              | Description                                                                                       | Reset |
|-------|------|---------------------|---------------------------------------------------------------------------------------------------|-------|
| 31    | R/W  | APFM_EN             | Controls the Anticipated pre-Fetch Abort mechanism                                                | 0x1   |
|       |      |                     | 0: Disabled                                                                                       |       |
|       |      |                     | 1: Enabled                                                                                        |       |
| 25:16 | R/W  | PREFETCHABORT _TIME | Defines the instant in µs at which immediate abort is required after anticipated pre-fetch abort. | 0x1FE |
| 8:0   | R/W  | PREFETCH_TIME       | Defines Exchange Table pre-fetch instant in μs                                                    | 0x96  |

#### Table 109: BLE\_GROSSTIMTGT\_REG (0x400000F4)

| Bit  | Mode | Symbol      | Description                                                                                                                                                                                                     | Reset |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 22:0 | R/W  | GROSSTARGET | Gross Timer Target value on which a ble_grosstgtim_irq must be generated. This timer has a precision of 10 ms: interrupt is generated only when GROSSTARGET[22:0] = BASETIMECNT[26:4] and BASETIMECNT[3:0] = 0. | 0x0   |

### Table 110: BLE\_FINETIMTGT\_REG (0x400000F8)

| Bit  | Mode | Symbol     | Description                                                                                                                                                             | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 26:0 | R/W  | FINETARGET | Fine Timer Target value on which a ble_finetgtim_irq must be generated. This timer has a precision of 625 µs: interrupt is generated only when FINETARGET = BASETIMECNT | 0x0   |

### Table 111: BLE\_SAMPLECLK\_REG (0x400000FC)

| Bit  | Mode | Symbol | Description                                                                                                    | Reset |
|------|------|--------|----------------------------------------------------------------------------------------------------------------|-------|
| 31:1 | -    | •      | Reserved                                                                                                       | 0x0   |
| 0    | R0/W | SAMP   | Writing a 1 samples the Base Time Counter value in BASETIMECNT register. Resets at 0 when action is performed. | 0x0   |

### Table 112: BLE\_COEXIFCNTL0\_REG (0x40000100)

| Bit   | Mode | Symbol        | Description                                                                       | Reset |
|-------|------|---------------|-----------------------------------------------------------------------------------|-------|
| 21:20 | R/W  | WLCRXPRIOMODE | Defines Bluetooth Low Energy packet ble_rx mode behavior.                         | 0x0   |
|       |      |               | 00: Rx indication excluding Rx Power up delay (starts when correlator is enabled) |       |
|       |      |               | 01: Rx indication including Rx Power up delay                                     |       |
|       |      |               | 10: Rx High priority indicator                                                    |       |
|       |      |               | 11: n/a                                                                           |       |
| 17:16 | R/W  | WLCTXPRIOMODE | Defines Bluetooth Low Energy packet ble_tx mode behavior                          | 0x0   |
|       |      |               | 00: Tx indication excluding Tx Power up delay                                     |       |



**Final** 

| Bit | Mode | Symbol     | Description                                                     | Reset |
|-----|------|------------|-----------------------------------------------------------------|-------|
|     |      |            | 01: Tx indication including Tx Power up delay                   |       |
|     |      |            | 10: Tx High priority indicator                                  |       |
|     |      |            | 11: n/a                                                         |       |
| 7:6 | R/W  | WLANTXMSK  | Determines how wlan_tx impact BLE Tx and Rx                     | 0x0   |
|     |      |            | 00: wlan_tx has no impact (default mode)                        |       |
|     |      |            | 01: wlan_tx can stop BLE Tx, no impact on BLE Rx                |       |
|     |      |            | 10: wlan_tx can stop BLE Rx, no impact on BLE Tx                |       |
|     |      |            | 11: wlan_tx can stop both BLE Tx and BLE Rx                     |       |
| 5:4 | R/W  | WLANRXMSK  | Determines how wlan_rx impact BLE Tx and Rx                     | 0x1   |
|     |      |            | 00: wlan_rx has no impact                                       |       |
|     |      |            | 01: wlan_rx can stop BLE Tx, no impact on BLE Rx (default mode) |       |
|     |      |            | 10: wlan_rx can stop BLE Rx, no impact on BLE Tx                |       |
|     |      |            | 11: wlan_rx can stop both BLE Tx and BLE Rx                     |       |
| 1   | R/W  | SYNCGEN_EN | Determines whether ble_sync is generated or not.                | 0x0   |
|     |      |            | 0: ble_sync pulse not generated                                 |       |
|     |      |            | 1: ble_sync pulse generated                                     |       |
| 0   | R/W  | COEX_EN    | Enable / Disable control of the MWS/WLAN Coexistence control    | 0x0   |
|     |      |            | 0: Coexistence interface disabled                               |       |
|     |      |            | 1: Coexistence interface enabled                                |       |

# Table 113: BLE\_COEXIFCNTL1\_REG (0x40000104)

| Bit   | Mode | Symbol       | Description                                                                                                                                                                                                                                                             | Reset |
|-------|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 28:24 | R/W  | WLCPRXTHR    | Applies on ble_rx if WLCRXPRIOMODE equals 10                                                                                                                                                                                                                            | 0x0   |
|       |      |              | Determines the threshold for Rx priority setting.  If ble_pti[3:0] output value is greater than  WLCPRXTHR, then Rx Bluetooth Low Energy priority is considered as high, and must be provided to the WLAN coexistence interface                                         |       |
| 20:16 | R/W  | WLCPTXTHR    | Applies on ble_tx if WLCTXPRIOMODE equals 10 Determines the threshold for priority setting. If ble_pti[3:0] output value is greater than WLCPTXTHR, then Tx Bluetooth Low Energy priority is considered as high, and must be provided to the WLAN coexistence interface | 0x0   |
| 14:8  | R/W  | WLCPDURATION | Applies on ble_tx if WLCTXPRIOMODE equals 10 Applies on ble_rx if WLCRXPRIOMODE equals 10 Determines how many s the priority information must be maintained Note that if WLCPDURATION = 0x00, then Tx/Rx priority levels are maintained till Tx/Rx EN are deasserted.   | 0x0   |
| 6:0   | R/W  | WLCPDELAY    | Applies on ble_tx if WLCTXPRIOMODE equals 10.                                                                                                                                                                                                                           | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                         | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | Applies on ble_rx if WLCRXPRIOMODE equals 10.                                                                       |       |
|     |      |        | Determines the delay (in µs) in Tx/Rx enables rises the time Bluetooth Low energy Tx/Rx priority has to be provided |       |

# Table 114: BLE\_BLEMPRIOO\_REG (0x40000108)

| Bit   | Mode | Symbol | Description                                                                 | Reset |
|-------|------|--------|-----------------------------------------------------------------------------|-------|
| 31:28 | R/W  | BLEM7  | Set Priority value for Passive Scanning                                     | 0x3   |
| 27:24 | R/W  | BLEM6  | Set Priority value for Non-Connectable Advertising                          | 0x4   |
| 23:20 | R/W  | BLEM5  | Set Priority value for Connectable Advertising BLE message                  | 0x8   |
| 19:16 | R/W  | BLEM4  | Set Priority value for Active Scanning BLE message                          | 0x9   |
| 15:12 | R/W  | BLEM3  | Set Priority value for Initiating (Scanning) BLE message                    | 0xA   |
| 11:8  | R/W  | BLEM2  | Set Priority value for Data Channel transmission BLE message                | 0xD   |
| 7:4   | R/W  | BLEM1  | Set Priority value for LLCP BLE message                                     | 0xE   |
| 3:0   | R/W  | BLEM0  | Set Priority value for Initiating (Connection Request Response) BLE message | 0xF   |

### Table 115: BLE\_BLEMPRIO1\_REG (0x4000010C)

| Bit   | Mode | Symbol      | Description                                                               | Reset |
|-------|------|-------------|---------------------------------------------------------------------------|-------|
| 31:28 | R/W  | BLEMDEFAULT | Set default priority value for other BLE message than those defined above | 0x3   |

### Table 116: BLE\_CNTL2\_REG (0x40000200)

| Bit   | Mode | Symbol                   | Description                                                                                                                                                                                                                                                            | Reset |
|-------|------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:25 | R    | -                        | Reserved                                                                                                                                                                                                                                                               | 0x0   |
| 24    | R/W  | BLE_PHY_ERR_M<br>SK_N    |                                                                                                                                                                                                                                                                        | 0x0   |
| 23    | R/W  | BLE_ARP_ERR_M<br>SK_N    | When cleared to "0" then it masks the BLE_ARP_ERR_STAT in order to not trigger a BLE_ERROR_IRQ.                                                                                                                                                                        | 0x0   |
| 22    | RW1C | BLE_ARP_PHY_ER<br>R_STAT | When set to "1" then an error occured in BLE ARP sub-block and the BLE_GEN_IRQ will be asserted. It will be set if the ARP_ERROR or PHY_ERROR will be asserted and if the BLE_ARP_ERR_MSK is set to "1".  Writing the value "1" will acknowledge and clear this field. | 0x0   |
| 21    | R/W  | BLE_RSSI_SEL             | 0: (default) Select Peak-hold RSSI value during the SYNC_FOUND event:                                                                                                                                                                                                  | 0x0   |

Final

| Bit   | Mode | Symbol                 | Description                                                                                                                                                                                                                                                                                    | Reset |
|-------|------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|       |      |                        | CS->RXRSSI[7:0] = RF_RSSI_RESULT_REG-<br>>RSSI_LATCHED_RD[9:2].                                                                                                                                                                                                                                |       |
|       |      |                        | Select the Average RSSI value during the SYNC_FOUND event:                                                                                                                                                                                                                                     |       |
|       |      |                        | CS->RXRSSI[7:0] = RF_RSSI_RESULT_REG->RSSI_AVG_RD[9:2].                                                                                                                                                                                                                                        |       |
| 20    | R    | WAKEUPLPSTAT           | The status of the BLE_WAKEUP_LP_IRQ. The Interrupt Service Routine of BLE_WAKEUP_LP_IRQ should return only when the WAKEUPLPSTAT is cleared.  Note that BLE_WAKEUP_LP_IRQ is automatically acknowledged after the power up of the Radio Subsystem, plus one Low Power Clock period.            | 0x0   |
| 19    | R/W  | SW_RPL_SPI             | Keep to 0.                                                                                                                                                                                                                                                                                     | 0x0   |
| 18    | R/W  | BB_ONLY                | Keep to 0.                                                                                                                                                                                                                                                                                     | 0x0   |
| 17    | R/W  | BLE_PTI_SOURCE<br>_SEL | O: Provide to COEX block the PTI value indicated by the Control Structure. Recommended value is "0".                                                                                                                                                                                           | 0x0   |
|       |      |                        | 1: Provide to COEX block the PTI value generated dynamically by the BLE core, which is based on the PTI of the Control Structure.                                                                                                                                                              |       |
| 16:15 | R    | -                      | Reserved                                                                                                                                                                                                                                                                                       | 0x0   |
| 14:9  | R/W  | BLE_CLK_SEL            | BLE Clock Select.                                                                                                                                                                                                                                                                              | 0x0   |
|       |      |                        | Specifies the BLE master clock absolute frequency in MHz.                                                                                                                                                                                                                                      |       |
|       |      |                        | Typical values are 16 and 8.                                                                                                                                                                                                                                                                   |       |
|       |      |                        | Value depends on the selected XTAL frequency and the value of CLK_RADIO_REG[BLE_DIV] bitfield. For example, if XTAL oscillates at 16 MHz and CLK_RADIO_REG[BLE_DIV] = 1 (divide by 2), then BLE master clock frequency is 8 MHz and BLE_CLK_SEL should be set to value 8.                      |       |
|       |      |                        | The selected BLE master clock frequency (affected by BLE_DIV and BLE_CLK_SEL) must be modified and set only during the initialization time, that is before setting BLE_RWBLECNTL_REG[RWBLE_EN] to 1.                                                                                           |       |
|       |      |                        | Also see BLE_RWBLECONF_REG[CLK_SEL].                                                                                                                                                                                                                                                           |       |
| 8     | R    | RADIO_PWRDN_A<br>LLOW  | This active high signal indicates when it is allowed for the BLE core (embedded in the Radio sub-System power domain) to be powered down.                                                                                                                                                      | 0x0   |
|       |      |                        | After the assertion of the BLE_DEEPSLCNTL_REG[DEEP_SLEEP_ON] a hardware sequence based on the Low Power clock will cause the assertion of RADIO_PWRDN_ALLOW. The RADIO_PWRDN_ALLOW will be cleared to "0" when the BLE core exits from the sleep state, when the BLE_SLP_IRQ will be asserted. |       |
| 7     | R    | MON_LP_CLK             | The SW can only write a "0" to this bit.                                                                                                                                                                                                                                                       | 0x0   |
|       |      |                        | Whenever a positive edge of the low power clock used by the BLE Timers is detected, then the HW will automatically set this bit to "1". This functionality will not work if BLE Timer is in reset                                                                                              |       |



**Final** 

| Bit | Mode | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                          | Reset |
|-----|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |              | state (refer to CLK_RADIO_REG[BLE_LP_RESET]). This bit can be used for SW synchronization, to debug the low power clock, and so on.                                                                                                                                                                                                                                  |       |
| 6   | R    | BLE_CLK_STAT | 0: BLE uses low power clock 1: BLE uses master clock                                                                                                                                                                                                                                                                                                                 | 0x0   |
| 5:4 | R/W  | -            | Reserved                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
| 3   | R/W  | BLE_DIAG_OVR | 1: Overrule BLE_DIAG. 0: BLE_DIAG is not overruled.                                                                                                                                                                                                                                                                                                                  | 0x0   |
| 2   | R/W  | EMACCERRMSK  | Exchange Memory Access Error Mask:  When cleared to "0" the EM_ACC_ERR will not cause an BLE_ERROR_IRQ interrupt.  When set to "1" an BLE_ERROR_IRQ will be generated as long as EM_ACC_ERR is "1".                                                                                                                                                                  | 0x1   |
| 1   | R0/W | EMACCERRACK  | Exchange Memory Access Error Acknowledge. When the SW writes a "1" to this bit then the EMACCERRSTAT bit will be cleared. When the SW writes "0" it will have no affect. The read value is always "0".                                                                                                                                                               | 0x0   |
| 0   | R    | EMACCERRSTAT | Exchange Memory Access Error Status: The bit is read-only and can be cleared only by writing a "1" at EMACCERRACK bitfield. This bit will be set to "1" by the hardware when the controller will access an EM page that is not mapped according to the EM_MAPPING value. When this bit is "1" then the BLE_ERROR_IRQ will be asserted as long as EMACCERRMSK is "1". | 0x0   |

# Table 117: BLE\_EM\_BASE\_REG (0x40000208)

| Bit   | Mode | Symbol                | Description                                                                       | Reset |
|-------|------|-----------------------|-----------------------------------------------------------------------------------|-------|
| 31:17 | R    | -                     | Reserved                                                                          | 0x0   |
| 16:10 | R/W  | BLE_EM_BASE_16<br>_10 | The physical address on the system memory map of the base of the Exchange Memory. | 0x0   |
| 9:0   | R    | -                     | Reserved                                                                          | 0x0   |

# Table 118: BLE\_DIAGCNTL2\_REG (0x4000020C)

| Bit   | Mode | Symbol   | Description                                                                                                      | Reset |
|-------|------|----------|------------------------------------------------------------------------------------------------------------------|-------|
| 31    | R/W  | DIAG7_EN | 0: Disable diagnostic port 0 output. All outputs are set to 0x0.                                                 | 0x0   |
|       |      |          | 1: Enable diagnostic port 0 output.                                                                              |       |
| 30    | R    | -        | Reserved                                                                                                         | 0x0   |
| 29:24 | R/W  | DIAG7    | Only relevant when DIAG7_EN = 1.  Selection of the outputs that must be driven to the diagnostic port BLE_DIAG7. | 0x0   |

Final

| Bit   | Mode | Symbol   | Description                                                                                                      | Reset |
|-------|------|----------|------------------------------------------------------------------------------------------------------------------|-------|
| 23    | R/W  | DIAG6_EN | 0: Disable diagnostic port 0 output. All outputs are set to 0x0.                                                 | 0x0   |
|       |      |          | 1: Enable diagnostic port 0 output.                                                                              |       |
| 22    | R    | -        | Reserved                                                                                                         | 0x0   |
| 21:16 | R/W  | DIAG6    | Only relevant when DIAG6_EN = 1.  Selection of the outputs that must be driven to the diagnostic port BLE_DIAG6. | 0x0   |
| 15    | R/W  | DIAG5_EN | O: Disable diagnostic port 0 output. All outputs are set to 0x0.  1: Enable diagnostic port 0 output.            | 0x0   |
| 14    | R    | -        | Reserved                                                                                                         | 0x0   |
| 13:8  | R/W  | DIAG5    | Only relevant when DIAG5_EN= 1.  Selection of the outputs that must be driven to the diagnostic port BLE_DIAG5.  | 0x0   |
| 7     | R/W  | DIAG4_EN | O: Disable diagnostic port 0 output. All outputs are set to 0x0.  1: Enable diagnostic port 0 output.            | 0x0   |
| 6     | R    | -        | Reserved                                                                                                         | 0x0   |
| 5:0   | R/W  | DIAG4    | Only relevant when DIAG4_EN = 1.  Selection of the outputs that must be driven to the diagnostic port BLE_DIAG4. | 0x0   |

# Table 119: BLE\_DIAGCNTL3\_REG (0x40000210)

| Bit   | Mode | Symbol    | Description                                                                                  | Reset |
|-------|------|-----------|----------------------------------------------------------------------------------------------|-------|
| 31    | R/W  | DIAG7_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |
| 30:28 | R/W  | DIAG7_BIT | Selects which bit from the DIAG7 word will be forwarded to bit 7 of the BLE Dlagnostic Port. | 0x0   |
| 27    | R/W  | DIAG6_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |
| 26:24 | R/W  | DIAG6_BIT | Selects which bit from the DIAG6 word will be forwarded to bit 6 of the BLE Dlagnostic Port. | 0x0   |
| 23    | R/W  | DIAG5_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |
| 22:20 | R/W  | DIAG5_BIT | Selects which bit from the DIAG5 word will be forwarded to bit 5 of the BLE Dlagnostic Port. | 0x0   |
| 19    | R/W  | DIAG4_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |
| 18:16 | R/W  | DIAG4_BIT | Selects which bit from the DIAG4 word will be forwarded to bit 4 of the BLE Dlagnostic Port. | 0x0   |
| 15    | R/W  | DIAG3_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |
| 14:12 | R/W  | DIAG3_BIT | Selects which bit from the DIAG3 word will be forwarded to bit 3 of the BLE Dlagnostic Port. | 0x0   |
| 11    | R/W  | DIAG2_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |



Final

| Bit  | Mode | Symbol    | Description                                                                                  | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------|-------|
| 10:8 | R/W  | DIAG2_BIT | Selects which bit from the DIAG2 word will be forwarded to bit 2 of the BLE Dlagnostic Port. | 0x0   |
| 7    | R/W  | DIAG1_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |
| 6:4  | R/W  | DIAG1_BIT | Selects which bit from the DIAG1 word will be forwarded to bit 1 of the BLE Dlagnostic Port. | 0x0   |
| 3    | R/W  | DIAG0_INV | If set, then the specific diagnostic bit will be inverted.                                   | 0x0   |
| 2:0  | R/W  | DIAG0_BIT | Selects which bit from the DIAG0 word will be forwarded to bit 0 of the BLE Dlagnostic Port. | 0x0   |

**Final** 

# 32.3 Clock Generation and Reset Registers

Table 120: Register map CRG

| Address    | Register               | Description                                      |
|------------|------------------------|--------------------------------------------------|
| 0x50000000 | CLK_AMBA_REG           | HCLK, PCLK, divider and clock gates              |
| 0x50000002 | CLK_FREQ_TRIM_RE<br>G  | Xtal frequency trimming register                 |
| 0x50000004 | CLK_PER_REG            | Peripheral divider register                      |
| 0x50000008 | CLK_RADIO_REG          | Radio PLL control register                       |
| 0x5000000A | CLK_CTRL_REG           | Clock control register                           |
| 0x50000010 | PMU_CTRL_REG           | Power Management Unit control register           |
| 0x50000012 | SYS_CTRL_REG           | System Control register                          |
| 0x50000014 | SYS_STAT_REG           | System status register                           |
| 0x50000016 | TRIM_CTRL_REG          | Control trimming of the XTAL32M                  |
| 0x50000018 | RAM_PWR_CTRL_RE<br>G   | Control power state of System RAMS               |
| 0x50000020 | CLK_RC32K_REG          | 32 kHz RC oscillator register                    |
| 0x50000022 | CLK_XTAL32K_REG        | 32 kHz XTAL oscillator register                  |
| 0x50000024 | CLK_RC32M_REG          | Fast RC control register                         |
| 0x50000026 | CLK_RCX_REG            | RCX-oscillator control register                  |
| 0x50000028 | BANDGAP_REG            | Bandgap trimming                                 |
| 0x5000002A | ANA_STATUS_REG         | Status bit of analog (power management) circuits |
| 0x50000030 | XTAL32M_START_RE<br>G  | Trim values for XTAL32M                          |
| 0x50000032 | XTAL32M_TRSTAT_R<br>EG | Read back value of current XTAL trimming         |
| 0x50000034 | XTALRDY_CTRL_RE G      | Control register for XTALRDY IRQ                 |
| 0x50000038 | XTAL32M_CTRL0_RE G     | Control bits for XTAL32M                         |
| 0x50000040 | POR_PIN_REG            | Selects a GPIO pin for POR generation            |
| 0x50000042 | POR_TIMER_REG          | Time for POR to happen                           |
| 0x50000050 | PMU_SLEEP_REG          | Bandgap refresh interval during sleep            |
| 0x50000052 | POWER_CTRL_REG         | Power management control                         |
| 0x50000054 | POWER_LEVEL_REG        | Power management level and trim settings         |

# Table 121: CLK\_AMBA\_REG (0x50000000)

| Bit | Mode | Symbol     | Description                                                                             | Reset |
|-----|------|------------|-----------------------------------------------------------------------------------------|-------|
| 7   | R/W  | OTP_ENABLE | Clock enable for OTP controller                                                         | 0x0   |
| 6   | R/W  | -          | Reserved                                                                                | 0x0   |
| 5:4 | R/W  | PCLK_DIV   | APB interface clock (PCLK). Divider is cascaded with HCLK_DIV. PCLK is HCLK divided by: | 0x0   |



**Final** 

| Bit | Mode | Symbol   | Description                                                                     | Reset |
|-----|------|----------|---------------------------------------------------------------------------------|-------|
|     |      |          | 0x0: divide by 1                                                                |       |
|     |      |          | 0x1: divide by 2                                                                |       |
|     |      |          | 0x2: divide by 4                                                                |       |
|     |      |          | 0x3: divide by 8                                                                |       |
| 3:2 | R/W  | -        | Reserved                                                                        | 0x0   |
| 1:0 | R/W  | HCLK_DIV | AHB interface and microprocessor clock (HCLK). HCLK is source clock divided by: | 0x0   |
|     |      |          | 0x0: divide by 1                                                                |       |
|     |      |          | 0x1: divide by 2                                                                |       |
|     |      |          | 0x2: divide by 4                                                                |       |
|     |      |          | 0x3: divide by 8                                                                |       |

# Table 122: CLK\_FREQ\_TRIM\_REG (0x50000002)

| Bit | Mode | Symbol       | Description                            | Reset |
|-----|------|--------------|----------------------------------------|-------|
| 7:0 | R/W  | XTAL32M_TRIM | XTAL frequency fine trimming register. | 0x80  |
|     |      |              | 0x00: Highest frequency                |       |
|     |      |              | 0xFF: Lowest frequency                 |       |

### Table 123: CLK\_PER\_REG (0x50000004)

| Bit | Mode | Symbol              | Description                                                                                    | Reset |
|-----|------|---------------------|------------------------------------------------------------------------------------------------|-------|
| 11  | R/W  | QUAD_ENABLE         | Enable the Quadrature clock                                                                    | 0x1   |
| 10  | R/W  | SPI_ENABLE          | Enable SPI clock                                                                               | 0x0   |
| 9:8 | R/W  | -                   | Reserved                                                                                       | 0x0   |
| 7   | R/W  | UART1_ENABLE        | Enable UART1 clock                                                                             | 0x0   |
| 6   | R/W  | UART2_ENABLE        | Enable UART2 clock                                                                             | 0x0   |
| 5   | R/W  | I2C_ENABLE          | Enable I2C clock                                                                               | 0x0   |
| 4   | R/W  | WAKEUPCT_ENAB<br>LE | Enable Wakeup CaptureTimer clock                                                               | 0x0   |
| 3   | R/W  | TMR_ENABLE          | Enable TIMER0 and TIMER2 clock                                                                 | 0x0   |
| 2   | R/W  | -                   | Reserved                                                                                       | 0x0   |
| 1:0 | R/W  | TMR_DIV             | Division factor for TIMER0 0x0: divide by 1 0x1: divide by 2 0x2: divide by 4 0x3: divide by 8 | 0x0   |

### Table 124: CLK\_RADIO\_REG (0x50000008)

| Bit  | Mode | Symbol       | Description                | Reset |
|------|------|--------------|----------------------------|-------|
| 15:8 | -    | -            | Reserved                   | 0x0   |
| 7    | R/W  | BLE_ENABLE   | Enable the BLE core clocks | 0x0   |
| 6    | R/W  | BLE_LP_RESET | Reset for the BLE LP timer | 0x1   |



**Final** 

| Bit | Mode | Symbol      | Description                                                                                                                                          | Reset |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 5:4 | R/W  | BLE_DIV     | Division factor for BLE core blocks                                                                                                                  | 0x0   |
|     |      |             | 0x0: divide by 1                                                                                                                                     |       |
|     |      |             | 0x1: divide by 2                                                                                                                                     |       |
|     |      |             | 0x2: divide by 4                                                                                                                                     |       |
|     |      |             | 0x3: divide by 8                                                                                                                                     |       |
|     |      |             | The programmed frequency should not be lower than 8 MHz and not faster than the programmed CPU clock frequency. Also see BLE_CNTL2_REG[BLE_CLK_SEL]. |       |
| 3   | R/W  | RFCU_ENABLE | Enable the RF control Unit clock                                                                                                                     | 0x0   |
| 2   | R/W  | -           | Reserved                                                                                                                                             | 0x0   |
| 1:0 | R/W  | -           | Reserved                                                                                                                                             | 0x0   |

# Table 125: CLK\_CTRL\_REG (0x5000000A)

| Bit | Mode | Symbol                 | Description                                                                                                                                                                                                                                                                                                                                                       | Reset |
|-----|------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R    | RUNNING_AT_XTA<br>L32M | Indicates that the XTAL32M clock is used as clock, and may not be switched off                                                                                                                                                                                                                                                                                    | 0x0   |
| 6   | R    | RUNNING_AT_RC3<br>2M   | Indicates that the RC32M clock is used as clock                                                                                                                                                                                                                                                                                                                   | 0x1   |
| 5   | R    | RUNNING_AT_LP_<br>CLK  | Indicates that either the LP_CLK is being used as system clock                                                                                                                                                                                                                                                                                                    | 0x0   |
| 4:3 | R/W  | LP_CLK_SEL             | Sets the clock source of the LowerPower clock 0x0: RC32K 0x1: RCX 0x2: XTAL32K through the oscillator with an external Crystal. 0x3: XTAL32K through an external square wave generator (set PID of P0[3] to FUNC_GPIO) Change this setting before using this clock, and while RUNNING_AT_LP_CLK == 0.                                                             | 0x0   |
| 2   | R/W  | XTAL32M_DISABL<br>E    | Setting this bit instantaneously disables the 32 MHz crystal oscillator. Also, after sleep/wakeup cycle, the oscillator will not be enabled. This bit may not be set to '1' when "RUNNING_AT_XTAL32M is '1' to prevent deadlock. After resetting this bit, wait for XTAL32M_SETTLED or XTAL32M_TRIM_READY to become '1' before switching to XTAL32M clock source. | 0x0   |
| 1:0 | R/W  | SYS_CLK_SEL            | Selects the clock source.  0x0: XTAL32M (check the XTAL32M_SETTLED and XTAL32M_TRIM_READY bits!!)  0x1: RC32M  0x2/0x3: LP_CLK                                                                                                                                                                                                                                    | 0x1   |

**Final** 

Table 126: PMU\_CTRL\_REG (0x50000010)

| Bit | Mode | Symbol             | Description                                                                                                                                                                                                                                                                           | Reset |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 6   | R/W  | MAP_BANDGAP_E<br>N | Enable wake-up diagnostics mapping. When set, these functions are mapped (set direction to output)  P0[2]: BANDGAP_ENABLE  P0[1]: Power WOKENUP  Note: P0[2] assigned also to SWD_CLK, thus the debugger must be detached before entering into sleep mode with MAP_BANDGAP_EN=1. Also | 0x0   |
|     |      |                    | see SYS_STAT_REG->DBG_IS_UP.                                                                                                                                                                                                                                                          |       |
| 5:4 | R/W  | OTP_COPY_DIV       | Sets the HCLK division during OTP mirroring                                                                                                                                                                                                                                           | 0x0   |
| 3   | R/W  | -                  | Reserved                                                                                                                                                                                                                                                                              | 0x0   |
| 2   | R/W  | RADIO_SLEEP        | Put the digital part of the radio in powerdown                                                                                                                                                                                                                                        | 0x1   |
| 1   | R/W  | TIM_SLEEP          | Put PD_TIM in powerdown                                                                                                                                                                                                                                                               | 0x1   |
| 0   | R/W  | RESET_ON_WAKE UP   | Perform a Hardware Reset after waking up. Booter will be started.                                                                                                                                                                                                                     | 0x0   |

# Table 127: SYS\_CTRL\_REG (0x50000012)

| Bit | Mode | Symbol              | Description                                                                                                                                                                                                                                                                     | Reset |
|-----|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15  | W    | SW_RESET            | Writing a '1' to this bit will reset the device, except for:  SYS_CTRL_REG  CLK_FREQ_TRIM_REG                                                                                                                                                                                   | 0x0   |
| 10  | R/W  | TIMEOUT_DISABL<br>E | Disables timeout in Power statemachine. By default, the statemachine continues if after 2 ms the blocks are not started up. This can be read back from ANA_STATUS_REG.                                                                                                          | 0x0   |
| 9   | R/W  | -                   | Reserved                                                                                                                                                                                                                                                                        | 0x0   |
| 8:7 | R/W  | DEBUGGER_ENAB<br>LE | Enable the debugger. This bit is set by the booter according to the OTP header. If not set, the SWDIO and SW_CLK can be used as GPIO ports. 0x0: no debugger enabled.  0x1: SW_CLK = P0[2], SW_DIO=P0[5]  0x2: SW_CLK = P0[2], SW_DIO=P0[1]  0x3: SW_CLK = P0[2], SW_DIO=P0[10] | 0x0   |
| 6   | R/W  | OTPC_RESET_RE<br>Q  | Reset request for the OTP controller.                                                                                                                                                                                                                                           | 0x0   |
| 5   | R/W  | -                   | Reserved                                                                                                                                                                                                                                                                        | 0x1   |
| 4   | R/W  | OTP_COPY            | Enables OTP to SysRAM copy action after waking up PD_SYS                                                                                                                                                                                                                        | 0x0   |
| 3   | R/W  | -                   | Reserved                                                                                                                                                                                                                                                                        | 0x0   |
| 2   | R/W  | DEV_PHASE           | Sets the development phase mode.                                                                                                                                                                                                                                                | 0x0   |



**Final** 

| Bit | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |            | If this bit is set, in combination with the OTP_COPY bit, the OTP DMA will emulate the OTP mirroring to System RAM.                                                                                                                                                                                                                                                                                                 |       |
|     |      |            | No actual writing to RAM is done, but the exact same amount of time is spend as if the mirroring would take place. This is to mimic the behavior as if the System Code is already in OTP, and the mirroring takes place after waking up, but the (development) code still resides in an external source.  If this bit is set to 0 and OTP_COPY = 1, then the OTP DMA will actually do the OTP mirroring at wake-up. |       |
| 1:0 | R/W  | REMAP_ADR0 | Controls which memory is located at address 0x0000 for execution. 0x0: ROM 0x1: OTP 0x2: RAM (SysRAM1) 0x3: RAM (SysRAM3, 28 kB offset) This bitfield only takes affect after a Software Reset.                                                                                                                                                                                                                     | 0x0   |

# Table 128: SYS\_STAT\_REG (0x50000014)

| Bit | Mode | Symbol                 | Description                                                                                     | Reset |
|-----|------|------------------------|-------------------------------------------------------------------------------------------------|-------|
| 7   | R    | XTAL32M_SETTLE<br>D    | Indicates that XTAL32M has had its settle time, as defined by TRIM_CTRL_REG[XTAL_SETTLE_N]      | 0x0   |
| 6   | R    | XTAL32M_TRIM_R<br>EADY | Indicates that XTAL trimming mechanism is ready, that is the trimming equals CLK_FREQ_TRIM_REG. | 0x1   |
| 5   | R    | -                      | Reserved                                                                                        | 0x0   |
| 4   | R    | DBG_IS_UP              | Indicates that the SW debugger is attached and in connection with the Cortex                    | 0x0   |
| 3   | R    | TIM_IS_UP              | Indicates that PD_TIM is functional                                                             | 0x0   |
| 2   | R    | TIM_IS_DOWN            | Indicates that PD_TIM is in power down                                                          | 0x1   |
| 1   | R    | RAD_IS_UP              | Indicates that PD_RAD is functional                                                             | 0x0   |
| 0   | R    | RAD_IS_DOWN            | Indicates that PD_RAD is in power down                                                          | 0x1   |

# Table 129: TRIM\_CTRL\_REG (0x50000016)

| Bit  | Mode | Symbol               | Description                                                                                                                                                                                                 | Reset |
|------|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:8 | R/W  | XTAL_SETTLE_N        | Designates that the XTAL can be safely used as the CPU clock. When XTAL_CLK_CNT reases this value, the signal XTAL32M_SETTLED bit in the SYS_STAT_REG will be set. Counts in steps of 64 XTAL clock-cycles. | 0x3F  |
| 7:6  | R/W  | XTAL_TRIM_SELE<br>CT | Select which source controls the XTAL trimming 0b00: xtal counter. Starts XTAL32M_START_REG[XTAL32M_START] after                                                                                            | 0x0   |



**Final** 

| Bit | Mode | Symbol       | Description                                                                                                                                                                                                                       | Reset |
|-----|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |              | COUNT_N * 32 xtal pulses trim is changed to CLK_FREQ_TRIM_REG[XTAL32M_TRIM].                                                                                                                                                      |       |
|     |      |              | 0b01: xtal OK filter. Starts with CLK_FREQ_TRIM_REG[XTAL32M_START], when xtal amplitude is ramping is changed to CLK_FREQ_TRIM_REG[XTAL32M_TRIM].                                                                                 |       |
|     |      |              | 0b10: statically forced off. Only uses CLK_FREQ_TRIM_REG[XTAL32M_TRIM].                                                                                                                                                           |       |
|     |      |              | 0b11: xtal OK filter, 2 stage. Starts with CLK_FREQ_TRIM_REG[XTAL32M_START] switches to CLK_FREQ_TRIM_REG[XTAL32M_RAMP] after timeout (32 μs), and switches to CLK_FREQ_TRIM_REG[XTAL32M_TRIM] when xtal amplitude is ramping up. |       |
| 5:0 | R/W  | XTAL_COUNT_N | Defines the number of XTAL cycles to be counted, before the XTAL trimming is applied, in steps of 64 cycles.  0x01: 64                                                                                                            | 0x22  |
|     |      |              | 0x02: 128                                                                                                                                                                                                                         |       |
|     |      |              | 0x3f: 4032                                                                                                                                                                                                                        |       |

# Table 130: RAM\_PWR\_CTRL\_REG (0x50000018)

| Bit | Mode | Symbol        | Description                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|-----|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 5:4 | R/W  | RAM3_PWR_CTRL | See description of RAM1_PWR_CTRL                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
| 3:2 | R/W  | RAM2_PWR_CTRL | See description of RAM1_PWR_CTRL                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
| 1:0 | R/W  | RAM1_PWR_CTRL | Power state control of the individual RAMs. May only change when the memory isn't accessed.  When in Active or Sleep mode:  0x0: Normal operation  0x1: Normal operation  0x2: Retained (no access possible)  0x3: Off (memory content corrupted)  When in Extended Sleep, Deep Sleep or Hibernation mode  0x0: Retained  0x1: Off (memory content corrupted)  0x2: Retained  0x3: Off (memory content corrupted) | 0x0   |

### Table 131: CLK\_RC32K\_REG (0x50000020)

| Bit | Mode | Symbol        | Description                                                                                           | Reset |
|-----|------|---------------|-------------------------------------------------------------------------------------------------------|-------|
| 4:1 | R/W  | RC32K_TRIM    | 0000 = lowest frequency<br>0111 = default<br>1111 = highest frequency                                 | 0x7   |
| 0   | R/W  | RC32K_DISABLE | Instantly disables the 32 kHz RC oscillator<br>Sleep cycles cannot happen with this clock<br>disabled | 0x0   |

**Final** 

Table 132: CLK\_XTAL32K\_REG (0x50000022)

| Bit | Mode | Symbol                     | Description                                                                                                                                                                                 | Reset |
|-----|------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 8   | R/W  | -                          | Reserved                                                                                                                                                                                    | 0x0   |
| 7   | R/W  | XTAL32K_DISABLE<br>_AMPREG | Setting this bit disables the amplitude regulation of the XTAL32kHz oscillator.  Set this bit to '1' for an external clock to                                                               | 0x0   |
|     |      |                            | XTAL32Kp                                                                                                                                                                                    |       |
|     |      |                            | Keep this bit '0' with a crystal between XTAL32Kp and XTAL32Km                                                                                                                              |       |
| 6:3 | R/W  | XTAL32K_CUR                | Bias current for the 32 kHz XTAL oscillator. 0000 is minimum, 1111 is maximum, 0011 is default. For each application there is an optimal setting for which the start-up behavior is optimal | 0x5   |
| 2:1 | R/W  | XTAL32K_RBIAS              | Setting for the bias resistor. 00 is maximum, 11 is minimum. Prefered setting will be provided by Dialog                                                                                    | 0x3   |
| 0   | R/W  | XTAL32K_ENABLE             | Enables the 32 kHz XTAL oscillator.                                                                                                                                                         | 0x0   |
|     |      |                            | Also set GP_DATA_REG[P03_P04_FILT_DIS] = 1 for lowest current consumption.                                                                                                                  |       |

### Table 133: CLK\_RC32M\_REG (0x50000024)

| Bit  | Mode | Symbol        | Description                                                                     | Reset |
|------|------|---------------|---------------------------------------------------------------------------------|-------|
| 10:7 | R/W  | RC32M_COSC    | C-adjust of RC-oscillator                                                       | 0xF   |
|      |      |               | A higher value of COSC results in a lower frequency                             |       |
| 6:5  | R/W  | RC32M_RANGE   | Coarse adjust                                                                   | 0x0   |
|      |      |               | A higher value of RANGE results in a higher frequency, values 2 and 3 are equal |       |
| 4:1  | R/W  | RC32M_BIAS    | Bias adjustment                                                                 | 0x7   |
| 0    | R/W  | RC32M_DISABLE | Instantly disables the 32 MHz RC oscillator                                     | 0x0   |
|      |      |               | Disabling of the oscillator during sleep happens automatically.                 |       |

# Table 134: CLK\_RCX\_REG (0x50000026)

| Bit  | Mode | Symbol      | Description                                                                                     | Reset |
|------|------|-------------|-------------------------------------------------------------------------------------------------|-------|
| 11:8 | R/W  | RCX_BIAS    | LDO bias current.                                                                               | 0xA   |
|      |      |             | 0x0: minimum                                                                                    |       |
|      |      |             | 0xF: maximum                                                                                    |       |
| 7    | R/W  | RCX_C0      | Add unit capacitance to RC-time delay                                                           | 0x1   |
| 6:2  | R/W  | RCX_CADJUST | Adjust capacitance part of RC-time delay.  0x00: minimum capacitance  0x1F: maximum capacitance | 0x1F  |
| 1    | R/W  | RCX_RADJUST | Adjust resistance part of RC-time delay. Lower resistance increases power consumption.          | 0x0   |



**Final** 

| Bit | Mode | Symbol     | Description               | Reset |
|-----|------|------------|---------------------------|-------|
|     |      |            | 0x0: maximum resistance   |       |
|     |      |            | 0x1: minimum resistance   |       |
| 0   | R/W  | RCX_ENABLE | Enable the RCX oscillator | 0x0   |

# Table 135: BANDGAP\_REG (0x50000028)

| Bit | Mode | Symbol    | Description                                                                                       | Reset |
|-----|------|-----------|---------------------------------------------------------------------------------------------------|-------|
| 9:5 | R/W  | BGR_ITRIM | Trim setting for bandgap bias current 10000 -> -25% 11111 -> ~0% 00000 -> ~0% (typ) 01111 -> +32% | 0x0   |
| 4:0 | R/W  | BGR_TRIM  | Trim setting for bandgap voltage 10000 -> -6.4% 11111 -> ~0% 00000 -> ~0% (typ) 01111 -> +5.8%    | 0x0   |

# Table 136: ANA\_STATUS\_REG (0x5000002A)

| Bit | Mode | Symbol                  | Description                                                                                                                                                                                                                                                                                    | Reset |
|-----|------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 12  | R    | CLKLESS_WAKEU<br>P_STAT | Indicates the output of the Clockless wake-up XOR tree. If this signal is "0", the chip will wake up.  Use the HIBERN_WKUP_POLARITY bit to set the value to "1" before going into hibernation mode.                                                                                            | 0x0   |
| 11  | R    | -                       | Reserved                                                                                                                                                                                                                                                                                       | 0x0   |
| 10  | R    | LDO_GPADC_OK            | Indicates that LDO_GPADC output is OK                                                                                                                                                                                                                                                          | 0x0   |
| 9   | R    | LDO_XTAL_OK             | Indicates that LDO_XTAL output is OK                                                                                                                                                                                                                                                           | 0x0   |
| 8   | R    | BOOST_SELECTE<br>D      | 0: Buck mode detected 1: Boost mode detected                                                                                                                                                                                                                                                   | 0x0   |
| 7   | R    | POR_VBAT_HIGH           | Output of VBAT_HIGH supply rail voltage monitoring circuit.  0: Voltage level on VBAT_HIGH is lower than POR VBAT_HIGH threshold VTH_L (rail not ok, will result in reset if not masked)  1: Voltage level on VBAT_HIGH is higher than POR VBAT_HIGH threshold VTH_H (rail ok, reset released) | 0x0   |
| 6   | R    | POR_VBAT_LOW            | Output of VBAT_LOW supply rail voltage monitoring circuit.  0: Voltage level on VBAT_LOW is lower than POR VBAT_LOW threshold VTH_L (rail not ok, will result in reset if not masked)                                                                                                          | 0x0   |



**Final** 

| Bit | Mode | Symbol                 | Description                                                                                        | Reset |
|-----|------|------------------------|----------------------------------------------------------------------------------------------------|-------|
|     |      |                        | 1: Voltage level on VBAT_LOW is higher than POR VBAT_LOW threshold VTH_H (rail ok, reset released) |       |
| 5   | R    | BANDGAP_OK             | Indicates that BANDGAP is OK                                                                       | 0x0   |
| 4   | R    | COMP_VBAT_HIG<br>H_NOK | Indicates that VBAT_HIGH < VBAT_LOW -50 mV                                                         | 0x0   |
| 3   | R    | COMP_VBAT_HIG<br>H_OK  | Indicates that VBAT_HIGH > VBAT_LOW +50 mV                                                         | 0x0   |
| 2   | R    | DCDC_OK                | Indicates that VBAT_LOW (buck mode) or VBAT_HIGH (boost mode) is OK                                | 0x0   |
| 1   | R    | LDO_LOW_OK             | Indicates that LDO_LOW output is OK (only valid for high current mode)                             | 0x0   |
| 0   | R    | LDO_CORE_OK            | Indicates that LDO_CORE output is OK                                                               | 0x0   |

# Table 137: XTAL32M\_START\_REG (0x50000030)

| Bit  | Mode | Symbol        | Description                                                                         | Reset |
|------|------|---------------|-------------------------------------------------------------------------------------|-------|
| 15:8 | R/W  | XTAL32M_RAMP  | Xtal frequency trimming register.  0x00 : highest frequency  0xFF :lowest frequency | 0x0   |
| 7:0  | R/W  | XTAL32M_START | Xtal frequency trimming register.  0x0 = highest frequency  0xF = lowest frequency  | 0xAA  |

### Table 138: XTALRDY\_CTRL\_REG (0x50000034)

| Bit | Mode | Symbol      | Description                                                                                              | Reset |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------|-------|
| 7:0 | R/W  | XTALRDY_CNT | Number of 32 kHz cycles between the crystal is enabled, and the XTALRDY_IRQ is fired. 0x00: no interrupt | 0x0   |

# Table 139: XTAL32M\_CTRL0\_REG (0x50000038)

| Bit | Mode | Symbol                     | Description                                                        | Reset |
|-----|------|----------------------------|--------------------------------------------------------------------|-------|
| 9:8 | R/W  | -                          | Reserved                                                           | 0x0   |
| 7:5 | R/W  | CORE_AMPL_TRIM             | Core amplitude trimming                                            | 0x0   |
| 4:2 | R/W  | CORE_CUR_SET               | Core current trim setting                                          | 0x5   |
| 1   | R/W  | CORE_AMPL_REG<br>_NULLBIAS | Keep bias in ampl detector alive, even when there is a large drive | 0x0   |
| 0   | R/W  | DCBLOCK_ENABL<br>E         | Enable dcblock/high pass filter circuit                            | 0x1   |

**Final** 

### Table 140: POR\_PIN\_REG (0x50000040)

| Bit | Mode | Symbol               | Description                                                                                                                                            | Reset |
|-----|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R/W  | POR_PIN_POLARI<br>TY | O: Active Low  1: Active High  Note: This applies only for the GPIO pin. Reset pad has a fixed polarity                                                | 0x0   |
| 6:4 | R/W  | -                    | Reserved                                                                                                                                               | 0x0   |
| 3:0 | R/W  | POR_PIN_SELECT       | Selects the GPIO which is used for POR generation.  0x0: GPIO pin POReset disabled  0x1: P0_0  0x2: P0_1   0xB: P0_10  0xC: P0_11  0xD - 0xF: reserved | 0x0   |

### Table 141: POR\_TIMER\_REG (0x50000042)

| Bit | Mode | Symbol   | Description                                  | Reset |
|-----|------|----------|----------------------------------------------|-------|
| 6:0 | R/W  | POR_TIME | Time for the POReset to happen.              | 0x18  |
|     |      |          | Formula:                                     |       |
|     |      |          | Time = POR_TIME x 4096 x RC32k clock period  |       |
|     |      |          | Default value: ~3 seconds                    |       |
|     |      |          | When set to 0x00, the POR TIMER is disabled. |       |

### Table 142: PMU\_SLEEP\_REG (0x50000050)

| Bit  | Mode | Symbol                  | Description                                                                                             | Reset |
|------|------|-------------------------|---------------------------------------------------------------------------------------------------------|-------|
| 11:0 | R/W  | BG_REFRESH_INT<br>ERVAL | Defines the refresh interval of reference voltages (bandgap activation and sampling), in units of 2 ms. | 0x80  |

### Table 143: POWER\_CTRL\_REG (0x50000052)

| Bit | Mode | Symbol                   | Description                                                        | Reset |
|-----|------|--------------------------|--------------------------------------------------------------------|-------|
| 15  | R/W  | VBAT_HL_CONNE<br>CT_MODE | Sets the control mode fo the switch between VBAT_HIGH and VBAT_LOW | 0x0   |
|     |      |                          | 0: Manual (default)                                                |       |
|     |      |                          | 1: Automatic (boost mode only)                                     |       |
| 14  | R/W  | POR_VBAT_HIGH_           | 0: Hysteresis enabled                                              | 0x1   |
|     |      | HYST_DIS                 | 1: Hysteresis disabled                                             |       |
| 13  | R/W  | POR_VBAT_HIGH_           | 0: Low level selected                                              | 0x0   |
|     |      | HYST_SEL                 | 1: High level selected                                             |       |



**Final** 

| Bit | Mode | Symbol                       | Description                                                                                                                                                                                | Reset |
|-----|------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 12  | R/W  | POR_VBAT_HIGH_<br>DISABLE    | Disable por_vbat_high circuit                                                                                                                                                              | 0x0   |
| 11  | R/W  | POR_VBAT_LOW_<br>HYST_DIS    | 0: Hysteresis enabled<br>1: Hysteresis disabled                                                                                                                                            | 0x0   |
| 10  | R/W  | POR_VBAT_LOW_<br>HYST_SEL    | 0: Low level selected 1: High level selected                                                                                                                                               | 0x0   |
| 9   | R/W  | POR_VBAT_LOW_<br>DISABLE     | Disable por_vbat_low circuit                                                                                                                                                               | 0x0   |
| 8   | R/W  | CP_DISABLE                   | Disables LDO_CORE charge-pump circuit                                                                                                                                                      | 0x0   |
| 7   | R/W  | LDO_VREF_HOLD_<br>FORCE      | Forces LDO references in HOLD mode                                                                                                                                                         | 0x0   |
| 6:5 | R/W  | LDO_LOW_CTRL_<br>REG         | 00: High-current mode in active, LDO_LOW OFF in sleep 01: LDO_LOW OFF 10: Low-current mode in active, Low-current mode in sleep 11: High-current mode in active, Low-current mode in sleep | 0x0   |
| 4   | R/W  | LDO_CORE_DISAB<br>LE         | Disables LDO_CORE                                                                                                                                                                          | 0x0   |
| 3   | R/W  | LDO_CORE_RET_<br>ENABLE      | LDO_CORE_RETENTION 0: Disabled 1: Enabled                                                                                                                                                  | 0x0   |
| 2   | R/W  | VBAT_HL_CONNE<br>CT          | Switch between VBAT_HIGH and VBAT_LOW 0: Open 1: Closed                                                                                                                                    | 0x0   |
| 1   | R/W  | CMP_VBAT_HIGH_<br>OK_ENABLE  | Enable cmp_vbat_high_ok                                                                                                                                                                    | 0x0   |
| 0   | R/W  | CMP_VBAT_HIGH_<br>NOK_ENABLE | Enable cmp_vbat_high_nok                                                                                                                                                                   | 0x0   |

# Table 144: POWER\_LEVEL\_REG (0x50000054)

| Bit   | Mode | Symbol     | Description                         | Reset |
|-------|------|------------|-------------------------------------|-------|
| 13:11 | R/W  | DCDC_TRIM  | Delta from DCDC_LEVEL nominal value | 0x3   |
|       |      |            | 000: -75 mV                         |       |
|       |      |            | 001: -50 mV                         |       |
|       |      |            | 010: -25 mV                         |       |
|       |      |            | 011: 0 (default)                    |       |
|       |      |            | 100: +25 mV                         |       |
|       |      |            | 101: +50 mV                         |       |
|       |      |            | 110: +75 mV                         |       |
|       |      |            | 111: +100 mV                        |       |
| 10:9  | R/W  | DCDC_LEVEL | 00: 1.1 V                           | 0x1   |
|       |      |            | 01: 1.8 V (default)                 |       |



**Final** 

| Bit | Mode | Symbol        | Description                    | Reset |
|-----|------|---------------|--------------------------------|-------|
|     |      |               | 10: 2.5 V                      |       |
|     |      |               | 11: 3.0 V                      |       |
| 8:7 | R/W  | -             | Reserved                       | 0x0   |
| 6:4 | R/W  | LDO_XTAL_TRIM | Delta from 0.9 V nominal value | 0x3   |
|     |      |               | 000: -75 mV                    |       |
|     |      |               | 001: -50 mV                    |       |
|     |      |               | 010: -25 mV                    |       |
|     |      |               | 011: 0 (default)               |       |
|     |      |               | 100: +25 mV                    |       |
|     |      |               | 101: +50 mV                    |       |
|     |      |               | 110: +75 mV                    |       |
|     |      |               | 111: +100 mV                   |       |
| 3:1 | R/W  | LDO_LOW_TRIM  | Delta from 1.1 V nominal value | 0x7   |
|     |      |               | 000: -75 mV                    |       |
|     |      |               | 001: -50 mV                    |       |
|     |      |               | 010: -25 mV                    |       |
|     |      |               | 011: 0 (default)               |       |
|     |      |               | 100: +25 mV                    |       |
|     |      |               | 101: +50 mV                    |       |
|     |      |               | 110: +75 mV                    |       |
|     |      |               | 111: +100 mV (coldboot)        |       |
| 0   | R/W  | -             | Reserved                       | 0x0   |

### Table 145: XTAL32M\_TRSTAT\_REG (0x50000032)

| Bit | Mode | Symbol         | Description                              | Reset |
|-----|------|----------------|------------------------------------------|-------|
| 7:0 | R    | XTAL32M_TRSTAT | Reads value of the current XTAL trimming | 0x0   |

### Table 146: Register map CRG\_TIM

| Address    | Register       | Description                  |
|------------|----------------|------------------------------|
| 0x5000424C | CLK_RTCDIV_REG | Divisor for RTC 100 Hz clock |

# Table 147: CLK\_RTCDIV\_REG (0x5000424C)

| Bit | Mode | Symbol         | Description                                                    | Reset |
|-----|------|----------------|----------------------------------------------------------------|-------|
| 21  | R/W  | RTC_RESET_REQ  | Reset request for the RTC module                               | 0x0   |
| 20  | R/W  | RTC_DIV_ENABLE | Enable for the 100 Hz generation for the RTC block             | 0x0   |
| 19  | R/W  | RTC_DIV_DENOM  | Selects the denominator for the fractional division: 0b0: 1000 | 0x0   |



Final

| Bit   | Mode | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|-------|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|       |      |              | 0b1: 1024                                                                                                                                                                                                                                                                                                                                                                     |       |
| 18:10 | R/W  | RTC_DIV_INT  | Integer divisor part for RTC 100 Hz generation                                                                                                                                                                                                                                                                                                                                | 0x147 |
| 9:0   | R/W  | RTC_DIV_FRAC | Fractional divisor part for RTC 100 Hz generation. if RTC_DIV_DENOM=1, <rtc_div_frac> out of 1024 cycles will divide by <rtc_div_int+1>, the rest is <rtc_div_int>  If RTC_DIV_DENOM=0, <rtc_div_frac> out of 1000 cycles will divide by <rtc_div_int+1>, the rest is <rtc_div_int></rtc_div_int></rtc_div_int+1></rtc_div_frac></rtc_div_int></rtc_div_int+1></rtc_div_frac> | 0x2A8 |

**Final** 

# **32.4 DCDC Converter Registers**

### Table 148: Register map DCDC

| Address    | Register      | Description |
|------------|---------------|-------------|
| 0x50000080 | DCDC_CTRL_REG |             |

### Table 149: DCDC\_CTRL\_REG (0x50000080)

| Bit   | Mode | Symbol              | Description                                                      | Reset |
|-------|------|---------------------|------------------------------------------------------------------|-------|
| 15:12 | R/W  | DCDC_ILIM_MAX       | Maximum value for automatic inductor peak current limit control. | 0x8   |
|       |      |                     | 0x0: 6 mA                                                        |       |
|       |      |                     | 0x1: 12 mA                                                       |       |
|       |      |                     | 0x2: 18 mA                                                       |       |
|       |      |                     | 0x3: 24 mA                                                       |       |
|       |      |                     | 0x4: 30 mA                                                       |       |
|       |      |                     | 0x5: 36 mA                                                       |       |
|       |      |                     | 0x6: 42 mA                                                       |       |
|       |      |                     | 0x7: 48 mA                                                       |       |
|       |      |                     | 0x8: 54 mA (default, limits inrush current)                      |       |
|       |      |                     | 0x9: 60 mA                                                       |       |
|       |      |                     | 0xA: 66 mA                                                       |       |
|       |      |                     | 0xB: 72 mA                                                       |       |
|       |      |                     | 0xC: 78 mA                                                       |       |
|       |      |                     | 0xD: 84 mA                                                       |       |
|       |      |                     | 0xE: 90 mA                                                       |       |
|       |      |                     | 0xF: 96 mA (set as default for low-ohmic batteries)              |       |
| 11:8  | R/W  | DCDC_ILIM_MIN       | Minimum value for automatic inductor peak current limit control. | 0x4   |
|       |      |                     | 0x0: 6 mA                                                        |       |
|       |      |                     | 0x1: 12 mA                                                       |       |
|       |      |                     | 0x2: 18 mA                                                       |       |
|       |      |                     | 0x3: 24 mA                                                       |       |
|       |      |                     | 0x4: 30 mA (default)                                             |       |
|       |      |                     | 0x5: 36 mA                                                       |       |
|       |      |                     | 0x6: 42 mA                                                       |       |
|       |      |                     | 0x7: 48 mA                                                       |       |
|       |      |                     | 0x8: 54 mA                                                       |       |
|       |      |                     | 0x9: 60 mA                                                       |       |
|       |      |                     | 0xA: 66 mA                                                       |       |
|       |      |                     | 0xB: 72 mA                                                       |       |
|       |      |                     | 0xC: 78 mA                                                       |       |
|       |      |                     | 0xD: 84 mA                                                       |       |
|       |      |                     | 0xE: 90 mA                                                       |       |
|       |      |                     | 0xF: 96 mA                                                       |       |
| 7:6   | R/W  | DCDC_OK_CLR_C<br>NT | Number of subsequent V_NOK events needed to reset VDCD_OK.       | 0x2   |



Final

| Bit | Mode | Symbol       | Description                                                                                | Reset |
|-----|------|--------------|--------------------------------------------------------------------------------------------|-------|
|     |      |              | 0x0: 2                                                                                     |       |
|     |      |              | 0x1: 4                                                                                     |       |
|     |      |              | 0x2: 8 (deafult)                                                                           |       |
|     |      |              | 0x3: 15                                                                                    |       |
| 5:3 | R/W  | DCDC_TIMEOUT | Switch timeout, go to next state if either switch is active for longer than this setting.  | 0x4   |
|     |      |              | 0x0: Disabled                                                                              |       |
|     |      |              | 0x1: 0.25 μs                                                                               |       |
|     |      |              | 0x2: 0.50 μs                                                                               |       |
|     |      |              | 0x3: 0.75 μs                                                                               |       |
|     |      |              | 0x4: 1.00 μs (default)                                                                     |       |
|     |      |              | 0x5: 1.25 μs                                                                               |       |
|     |      |              | 0x6: 1.50 μs                                                                               |       |
|     |      |              | 0x7: 1.75 μs                                                                               |       |
| 2:1 | R/W  | DCDC_CLK_DIV | Idle clock divider, sets rate at which the output is monitored when the converter is idle. | 0x1   |
|     |      |              | 0x0: Divide by 4                                                                           |       |
|     |      |              | 0x1: Divide by 8                                                                           |       |
|     |      |              | 0x2: Divide by 16                                                                          |       |
|     |      |              | 0x3: Divide by 32                                                                          |       |
| 0   | R/W  | DCDC_ENABLE  | Enables hardware control of the DCDC converter.                                            | 0x0   |
|     |      |              | 0: DCDC converter disabled                                                                 |       |
|     |      |              | 1: DCDC converter under hardware control                                                   |       |

© 2022 Renesas Electronics

**Final** 

# 32.5 DMA Controller Registers

# Table 150: Register map DMA

| Address    | Register              | Description                              |
|------------|-----------------------|------------------------------------------|
| 0x50003600 | DMA0_A_STARTL_R<br>EG | Start address Low A of DMA channel 0     |
| 0x50003602 | DMA0_A_STARTH_R<br>EG | Start address High A of DMA channel 0    |
| 0x50003604 | DMA0_B_STARTL_R<br>EG | Start address Low B of DMA channel 0     |
| 0x50003606 | DMA0_B_STARTH_R<br>EG | Start address High B of DMA channel 0    |
| 0x50003608 | DMA0_INT_REG          | DMA receive interrupt register channel 0 |
| 0x5000360A | DMA0_LEN_REG          | DMA receive length register channel 0    |
| 0x5000360C | DMA0_CTRL_REG         | Control register for the DMA channel 0   |
| 0x5000360E | DMA0_IDX_REG          | Index value of DMA channel 0             |
| 0x50003610 | DMA1_A_STARTL_R<br>EG | Start address Low A of DMA channel 1     |
| 0x50003612 | DMA1_A_STARTH_R<br>EG | Start address High A of DMA channel 1    |
| 0x50003614 | DMA1_B_STARTL_R<br>EG | Start address Low B of DMA channel 1     |
| 0x50003616 | DMA1_B_STARTH_R<br>EG | Start address High B of DMA channel 1    |
| 0x50003618 | DMA1_INT_REG          | DMA receive interrupt register channel 1 |
| 0x5000361A | DMA1_LEN_REG          | DMA receive length register channel 1    |
| 0x5000361C | DMA1_CTRL_REG         | Control register for the DMA channel 1   |
| 0x5000361E | DMA1_IDX_REG          | Index value of DMA channel 1             |
| 0x50003620 | DMA2_A_STARTL_R<br>EG | Start address Low A of DMA channel 2     |
| 0x50003622 | DMA2_A_STARTH_R<br>EG | Start address High A of DMA channel 2    |
| 0x50003624 | DMA2_B_STARTL_R<br>EG | Start address Low B of DMA channel 2     |
| 0x50003626 | DMA2_B_STARTH_R<br>EG | Start address High B of DMA channel 2    |
| 0x50003628 | DMA2_INT_REG          | DMA receive interrupt register channel 2 |
| 0x5000362A | DMA2_LEN_REG          | DMA receive length register channel 2    |
| 0x5000362C | DMA2_CTRL_REG         | Control register for the DMA channel 2   |
| 0x5000362E | DMA2_IDX_REG          | Index value of DMA channel 2             |
| 0x50003630 | DMA3_A_STARTL_R<br>EG | Start address Low A of DMA channel 3     |
| 0x50003632 | DMA3_A_STARTH_R<br>EG | Start address High A of DMA channel 3    |
| 0x50003634 | DMA3_B_STARTL_R<br>EG | Start address Low B of DMA channel 3     |



**Final** 

| Address    | Register               | Description                              |
|------------|------------------------|------------------------------------------|
| 0x50003636 | DMA3_B_STARTH_R<br>EG  | Start address High B of DMA channel 3    |
| 0x50003638 | DMA3_INT_REG           | DMA receive interrupt register channel 3 |
| 0x5000363A | DMA3_LEN_REG           | DMA receive length register channel 3    |
| 0x5000363C | DMA3_CTRL_REG          | Control register for the DMA channel 3   |
| 0x5000363E | DMA3_IDX_REG           | Index value of DMA channel 3             |
| 0x50003680 | DMA_REQ_MUX_RE<br>G    | DMA channel assignments                  |
| 0x50003682 | DMA_INT_STATUS_R<br>EG | DMA interrupt status register            |
| 0x50003684 | DMA_CLEAR_INT_RE<br>G  | DMA clear interrupt register             |

### Table 151: DMA0\_A\_STARTL\_REG (0x50003600)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA0_A_STARTL | Source start address, lower 16 bits | 0x0   |

### Table 152: DMA0\_A\_STARTH\_REG (0x50003602)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA0_A_STARTH | Source start address, upper 16 bits | 0x0   |

### Table 153: DMA0\_B\_STARTL\_REG (0x50003604)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA0_B_STARTL | Destination start address, lower 16 bits | 0x0   |

#### Table 154: DMA0\_B\_STARTH\_REG (0x50003606)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA0_B_STARTH | Destination start address, upper 16 bits | 0x0   |

### Table 155: DMA0\_INT\_REG (0x50003608)

| Bit  | Mode | Symbol   | Description                                                                                             | Reset |
|------|------|----------|---------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA0_INT | Number of transfers until an interrupt is generated.<br>The interrupt is generated after a transfer, if | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                              | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | DMAx_INT_REG is equal to DMAx_IDX_REG and before DMAx_IDX_REG is incremented. The bit-field IRQ_ENABLE of DMAx_CTRL_REG must be set to '1' to let the controller generate the interrupt. |       |

# Table 156: DMA0\_LEN\_REG (0x5000360A)

| Bit  | Mode | Symbol   | Description                                                                                                  | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA0_LEN | DMA channel's transfer length. DMAx_LEN of value 0, 1, 2, results into an actual transfer length of 1, 2, 3, | 0x0   |

# Table 157: DMA0\_CTRL\_REG (0x5000360C)

| Bit   | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                        | Reset |
|-------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:14 | R    | -         | Reserved                                                                                                                                                                                                                                                                                           | 0x0   |
| 13    | R/W  | REQ_SENSE | 0 = DMA operates with level-sensitive peripheral requests (default)                                                                                                                                                                                                                                | 0x0   |
|       |      |           | 1 = DMA operates with (positive) edge-sensitive peripheral requests                                                                                                                                                                                                                                |       |
| 12    | R/W  | DMA_INIT  | 0 = DMA performs copy A1 to B1, A2 to B2, etc                                                                                                                                                                                                                                                      | 0x0   |
|       |      |           | 1 = DMA performs copy of A1 to B1, B2, etc                                                                                                                                                                                                                                                         |       |
|       |      |           | This feature is useful for memory initialization to any value. Thus, BINC must be set to '1', while AINC is don't care, as only one fetch from A is done. This process cannot be interrupted by other DMA channels. It is also noted that DMA_INIT should not be used when DREQ_MODE='1'.          |       |
| 11    | R/W  | DMA_IDLE  | 0 = Blocking mode, the DMA performs a fast back-<br>to-back copy, disabling bus access for any bus<br>master with lower priority.                                                                                                                                                                  | 0x0   |
|       |      |           | 1 = Interrupting mode, the DMA inserts a wait cycle after each store allowing the CPU to steal cycles or cache to perform a burst read. If DREQ_MODE='1', DMA_IDLE is don't care.                                                                                                                  |       |
| 10:8  | R/W  | DMA_PRIO  | The priority level determines which DMA channel will be granted access for transferring data, in case more than one channels are active and request the bus at the same time. The greater the value, the higher the priority. In specific:                                                         | 0x0   |
|       |      |           | 000 = lowest priority                                                                                                                                                                                                                                                                              |       |
|       |      |           | 111 = highest priority                                                                                                                                                                                                                                                                             |       |
|       |      |           | If different channels with equal priority level values request the bus at the same time, an inherent priority mechanism is applied. According to this mechanism, if, for example, both the DMA0 and DMA1 channels have the same priority level, then DMA0 will first be granted access to the bus. |       |
| 7     | R/W  | CIRCULAR  | 0 = Normal mode. The DMA channel stops after having completed the transfer of length                                                                                                                                                                                                               | 0x0   |



**Final** 

| Bit | Mode | Symbol     | Description                                                                                                                                                                   | Reset |
|-----|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |            | determined by DMAx_LEN_REG. DMA_ON automatically deasserts when the transfer is completed.                                                                                    |       |
|     |      |            | 1 = Circular mode (applicable only if DREQ_MODE = '1'). In this mode, DMA_ON never deasserts, as the DMA channel automatically resets DMAx_IDX_REG and starts a new transfer. |       |
| 6   | R/W  | AINC       | Enable increment of source address.  0 = do not increment (source address stays the same during the transfer)                                                                 | 0x0   |
|     |      |            | 1 = increment according to the value of BW bit-field (by 1, when BW="00"; by 2, when BW="01"; by 4, when BW="10")                                                             |       |
| 5   | R/W  | BINC       | Enable increment of destination address.                                                                                                                                      | 0x0   |
|     |      |            | 0 = do not increment (destination address stays the same during the transfer)                                                                                                 |       |
|     |      |            | 1 = increment according to the value of BW bit-field (by 1, when BW="00"; by 2, when BW="01"; by 4, when BW="10")                                                             |       |
| 4   | R/W  | DREQ_MODE  | 0 = DMA channel starts immediately                                                                                                                                            | 0x0   |
|     |      |            | 1 = DMA channel must be triggered by peripheral<br>DMA request (see also the description of<br>DMA_REQ_MUX_REG)                                                               |       |
| 3   | R/W  | IRQ_ENABLE | 0 = disable interrupt on this channel 1 = enable interrupt on this channel                                                                                                    | 0x0   |
| 2:1 | R/W  | BW         | Bus transfer width:                                                                                                                                                           | 0x0   |
|     |      |            | 00 = 1 Byte (suggested for peripherals like UART and 8-bit SPI)                                                                                                               |       |
|     |      |            | 01 = 2 Bytes (suggested for peripherals like I2C and 16-bit SPI)                                                                                                              |       |
|     |      |            | 10 = 4 Bytes (suggested for Memory-to-Memory transfers)                                                                                                                       |       |
|     |      |            | 11 = Reserved                                                                                                                                                                 |       |
| 0   | R/W  | DMA_ON     | 0 = DMA channel is off, clocks are disabled                                                                                                                                   | 0x0   |
|     |      |            | 1 = DMA channel is enabled. This bit will be automatically cleared after the completion of a transfer, if circular mode is not enabled. In circular mode, this bit stays set  |       |

# Table 158: DMA0\_IDX\_REG (0x5000360E)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                      | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | DMA0_IDX | This (read-only) register determines the data items currently fetched by the DMA channel, during an on-going transfer. When the transfer is completed, the register is automatically reset to 0. | 0x0   |
|      |      |          | The DMA channel uses this register to form the source/destination address of the next DMA cycle, considering also AINC/BINC and BW.                                                              |       |



**Final** 

#### Table 159: **DMA1\_A\_STARTL\_REG** (0x50003610)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA1_A_STARTL | Source start address, lower 16 bits | 0x0   |

#### Table 160: DMA1\_A\_STARTH\_REG (0x50003612)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA1_A_STARTH | Source start address, upper 16 bits | 0x0   |

# Table 161: DMA1\_B\_STARTL\_REG (0x50003614)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA1_B_STARTL | Destination start address, lower 16 bits | 0x0   |

#### Table 162: DMA1\_B\_STARTH\_REG (0x50003616)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA1_B_STARTH | Destination start address, upper 16 bits | 0x0   |

### Table 163: DMA1\_INT\_REG (0x50003618)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                   | Reset |
|------|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA1_INT | Number of transfers until an interrupt is generated. The interrupt is generated after a transfer, if DMAx_INT_REG is equal to DMAx_IDX_REG and before DMAx_IDX_REG is incremented. The bit-field IRQ_ENABLE of DMAx_CTRL_REG must be set to '1' to let the controller generate the interrupt. | 0x0   |

### Table 164: DMA1\_LEN\_REG (0x5000361A)

| Bit  | Mode | Symbol   | Description                                                                                                  | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA1_LEN | DMA channel's transfer length. DMAx_LEN of value 0, 1, 2, results into an actual transfer length of 1, 2, 3, | 0x0   |

**Final** 

### Table 165: DMA1\_CTRL\_REG (0x5000361C)

| Bit   | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                | Reset |
|-------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:14 | R    | -         | Reserved                                                                                                                                                                                                                                                                                                                   | 0x0   |
| 13    | R/W  | REQ_SENSE | 0 = DMA operates with level-sensitive peripheral requests (default)                                                                                                                                                                                                                                                        | 0x0   |
|       |      |           | 1 = DMA operates with (positive) edge-sensitive peripheral requests                                                                                                                                                                                                                                                        |       |
| 12    | R/W  | DMA_INIT  | 0 = DMA performs copy A1 to B1, A2 to B2, and so on                                                                                                                                                                                                                                                                        | 0x0   |
|       |      |           | 1 = DMA performs copy of A1 to B1, B2, and so on                                                                                                                                                                                                                                                                           |       |
|       |      |           | This feature is useful for memory initialization to any value. Thus, BINC must be set to "1", while AINC is don't care, as only one fetch from A is done. This process cannot be interrupted by other DMA channels. It is also noted that DMA_INIT should not be used when DREQ_MODE= 1.                                   |       |
| 11    | R/W  | DMA_IDLE  | 0 = Blocking mode, the DMA performs a fast back-<br>to-back copy, disabling bus access for any bus<br>master with lower priority.                                                                                                                                                                                          | 0x0   |
|       |      |           | 1 = Interrupting mode, the DMA inserts a wait cycle after each store allowing the CPU to steal cycles or cache to perform a burst read. If DREQ_MODE= 1, DMA_IDLE is don't care.                                                                                                                                           |       |
| 10:8  | R/W  | DMA_PRIO  | The priority level determines which DMA channel will be granted access for transferring data, in case more than one channels are active and request the bus at the same time. The greater the value, the higher the priority. In specific:                                                                                 | 0x0   |
|       |      |           | 000 = lowest priority                                                                                                                                                                                                                                                                                                      |       |
|       |      |           | 111 = highest priority  If different channels with equal priority level values request the bus at the same time, an inherent priority mechanism is applied. According to this mechanism, if, for example, both the DMA0 and DMA1 channels have the same priority level, then DMA0 will first be granted access to the bus. |       |
| 7     | R/W  | CIRCULAR  | 0 = Normal mode. The DMA channel stops after having completed the transfer of length determined by DMAx_LEN_REG. DMA_ON automatically deasserts when the transfer is completed.  1 = Circular mode (applicable only if                                                                                                     | 0x0   |
|       |      |           | DREQ_MODE = 1). In this mode, DMA_ON never deasserts, as the DMA channel automatically resets DMAx_IDX_REG and starts a new transfer.                                                                                                                                                                                      |       |
| 6     | R/W  | AINC      | Enable increment of source address.                                                                                                                                                                                                                                                                                        | 0x0   |
|       |      |           | 0 = do not increment (source address stays the same during the transfer)                                                                                                                                                                                                                                                   |       |
|       |      |           | 1 = increment according to the value of BW bit-field (by 1, when BW="00"; by 2, when BW="01"; by 4, when BW="10")                                                                                                                                                                                                          |       |
| 5     | R/W  | BINC      | Enable increment of destination address.                                                                                                                                                                                                                                                                                   | 0x0   |
|       |      |           | 0 = do not increment (destination address stays the same during the transfer)                                                                                                                                                                                                                                              |       |



**Final** 

| Bit | Mode | Symbol     | Description                                                                                                                                                                                                                    | Reset |
|-----|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |            | 1 = increment according to the value of BW bit-field (by 1, when BW="00"; by 2, when BW="01"; by 4, when BW="10")                                                                                                              |       |
| 4   | R/W  | DREQ_MODE  | 0 = DMA channel starts immediately 1 = DMA channel must be triggered by peripheral DMA request (see also the description of DMA_REQ_MUX_REG)                                                                                   | 0x0   |
| 3   | R/W  | IRQ_ENABLE | <ul><li>0 = disable interrupt on this channel</li><li>1 = enable interrupt on this channel</li></ul>                                                                                                                           | 0x0   |
| 2:1 | R/W  | BW         | Bus transfer width:  00 = 1 Byte (suggested for peripherals like UART and 8-bit SPI)  01 = 2 Bytes (suggested for peripherals like I2C and 16-bit SPI)  10 = 4 Bytes (suggested for Memory-to-Memory transfers)  11 = Reserved | 0x0   |
| 0   | R/W  | DMA_ON     | 0 = DMA channel is off, clocks are disabled 1 = DMA channel is enabled. This bit will be automatically cleared after the completion of a transfer, if circular mode is not enabled. In circular mode, this bit stays set.      | 0x0   |

### Table 166: DMA1\_IDX\_REG (0x5000361E)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                      | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | DMA1_IDX | This (read-only) register determines the data items currently fetched by the DMA channel, during an on-going transfer. When the transfer is completed, the register is automatically reset to 0. | 0x0   |
|      |      |          | The DMA channel uses this register to form the source/destination address of the next DMA cycle, considering also AINC/BINC and BW.                                                              |       |

### Table 167: DMA2\_A\_STARTL\_REG (0x50003620)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA2_A_STARTL | Source start address, lower 16 bits | 0x0   |

# Table 168: DMA2\_A\_STARTH\_REG (0x50003622)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA2_A_STARTH | Source start address, upper 16 bits | 0x0   |

**Final** 

#### Table 169: DMA2\_B\_STARTL\_REG (0x50003624)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA2_B_STARTL | Destination start address, lower 16 bits | 0x0   |

#### Table 170: DMA2\_B\_STARTH\_REG (0x50003626)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA2_B_STARTH | Destination start address, upper 16 bits | 0x0   |

### Table 171: DMA2\_INT\_REG (0x50003628)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                   | Reset |
|------|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA2_INT | Number of transfers until an interrupt is generated. The interrupt is generated after a transfer, if DMAx_INT_REG is equal to DMAx_IDX_REG and before DMAx_IDX_REG is incremented. The bit-field IRQ_ENABLE of DMAx_CTRL_REG must be set to '1' to let the controller generate the interrupt. | 0x0   |

### Table 172: DMA2\_LEN\_REG (0x5000362A)

| Bit  | Mode | Symbol   | Description                                                                                                  | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA2_LEN | DMA channel's transfer length. DMAx_LEN of value 0, 1, 2, results into an actual transfer length of 1, 2, 3, | 0x0   |

## Table 173: DMA2\_CTRL\_REG (0x5000362C)

| Bit   | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                     | Reset |
|-------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:14 | R    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 13    | R/W  | REQ_SENSE | 0 = DMA operates with level-sensitive peripheral requests (default)     1 = DMA operates with (positive) edge-sensitive peripheral requests                                                                                                                                                                                                                                                     | 0x0   |
| 12    | R/W  | DMA_INIT  | 0 = DMA performs copy A1 to B1, A2 to B2, and so on  1 = DMA performs copy of A1 to B1, B2, and so on  This feature is useful for memory initialization to any value. Thus, BINC must be set to "1", while AINC is don't care, as only one fetch from A is done. This process cannot be interrupted by other DMA channels. It is also noted that DMA_INIT should not be used when DREQ_MODE= 1. | 0x0   |



Final

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                        | Reset |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 11   | R/W  | DMA_IDLE   | 0 = Blocking mode, the DMA performs a fast back-<br>to-back copy, disabling bus access for any bus<br>master with lower priority.                                                                                                                                                                  | 0x0   |
|      |      |            | 1 = Interrupting mode, the DMA inserts a wait cycle after each store allowing the CPU to steal cycles or cache to perform a burst read. If DREQ_MODE = 1, DMA_IDLE is don't care.                                                                                                                  |       |
| 10:8 | R/W  | DMA_PRIO   | The priority level determines which DMA channel will be granted access for transferring data, in case more than one channels are active and request the bus at the same time. The greater the value, the higher the priority. In specific:                                                         | 0x0   |
|      |      |            | 000 = lowest priority                                                                                                                                                                                                                                                                              |       |
|      |      |            | 111 = highest priority                                                                                                                                                                                                                                                                             |       |
|      |      |            | If different channels with equal priority level values request the bus at the same time, an inherent priority mechanism is applied. According to this mechanism, if, for example, both the DMA0 and DMA1 channels have the same priority level, then DMA0 will first be granted access to the bus. |       |
| 7    | R/W  | CIRCULAR   | 0 = Normal mode. The DMA channel stops after having completed the transfer of length determined by DMAx_LEN_REG. DMA_ON automatically deasserts when the transfer is completed.                                                                                                                    | 0x0   |
|      |      |            | 1 = Circular mode (applicable only if DREQ_MODE = 1). In this mode, DMA_ON never deasserts, as the DMA channel automatically resets DMAx_IDX_REG and starts a new transfer.                                                                                                                        |       |
| 6    | R/W  | AINC       | Enable increment of destination address.                                                                                                                                                                                                                                                           | 0x0   |
|      |      |            | 0 = do not increment (destination address stays the same during the transfer)                                                                                                                                                                                                                      |       |
|      |      |            | 1 = increment according to the value of BW bit-field (by 1, when BW="00"; by 2, when BW="01"; by 4, when BW="10")                                                                                                                                                                                  |       |
| 5    | R/W  | BINC       | Enable increment of destination address  0 = do not increment                                                                                                                                                                                                                                      | 0x0   |
|      |      |            | 1 = increment according value of BW                                                                                                                                                                                                                                                                |       |
| 4    | R/W  | DREQ_MODE  | 0 = DMA channel starts immediately                                                                                                                                                                                                                                                                 | 0x0   |
|      |      |            | 1 = DMA channel must be triggered by peripheral DMA request (see also the description of DMA_REQ_MUX_REG)                                                                                                                                                                                          |       |
| 3    | R/W  | IRQ_ENABLE | 0 = disable interrupt on this channel                                                                                                                                                                                                                                                              | 0x0   |
|      |      |            | 1 = enable interrupt on this channel                                                                                                                                                                                                                                                               |       |
| 2:1  | R/W  | BW         | Bus transfer width:                                                                                                                                                                                                                                                                                | 0x0   |
|      |      |            | 00 = 1 Byte (suggested for peripherals like UART and 8-bit SPI)                                                                                                                                                                                                                                    |       |
|      |      |            | 01 = 2 Bytes (suggested for peripherals like I2C and 16-bit SPI)                                                                                                                                                                                                                                   |       |
|      |      |            | 10 = 4 Bytes (suggested for Memory-to-Memory transfers)                                                                                                                                                                                                                                            |       |
|      |      |            | 11 = Reserved                                                                                                                                                                                                                                                                                      |       |
| 0    | R/W  | DMA_ON     | 0 = DMA channel is off, clocks are disabled                                                                                                                                                                                                                                                        | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                               | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | DMA channel is enabled. This bit will be automatically cleared after the completion of a transfer, if circular mode is not enabled. In circular mode, this bit stays set. |       |

### Table 174: DMA2\_IDX\_REG (0x5000362E)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | DMA2_IDX | This (read-only) register determines the data items currently fetched by the DMA channel, during an on-going transfer. When the transfer is completed, the register is automatically reset to 0.  The DMA channel uses this register to form the source/destination address of the next DMA cycle, considering also AINC/BINC and BW. | 0x0   |

#### Table 175: DMA3\_A\_STARTL\_REG (0x50003630)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA3_A_STARTL | Source start address, lower 16 bits | 0x0   |

#### Table 176: DMA3\_A\_STARTH\_REG (0x50003632)

| Bit  | Mode | Symbol        | Description                         | Reset |
|------|------|---------------|-------------------------------------|-------|
| 15:0 | R/W  | DMA3_A_STARTH | Source start address, upper 16 bits | 0x0   |

#### Table 177: DMA3\_B\_STARTL\_REG (0x50003634)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA3_B_STARTL | Destination start address, lower 16 bits | 0x0   |

#### Table 178: DMA3\_B\_STARTH\_REG (0x50003636)

| Bit  | Mode | Symbol        | Description                              | Reset |
|------|------|---------------|------------------------------------------|-------|
| 15:0 | R/W  | DMA3_B_STARTH | Destination start address, upper 16 bits | 0x0   |

**Final** 

## Table 179: DMA3\_INT\_REG (0x50003638)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                   | Reset |
|------|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA3_INT | Number of transfers until an interrupt is generated. The interrupt is generated after a transfer, if DMAx_INT_REG is equal to DMAx_IDX_REG and before DMAx_IDX_REG is incremented. The bit-field IRQ_ENABLE of DMAx_CTRL_REG must be set to "1" to let the controller generate the interrupt. | 0x0   |

## Table 180: DMA3\_LEN\_REG (0x5000363A)

| Bit  | Mode | Symbol   | Description                                                                                                  | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | DMA3_LEN | DMA channel's transfer length. DMAx_LEN of value 0, 1, 2, results into an actual transfer length of 1, 2, 3, | 0x0   |

### Table 181: DMA3\_CTRL\_REG (0x5000363C)

| Bit   | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|-------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:14 | R    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 13    | R/W  | REQ_SENSE | <ul> <li>0 = DMA operates with level-sensitive peripheral requests (default)</li> <li>1 = DMA operates with (positive) edge-sensitive peripheral requests</li> </ul>                                                                                                                                                                                                                              | 0x0   |
| 12    | R/W  | DMA_INIT  | 0 = DMA performs copy A1 to B1, A2 to B2, and so on  1 = DMA performs copy of A1 to B1, B2, and so on  This feature is useful for memory initialization to any value. Thus, BINC must be set to "1"', while AINC is don't care, as only one fetch from A is done. This process cannot be interrupted by other DMA channels. It is also noted that DMA_INIT should not be used when DREQ_MODE = 1. | 0x0   |
| 11    | R/W  | DMA_IDLE  | 0 = Blocking mode, the DMA performs a fast back-to-back copy, disabling bus access for any bus master with lower priority.  1 = Interrupting mode, the DMA inserts a wait cycle after each store allowing the CPU to steal cycles or cache to perform a burst read. If DREQ_MODE = 1, DMA_IDLE is don't care.                                                                                     | 0x0   |
| 10:8  | R/W  | DMA_PRIO  | The priority level determines which DMA channel will be granted access for transferring data, in case more than one channels are active and request the bus at the same time. The greater the value, the higher the priority. In specific:  000 = lowest priority  111 = highest priority                                                                                                         | 0x0   |



**Final** 

| Bit | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                  | Reset |
|-----|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |            | If different channels with equal priority level values request the bus at the same time, an inherent priority mechanism is applied. According to this mechanism, if, for example, both the DMA0 and DMA1 channels have the same priority level, then DMA0 will first be granted access to the bus.                                                           |       |
| 7   | R/W  | CIRCULAR   | 0 = Normal mode. The DMA channel stops after having completed the transfer of length determined by DMAx_LEN_REG. DMA_ON automatically deasserts when the transfer is completed.  1 = Circular mode (applicable only if DREQ_MODE = 1). In this mode, DMA_ON never deasserts, as the DMA channel automatically resets DMAx_IDX_REG and starts a new transfer. | 0x0   |
| 6   | R/W  | AINC       | Enable increment of source address.  0 = do not increment (source address stays the same during the transfer)  1 = increment according to the value of BW bitfield (by 1, when BW="00"; by 2, when BW="01"; by 4, when BW="10")                                                                                                                              | 0x0   |
| 5   | R/W  | BINC       | Enable increment of destination address.  0 = do not increment (destination address stays the same during the transfer)  1 = increment according to the value of BW bitfield (by 1, when BW="00"; by 2, when BW="01"; by 4, when BW="10")                                                                                                                    | 0x0   |
| 4   | R/W  | DREQ_MODE  | 0 = DMA channel starts immediately 1 = DMA channel must be triggered by peripheral DMA request (see also the description of DMA_REQ_MUX_REG)                                                                                                                                                                                                                 | 0x0   |
| 3   | R/W  | IRQ_ENABLE | 0 = disable interrupt on this channel 1 = enable interrupt on this channel                                                                                                                                                                                                                                                                                   | 0x0   |
| 2:1 | R/W  | BW         | Bus transfer width:  00 = 1 Byte (suggested for peripherals like UART and 8-bit SPI)  01 = 2 Bytes (suggested for peripherals like I2C and 16-bit SPI)  10 = 4 Bytes (suggested for Memory-to-Memory transfers)  11 = Reserved                                                                                                                               | 0x0   |
| 0   | R/W  | DMA_ON     | 0 = DMA channel is off, clocks are disabled 1 = DMA channel is enabled. This bit will be automatically cleared after the completion of a transfer, if circular mode is not enabled. In circular mode, this bit stays set                                                                                                                                     | 0x0   |

**Final** 

## Table 182: DMA3\_IDX\_REG (0x5000363E)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | DMA3_IDX | This (read-only) register determines the data items currently fetched by the DMA channel, during an on-going transfer. When the transfer is completed, the register is automatically reset to 0.  The DMA channel uses this register to form the source/destination address of the next DMA cycle, considering also AINC/BINC and BW. | 0x0   |

### Table 183: DMA\_REQ\_MUX\_REG (0x50003680)

| Bit   | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset |
|-------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:12 | R/W  | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0xF   |
| 11:8  | R/W  | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0xF   |
| 7:4   | R/W  | DMA23_SEL | Select which combination of peripherals are mapped on the DMA channels. The peripherals are mapped as pairs on two channels.  Hence, the first DMA request (peripheral-to-memory) is mapped on channel 2 and the second (memory-to-peripheral) on channel 3.  See also the description of DMA01_SEL bit-field of this register for the supported peripherals.                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0xF   |
| 3:0   | R/W  | DMA01_SEL | Select which combination of peripherals are mapped on the DMA channels. The peripherals are mapped as pairs on two channels.  Hence, the first DMA request (peripheral-to-memory) is mapped on channel 0 and the second (memory-to-peripheral) on channel 1.  0x0: SPI_rx / SPI_tx  0x1: Reserved  0x2: UART_rx / UART_tx  0x3: UART2_rx / UART2_tx  0x4: I2C_rx / I2C_tx  0x5: GP_ADC (Rx only)  0x6-0xE: Reserved  0xF: None  Note: If any of the two available peripheral selector fields (DMA01_SEL, DMA23_SEL) have the same value, the lesser significant selector has higher priority and will control the dma acknowledge. Hence, if DMA01_SEL = DMA23_SEL, the channels 0 and 1 will generate the DMA acknowledge signals for the selected peripheral. Consequently, it is suggested to assign | 0xF   |

**Final** 

### Table 184: DMA\_INT\_STATUS\_REG (0x50003682)

| Bit  | Mode | Symbol      | Description                                                  | Reset |
|------|------|-------------|--------------------------------------------------------------|-------|
| 15:8 | R    | -           | Reserved                                                     | 0x0   |
| 7    | R    | -           | Reserved                                                     | 0x0   |
| 6    | R    | -           | Reserved                                                     | 0x0   |
| 5    | R    | -           | Reserved                                                     | 0x0   |
| 4    | R    | -           | Reserved                                                     | 0x0   |
| 3    | R    | DMA_IRQ_CH3 | 0: IRQ on channel 3 is not set 1: IRQ on channel 3 is set    | 0x0   |
| 2    | R    | DMA_IRQ_CH2 | 0: IRQ on channel 2 is not set 1: IRQ on channel 2 is set    | 0x0   |
| 1    | R    | DMA_IRQ_CH1 | 0: IRQ on channel 1 is not set<br>1: IRQ on channel 1 is set | 0x0   |
| 0    | R    | DMA_IRQ_CH0 | 0: IRQ on channel 0 is not set 1: IRQ on channel 0 is set    | 0x0   |

## Table 185: DMA\_CLEAR\_INT\_REG (0x50003684)

| Bit  | Mode | Symbol              | Description                                                                                                | Reset |
|------|------|---------------------|------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | R    | -                   | Reserved                                                                                                   | 0x0   |
| 7    | R    | -                   | Reserved                                                                                                   | 0x0   |
| 6    | R    | -                   | Reserved                                                                                                   | 0x0   |
| 5    | R    | -                   | Reserved                                                                                                   | 0x0   |
| 4    | R    | -                   | Reserved                                                                                                   | 0x0   |
| 3    | R0/W | DMA_RST_IRQ_CH      | Writing a 1 will reset the status bit of DMA_INT_STATUS_REG for channel 3; writing a 0 will have no effect | 0x0   |
| 2    | R0/W | DMA_RST_IRQ_CH      | Writing a 1 will reset the status bit of DMA_INT_STATUS_REG for channel 2; writing a 0 will have no effect | 0x0   |
| 1    | R0/W | DMA_RST_IRQ_CH<br>1 | Writing a 1 will reset the status bit of DMA_INT_STATUS_REG for channel 1; writing a 0 will have no effect | 0x0   |
| 0    | R0/W | DMA_RST_IRQ_CH<br>0 | Writing a 1 will reset the status bit of DMA_INT_STATUS_REG for channel 0; writing a 0 will have no effect | 0x0   |

# 32.6 General Purpose ADC Registers

## Table 186: Register map GPADC

| Address    | Register        | Description                          |
|------------|-----------------|--------------------------------------|
| 0x50001500 | GP_ADC_CTRL_REG | General Purpose ADC Control Register |



**Final** 

| Address    | Register                 | Description                                  |
|------------|--------------------------|----------------------------------------------|
| 0x50001502 | GP_ADC_CTRL2_RE<br>G     | General Purpose ADC Second Control Register  |
| 0x50001504 | GP_ADC_CTRL3_RE<br>G     | General Purpose ADC Third Control Register   |
| 0x50001506 | GP_ADC_SEL_REG           | General Purpose ADC Input Selection Register |
| 0x50001508 | GP_ADC_OFFP_REG          | General Purpose ADC Positive Offset Register |
| 0x5000150A | GP_ADC_OFFN_REG          | General Purpose ADC Negative Offset Register |
| 0x5000150C | GP_ADC_TRIM_REG          | General Purpose ADC Trim Register            |
| 0x5000150E | GP_ADC_CLEAR_INT<br>_REG | General Purpose ADC Clear Interrupt Register |
| 0x50001510 | GP_ADC_RESULT_R<br>EG    | General Purpose ADC Result Register          |

### Table 187: GP\_ADC\_CTRL\_REG (0x50001500)

| Bit | Mode | Symbol        | Description                                                                                                                                                                             | Reset |
|-----|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 12  | R/W  | DIE_TEMP_EN   | Enables the die-temperature sensor. Output can be measured on GPADC input 4.                                                                                                            | 0x0   |
| 11  | R/W  | -             | Reserved                                                                                                                                                                                | 0x0   |
| 10  | R/W  | GP_ADC_LDO_HO | GPADC LDO tracking bandgap reference     GPADC LDO hold sampled bandgap reference                                                                                                       | 0x0   |
| 9   | R/W  | GP_ADC_CHOP   | Chopper mode off     Chopper mode enabled. Takes two samples with opposite GP_ADC_SIGN to cancel the internal offset voltage of the ADC; Highly recommended for DC-measurements.        | 0x0   |
| 8   | R/W  | GP_ADC_SIGN   | Default     Conversion with opposite sign at input and output to cancel out the internal offset of the ADC and low-frequency                                                            | 0x0   |
| 7   | R/W  | GP_ADC_MUTE   | O: Normal operation  1: Mute ADC input. Takes sample at mid-scale (to dertermine the internal offset and/or noise of the ADC with regards to VDD_REF which is also sampled by the ADC). | 0x0   |
| 6   | R/W  | GP_ADC_SE     | Differential mode     Single ended mode                                                                                                                                                 | 0x0   |
| 5   | R/W  | GP_ADC_MINT   | 0: Disable (mask) GP_ADC_INT. 1: Enable GP_ADC_INT to ICU.                                                                                                                              | 0x0   |
| 4   | R    | GP_ADC_INT    | AD conversion ready and has generated an interrupt. Must be cleared by writing any value to GP_ADC_CLEAR_INT_REG.                                                                       | 0x0   |
| 3   | R/W  | GP_ADC_DMA_EN | DMA functionality disabled     DMA functionality enabled                                                                                                                                | 0x0   |
| 2   | R/W  | GP_ADC_CONT   | Manual ADC mode, a single result will be generated after setting the GP_ADC_START bit.                                                                                                  | 0x0   |



**Final** 

| Bit | Mode | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset |
|-----|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |              | 1: Continuous ADC mode, new ADC results will be constantly stored in GP_ADC_RESULT_REG. Still GP_ADC_START has to be set to start the execution. The time between conversions is configurable with GP_ADC_INTERVAL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |
| 1   | R/W  | GP_ADC_START | O: ADC conversion ready.  1: If a 1 is written, the ADC starts a conversion.  After the conversion this bit will be set to 0 and the GP_ADC_INT bit will be set. It is not allowed to write this bit while it is not (yet) zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 0   | R/W  | GP_ADC_EN    | Use the original of the original orig | 0x0   |

## Table 188: GP\_ADC\_CTRL2\_REG (0x50001502)

| Bit   | Mode | Symbol                | Description                                                                                                                                                                                                                                            | Reset |
|-------|------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:13 | R/W  | GP_ADC_STORE_<br>DEL  | Data is stored after handshake synchronisation     Data is stored 2 ADC_CLK cycles after internal start trigger     Data is stored 8 ADC_CLK cycles after internal start trigger                                                                       | 0x0   |
| 12:9  | R/W  | GP_ADC_SMPL_TI<br>ME  | 0: The sample time (switch is closed) is two ADC_CLK cycles 1: The sample time is 1*8 ADC_CLK cycles 2: The sample time is 2*8 ADC_CLK cycles 15: The sample time is 15*8 ADC_CLK cycles                                                               | 0x1   |
| 8:6   | R/W  | GP_ADC_CONV_N<br>RS   | 0: 1 sample is taken or 2 in case ADC_CHOP is active.  1: 2 samples are taken.  2: 4 samples are taken.  7: 128 samples are taken.                                                                                                                     | 0x0   |
| 5:4   | R/W  | GP_ADC_OFFS_S<br>H_CM | Common mode adjust for offset shifter. Input range is CM +/- 450 mV.  0: CM = 1.25 V (Input range 0.80 - 1.70)  1: CM = 1.30 V (Input range 0.85 - 1.75) (default)  2: CM = 1.35 V (Input range 0.90 - 1.80)  3: CM = 1.40 V (input range 0.95 - 1.85) | 0x1   |
| 3     | R/W  | GP_ADC_OFFS_S<br>H_EN | 0: Disable input shifter 1: Enable input shifter (900 mV - 1800 mV shifted to 0 mV - 900 mV)                                                                                                                                                           | 0x0   |
| 2     | R/W  | GP_ADC_I20U           | 1: Adds 20 uA constant load current at the ADC LDO to minimize ripple on the reference voltage of the ADC.                                                                                                                                             | 0x0   |
| 1:0   | R/W  | GP_ADC_ATTN           | 0: No attenuator (input voltages up to 0.9 V allowed) 1: Enabling 2x attenuator (input voltages up to 1.8 V allowed)                                                                                                                                   | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                    | Reset |
|-----|------|--------|----------------------------------------------------------------|-------|
|     |      |        | 2: Enabling 3x attenuator (input voltages up to 2.7 V allowed) |       |
|     |      |        | 3: Enabling 4x attenuator (input voltages up to 3.6 V allowed) |       |
|     |      |        | Enabling the attenuator requires a longer sampling time.       |       |

### Table 189: GP\_ADC\_CTRL3\_REG (0x50001504)

| Bit  | Mode | Symbol              | Description                                                                  | Reset |
|------|------|---------------------|------------------------------------------------------------------------------|-------|
| 15:8 | R/W  | GP_ADC_INTERVA<br>L | Defines the interval between two ADC conversions in case GP_ADC_CONT is set. | 0x0   |
|      |      |                     | 0: No extra delay between two conversions.                                   |       |
|      |      |                     | 1: 1.024 ms interval between two conversions.                                |       |
|      |      |                     | 2: 2.048 ms interval between two conversions.                                |       |
|      |      |                     | 255: 261.12 ms interval between two conversions.                             |       |
| 7:0  | R/W  | GP_ADC_EN_DEL       | Defines the delay for enabling the ADC after enabling the LDO.               | 0x40  |
|      |      |                     | 0: Not allowed                                                               |       |
|      |      |                     | 1: 4x ADC_CLK period.                                                        |       |
|      |      |                     | n: n*4x ADC_CLK period.                                                      |       |

## Table 190: GP\_ADC\_OFFP\_REG (0x50001508)

| Bit | Mode | Symbol      | Description                                                                                                                        | Reset |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9:0 | R/W  | GP_ADC_OFFP | Offset adjust of 'positive' array of ADC-network (effective if "GP_ADC_SE=0", or "GP_ADC_SE=1 AND GP_ADC_SIGN=0 OR GP_ADC_CHOP=1") | 0x200 |

### Table 191: **GP\_ADC\_OFFN\_REG** (0x5000150A)

| Bit | Mode | Symbol      | Description                                                                                                                        | Reset |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9:0 | R/W  | GP_ADC_OFFN | Offset adjust of 'negative' array of ADC-network (effective if "GP_ADC_SE=0", or "GP_ADC_SE=1 AND GP_ADC_SIGN=1 OR GP_ADC_CHOP=1") | 0x200 |

## Table 192: **GP\_ADC\_TRIM\_REG** (0x5000150C)

| Bit | Mode | Symbol         | Description     | Reset |
|-----|------|----------------|-----------------|-------|
| 6:4 | R/W  | GP_ADC_LDO_LEV | GPADC LDO level | 0x3   |
|     |      | EL             | 0: 825 mV       |       |
|     |      |                | 1: 850 mV       |       |
|     |      |                | 2: 875 mV       |       |



**Final** 

| Bit | Mode | Symbol                  | Description                                                  | Reset |
|-----|------|-------------------------|--------------------------------------------------------------|-------|
|     |      |                         | 3: 900 mV (reset)                                            |       |
|     |      |                         | 4: 925 mV (default)                                          |       |
|     |      |                         | 5: 950 mV                                                    |       |
|     |      |                         | 6: 975 mV                                                    |       |
|     |      |                         | 7:1000 mV                                                    |       |
| 3:0 | R/W  | GP_ADC_OFFS_S<br>H_VREF | Offset Shifter common-mode reference fine trimming: 2 mV/LSB | 0x8   |
|     |      |                         | Default = mid-scale at 1000                                  |       |

### Table 193: GP\_ADC\_CLEAR\_INT\_REG (0x5000150E)

| Bit  | Mode | Symbol         | Description                                                                             | Reset |
|------|------|----------------|-----------------------------------------------------------------------------------------|-------|
| 15:0 | R0/W | GP_ADC_CLR_INT | Writing any value to this register will clear the ADC_INT interrupt. Reading returns 0. | 0x0   |

## Table 194: GP\_ADC\_RESULT\_REG (0x50001510)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                    | Reset |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | GP_ADC_VAL | Returns the 10 up to 16 bits linear value of the last AD conversion. The upper 10 bits are always valid, the lower 6 bits are only valid in case oversampling has been applied. Two samples results in one extra bit and 64 samples results in six extra bits. | 0x0   |

### Table 195: GP\_ADC\_SEL\_REG (0x50001506)

| Bit | Mode | Symbol       | Description                                                                                                                                                  | Reset |
|-----|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R/W  | -            | Reserved                                                                                                                                                     | 0x0   |
| 6:4 | R/W  | GP_ADC_SEL_P | ADC positive input selection.  0: ADC0 (P0[1])  1: ADC1 (P0[2])  2: ADC2 (P0[6])  3: ADC3 (P0[7])  4: Temperature Sensor  5: VBAT_HIGH  6: VBAT_LOW  7: VDDD | 0x0   |
| 3   | R/W  | -            | Reserved                                                                                                                                                     | 0x0   |
| 2:0 | R/W  | GP_ADC_SEL_N | ADC negative input selection. Differential only (GP_ADC_SE=0). 0: ADC0 (P0[1]) 1: ADC1 (P0[2])                                                               | 0x0   |



Final

| Bit | Mode | Symbol | Description                          | Reset |
|-----|------|--------|--------------------------------------|-------|
|     |      |        | 2: ADC2 (P0[6])                      |       |
|     |      |        | 3: ADC3 (P0[7])                      |       |
|     |      |        | All other combinations are reserved. |       |

**Final** 

## 32.7 General Purpose I/O Registers

## Table 196: Register map GPIO

| Address    | Register              | Description                           |
|------------|-----------------------|---------------------------------------|
| 0x50003000 | P0_DATA_REG           | P0 Data input/output Register         |
| 0x50003002 | P0_SET_DATA_REG       | P0 Set port pins Register             |
| 0x50003004 | P0_RESET_DATA_RE<br>G | P0 Reset port pins Register           |
| 0x50003006 | P00_MODE_REG          | P00 Mode Register                     |
| 0x50003008 | P01_MODE_REG          | P01 Mode Register                     |
| 0x5000300A | P02_MODE_REG          | P02 Mode Register                     |
| 0x5000300C | P03_MODE_REG          | P03 Mode Register                     |
| 0x5000300E | P04_MODE_REG          | P04 Mode Register                     |
| 0x50003010 | P05_MODE_REG          | P05 Mode Register                     |
| 0x50003012 | P06_MODE_REG          | P06 Mode Register                     |
| 0x50003014 | P07_MODE_REG          | P07 Mode Register                     |
| 0x50003016 | P08_MODE_REG          | P08 Mode Register                     |
| 0x50003018 | P09_MODE_REG          | P09 Mode Register                     |
| 0x5000301A | P010_MODE_REG         | P010 Mode Register                    |
| 0x5000301C | P011_MODE_REG         | P011 Mode Register                    |
| 0x5000301E | PAD_WEAK_CTRL_R<br>EG | Pad driving strength control Register |

### Table 197: P0\_DATA\_REG (0x50003000)

| Bit   | Mode | Symbol  | Description                                                                  | Reset |
|-------|------|---------|------------------------------------------------------------------------------|-------|
| 15:12 | -    | -       | Reserved                                                                     | 0x0   |
| 11:0  | R/W  | P0_DATA | Sets P0 output register when written; Returns the value of P0 port when read | 0x0   |

## Table 198: P0\_SET\_DATA\_REG (0x50003002)

| Bit   | Mode | Symbol | Description                                                                     | Reset |
|-------|------|--------|---------------------------------------------------------------------------------|-------|
| 15:12 | -    | -      | Reserved                                                                        | 0x0   |
| 11:0  | R0/W | P0_SET | Writing a 1 to P0[x] sets P0[x] to 1. Writing 0 is discarded, reading returns 0 | 0x0   |



**Final** 

## Table 199: P0\_RESET\_DATA\_REG (0x50003004)

| Bit   | Mode | Symbol   | Description                                                                    | Reset |
|-------|------|----------|--------------------------------------------------------------------------------|-------|
| 15:12 | -    | -        | Reserved                                                                       | 0x0   |
| 11:0  | R0/W | P0_RESET | Writing a 1 to P0[x] sets P0[x] to 0 Writing 0 is discarded, reading returns 0 | 0x0   |

### Table 200: P00\_MODE\_REG (0x50003006)

| Bit   | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset |
|-------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected In ADC mode, these bits are don't care                                                                                                                                                                                                                                                                                                                                    | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| 4:0   | R/W  | PID    | Function of port  0 = GPIO (pin direction determined by "PUPD" field)  1 = UART1_RX  2 = UART1_TX  3 = UART2_RX  4 = UART2_TX  5 = SYS_CLK  6 = LP_CLK  7 = Reserved  8 = Reserved  9 = I2C_SCL  10 = I2C_SDA  11 = PWM5  12 = PWM6  13 = PWM7  14 = Reserved  15 = ADC (only for P0_1, P0_2, P0_6 and P0_7)  16 = PWM0  17 = PWM1  18 = BLE_DIAG (signals mapped to P0[3:0] are also mapped to P0[11:8])  19 = UART1_CTSN  20 = UART1_RTSN  21 = Reserved  22 = Reserved  23 = PWM2  24 = PWM3  25 = PWM4 | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                              | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | 27 = SPI_DO                                                                                                                              |       |
|     |      |        | 28 = SPI_CLK                                                                                                                             |       |
|     |      |        | 29 = SPI_CSN0                                                                                                                            |       |
|     |      |        | 30 = SPI_CSN1                                                                                                                            |       |
|     |      |        | 31 = Reserved                                                                                                                            |       |
|     |      |        | Note: When a certain input function (like SPI_DI) is selected on more than 1 pins, the pin of the lowest index has the highest priority. |       |

### Table 201: P01\_MODE\_REG (0x50003008)

| Bit   | Mode | Symbol | Description                                                                                                                                                             | Reset |
|-------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                                                                | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected In ADC mode, these bits are don't care | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                                                                | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                                                                   | 0x0   |

### Table 202: P02\_MODE\_REG (0x5000300A)

| Bit   | Mode | Symbol | Description                                                                                                                                                             | Reset |
|-------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                                                                | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected In ADC mode, these bits are don't care | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                                                                | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                                                                   | 0x0   |

## Table 203: P03\_MODE\_REG (0x5000300C)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |



**Final** 

| Bit | Mode | Symbol | Description                            | Reset |
|-----|------|--------|----------------------------------------|-------|
|     |      |        | In ADC mode, these bits are don't care |       |
| 7:5 | -    | -      | Reserved                               | 0x0   |
| 4:0 | R/W  | PID    | See P00_MODE_REG[PID]                  | 0x0   |

## Table 204: P04\_MODE\_REG (0x5000300E)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                         | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                            | 0x0   |

## Table 205: P05\_MODE\_REG (0x50003010)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                         | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                            | 0x0   |

## Table 206: P06\_MODE\_REG (0x50003012)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                         | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                            | 0x0   |

**Final** 

## Table 207: P07\_MODE\_REG (0x50003014)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                         | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                            | 0x0   |

### Table 208: P08\_MODE\_REG (0x50003016)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                         | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                            | 0x0   |

### Table 209: P09\_MODE\_REG (0x50003018)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                         | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                            | 0x0   |

#### Table 210: P010\_MODE\_REG (0x5000301A)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |



**Final** 

| Bit | Mode | Symbol | Description           | Reset |
|-----|------|--------|-----------------------|-------|
| 7:5 | -    | -      | Reserved              | 0x0   |
| 4:0 | R/W  | PID    | See P00_MODE_REG[PID] | 0x0   |

## Table 211: P011\_MODE\_REG (0x5000301C)

| Bit   | Mode | Symbol | Description                                                                                                                      | Reset |
|-------|------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                         | 0x0   |
| 9:8   | R/W  | PUPD   | 00 = Input, no resistors selected 01 = Input, pull-up selected 10 = Input, pull-down selected 11 = Output, no resistors selected | 0x2   |
| 7:5   | -    | -      | Reserved                                                                                                                         | 0x0   |
| 4:0   | R/W  | PID    | See P00_MODE_REG[PID]                                                                                                            | 0x0   |

### Table 212: PAD\_WEAK\_CTRL\_REG (0x5000301E)

| Bit   | Mode | Symbol      | Description                                                                                                                  | Reset |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:12 | -    | -           | Reserved                                                                                                                     | 0x0   |
| 11:0  | R/W  | PAD_LOW_DRV | 0 = Normal operation 1 = Reduces the driving strength of P0_x pad. Bit x controls the driving strength of P0_x, x=0, 1,, 11. | 0x0   |

**Final** 

## **32.8 General Purpose Registers**

### **Table 213: Register map GPREG**

| Address    | Register             | Description                                          |
|------------|----------------------|------------------------------------------------------|
| 0x50003300 | SET_FREEZE_REG       | Controls freezing of various timers/counters.        |
| 0x50003302 | RESET_FREEZE_RE<br>G | Controls unfreezing of various timers/counters.      |
| 0x50003304 | DEBUG_REG            | Various debug information register.                  |
| 0x50003306 | GP_STATUS_REG        | General purpose system status register.              |
| 0x50003308 | GP_CONTROL_REG       | General purpose system control register.             |
| 0x5000330A | BLE_TIMER_REG        | BLE FINECNT sampled value while in deep sleep state. |

## Table 214: **SET\_FREEZE\_REG** (0x50003300)

| Bit  | Mode | Symbol      | Description                                                                                                            | Reset |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|-------|
| 15:5 | -    | -           | Reserved                                                                                                               | 0x0   |
| 4    | R/W  | FRZ_DMA     | If 1, the DMA is frozen, 0 is discarded.                                                                               | 0x0   |
| 3    | R/W  | FRZ_WDOG    | If 1, the watchdog timer is frozen, 0 is discarded. WATCHDOG_CTRL_REG[NMI_RST] must be 0 to allow the freeze function. | 0x0   |
| 2    | R/W  | FRZ_BLETIM  | If 1, the BLE master clock is frozen, 0 is discarded.                                                                  | 0x0   |
| 1    | R/W  | FRZ_SWTIM   | If 1, the SW Timer (TIMER0) is frozen, 0 is discarded.                                                                 | 0x0   |
| 0    | R/W  | FRZ_WKUPTIM | If 1, the Wake Up Timer is frozen, 0 is discarded.                                                                     | 0x0   |

### Table 215: RESET\_FREEZE\_REG (0x50003302)

| Bit  | Mode | Symbol      | Description                                               | Reset |
|------|------|-------------|-----------------------------------------------------------|-------|
| 15:5 | -    | -           | Reserved                                                  | 0x0   |
| 4    | R/W  | FRZ_DMA     | If 1, the DMA continues, 0 is discarded.                  | 0x0   |
| 3    | R/W  | FRZ_WDOG    | If 1, the watchdog timer continues, 0 is discarded.       | 0x0   |
| 2    | R/W  | FRZ_BLETIM  | If 1, the the BLE master clock continues, 0 is discarded. | 0x0   |
| 1    | R/W  | FRZ_SWTIM   | If 1, the SW Timer (TIMER0) continues, 0 is discarded.    | 0x0   |
| 0    | R/W  | FRZ_WKUPTIM | If 1, the Wake Up Timer continues, 0 is discarded.        | 0x0   |

**Final** 

### Table 216: **DEBUG\_REG** (0x50003304)

| Bit  | Mode | Symbol               | Description                                                                                                                                                                                                       | Reset |
|------|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | R/W  | -                    | Reserved                                                                                                                                                                                                          | 0x0   |
| 0    | R/W  | DEBUGS_FREEZE<br>_EN | Default 1, freezing of the on-chip timers is enabled when the Cortex is halted in DEBUG State.                                                                                                                    | 0x1   |
|      |      |                      | If 0, freezing of the on-chip timers is depending on FREEZE_REG when the Cortex is halted in DEBUG State except the watchdog timer. The watchdog timer is always frozen when the Cortex is halted in DEBUG State. |       |

### Table 217: **GP\_STATUS\_REG** (0x50003306)

| Bit  | Mode | Symbol    | Description                                                                                                                             | Reset |
|------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:2 | -    | -         | Reserved                                                                                                                                | 0x0   |
| 1    | R/W  | -         | Reserved                                                                                                                                | 0x0   |
| 0    | R/W  | CAL_PHASE | If 1, it designates that the chip is in Calibration Phase that is the OTP has been initially programmed but no Calibration has occured. | 0x0   |

### Table 218: **GP\_CONTROL\_REG** (0x50003308)

| Bit  | Mode | Symbol                  | Description                                                                                                                                          | Reset |
|------|------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:7 | -    | -                       | Reserved                                                                                                                                             | 0x0   |
| 6:5  | R/W  | BLE_TIMER_DATA<br>_CTRL | See BLE_TIMER_REG.                                                                                                                                   | 0x0   |
| 4    | R/W  | CPU_DMA_BUS_P<br>RIO    | Controls the CPU DMA system bus priority: If 0, the CPU has highest priority. If 1, the DMA has highest priority.                                    | 0x0   |
| 3    | -    | -                       | Reserved                                                                                                                                             | 0x0   |
| 2    | R    | BLE_WAKEUP_LP_<br>IRQ   | The current value of the BLE_WAKEUP_LP_IRQ interrupt request.                                                                                        | 0x0   |
| 1    | -    | -                       | Reserved                                                                                                                                             | 0x0   |
| 0    | R/W  | BLE_WAKEUP_RE<br>Q      | If 1, the BLE wakes up. Must be kept high at least for 1 low power clock period.                                                                     | 0x0   |
|      |      |                         | If the BLE is in deep sleep state, then by setting this bit it will cause the wake-up LP IRQ to be asserted with a delay of 3 to 4 low power cycles. |       |

### Table 219: BLE\_TIMER\_REG (0x5000330A)

| Bit   | Mode | Symbol | Description | Reset |
|-------|------|--------|-------------|-------|
| 15:10 | -    | -      | Reserved    | 0x0   |



Final

| Bit | Mode | Symbol         | Description                                                                                                                                                                                                                                         | Reset |
|-----|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 9:0 | R/W  | BLE_TIMER_DATA | Operation depends on GP_CONTROL_REG->BLE_TIMER_DATA_CTRL.                                                                                                                                                                                           | 0x0   |
|     |      |                | If BLE_TIMER_DATA_CTRL = 0 then:                                                                                                                                                                                                                    |       |
|     |      |                | This register is located at the Always On Power Domain and it holds the automatically sampled value of the BLE FINECNT timer                                                                                                                        |       |
|     |      |                | The HW automatically samples the value into this register during the sequence of "BLE Sleep On" and restores automatically the value during the BLE Wake up sequence.                                                                               |       |
|     |      |                | The Software may read and modify the value while the BLE is in Sleep state. While the BLE is awake, the value of the register has no meaning, while changing the value by writing another one will have no effect in the operation of the BLE core. |       |
|     |      |                | There is a constraint when the SW performs an write-read sequence where it has to inject a one cycle delay in between (e.g. write-NOP-read) in order to read back the correct value.                                                                |       |
|     |      |                | If BLE_TIMER_DATA_CTRL is non 0 then write operations have the same effect as when BLE_TIMER_DATA_CTRL=0, while for read operations:                                                                                                                |       |
|     |      |                | BLE_TIMER_DATA_CTRL= 1: then reading BLE_TIMER_REG returns "deepsldur[9:0]".                                                                                                                                                                        |       |
|     |      |                | BLE_TIMER_DATA_CTRL= 2: then reading BLE_TIMER_REG returns "deepsltime_samp[9:0]".                                                                                                                                                                  |       |
|     |      |                | BLE_TIMER_DATA_CTRL= 3: then reading BLE_TIMER_REG returns "{deep_sleep_stat_monitor, deepsltime_samp[18:10]}.                                                                                                                                      |       |
|     |      |                |                                                                                                                                                                                                                                                     |       |

**Final** 

# 32.9 I2C Interface Registers

## Table 220: Register map I2C

| Address    | Register                  | Description                                      |
|------------|---------------------------|--------------------------------------------------|
| 0x50001300 | I2C_CON_REG               | I2C Control Register                             |
| 0x50001304 | I2C_TAR_REG               | I2C Target Address Register                      |
| 0x50001308 | I2C_SAR_REG               | I2C Slave Address Register                       |
| 0x50001310 | I2C_DATA_CMD_RE<br>G      | I2C Rx/Tx Data Buffer and Command Register       |
| 0x50001314 | I2C_SS_SCL_HCNT_<br>REG   | Standard Speed I2C Clock SCL High Count Register |
| 0x50001318 | I2C_SS_SCL_LCNT_<br>REG   | Standard Speed I2C Clock SCL Low Count Register  |
| 0x5000131C | I2C_FS_SCL_HCNT_<br>REG   | Fast Speed I2C Clock SCL High Count Register     |
| 0x50001320 | I2C_FS_SCL_LCNT_<br>REG   | Fast Speed I2C Clock SCL Low Count Register      |
| 0x5000132C | I2C_INTR_STAT_REG         | I2C Interrupt Status Register                    |
| 0x50001330 | I2C_INTR_MASK_RE<br>G     | I2C Interrupt Mask Register                      |
| 0x50001334 | I2C_RAW_INTR_STA<br>T_REG | I2C Raw Interrupt Status Register                |
| 0x50001338 | I2C_RX_TL_REG             | I2C Receive FIFO Threshold Register              |
| 0x5000133C | I2C_TX_TL_REG             | I2C Transmit FIFO Threshold Register             |
| 0x50001340 | I2C_CLR_INTR_REG          | Clear Combined and Individual Interrupt Register |
| 0x50001344 | I2C_CLR_RX_UNDER<br>_REG  | Clear RX_UNDER Interrupt Register                |
| 0x50001348 | I2C_CLR_RX_OVER_<br>REG   | Clear RX_OVER Interrupt Register                 |
| 0x5000134C | I2C_CLR_TX_OVER_<br>REG   | Clear TX_OVER Interrupt Register                 |
| 0x50001350 | I2C_CLR_RD_REQ_R<br>EG    | Clear RD_REQ Interrupt Register                  |
| 0x50001354 | I2C_CLR_TX_ABRT_<br>REG   | Clear TX_ABRT Interrupt Register                 |
| 0x50001358 | I2C_CLR_RX_DONE_<br>REG   | Clear RX_DONE Interrupt Register                 |
| 0x5000135C | I2C_CLR_ACTIVITY_<br>REG  | Clear ACTIVITY Interrupt Register                |
| 0x50001360 | I2C_CLR_STOP_DET _REG     | Clear STOP_DET Interrupt Register                |
| 0x50001364 | I2C_CLR_START_DE<br>T_REG | Clear START_DET Interrupt Register               |
| 0x50001368 | I2C_CLR_GEN_CALL<br>_REG  | Clear GEN_CALL Interrupt Register                |
| 0x5000136C | I2C_ENABLE_REG            | I2C Enable Register                              |



**Final** 

| Address    | Register                     | Description                                |
|------------|------------------------------|--------------------------------------------|
| 0x50001370 | I2C_STATUS_REG               | I2C Status Register                        |
| 0x50001374 | I2C_TXFLR_REG                | I2C Transmit FIFO Level Register           |
| 0x50001378 | I2C_RXFLR_REG                | I2C Receive FIFO Level Register            |
| 0x5000137C | I2C_SDA_HOLD_REG             | I2C SDA Hold Time Length Register          |
| 0x50001380 | I2C_TX_ABRT_SOUR<br>CE_REG   | I2C Transmit Abort Source Register         |
| 0x50001388 | I2C_DMA_CR_REG               | DMA Control Register                       |
| 0x5000138C | I2C_DMA_TDLR_REG             | DMA Transmit Data Level Register           |
| 0x50001390 | I2C_DMA_RDLR_RE<br>G         | I2C Receive Data Level Register            |
| 0x50001394 | I2C_SDA_SETUP_RE<br>G        | I2C SDA Setup Register                     |
| 0x50001398 | I2C_ACK_GENERAL_<br>CALL_REG | I2C ACK General Call Register              |
| 0x5000139C | I2C_ENABLE_STATU<br>S_REG    | I2C Enable Status Register                 |
| 0x500013A0 | I2C_IC_FS_SPKLEN_<br>REG     | I2C SS and FS spike suppression limit Size |

# Table 221: I2C\_CON\_REG (0x50001300)

| Bit  | Mode | Symbol                   | Description                                                                                                                                              | Reset |
|------|------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:7 | -    | -                        | Reserved                                                                                                                                                 | 0x0   |
| 6    | R/W  | I2C_SLAVE_DISAB<br>LE    | Slave enabled or disabled after reset is applied, which means software does not have to configure the slave.                                             | 0x1   |
|      |      |                          | 0=slave is enabled                                                                                                                                       |       |
|      |      |                          | 1=slave is disabled                                                                                                                                      |       |
|      |      |                          | Software should ensure that if this bit is written with "0", then bit 0 should also be written with a "0".                                               |       |
| 5    | R/W  | I2C_RESTART_EN           | Determines whether RESTART conditions may be sent when acting as a master  0= disable                                                                    | 0x1   |
|      |      |                          | 1=enable                                                                                                                                                 |       |
| 4    | R/W  | I2C_10BITADDR_M<br>ASTER | Controls whether the controller starts its transfers in 7- or 10-bit addressing mode when acting as a master.  0= 7-bit addressing  1= 10-bit addressing | 0x1   |
| 3    | R/W  | I2C_10BITADDR_S<br>LAVE  | When acting as a slave, this bit controls whether the controller responds to 7- or 10-bit addresses.  0= 7-bit addressing  1= 10-bit addressing          | 0x1   |
| 2:1  | R/W  | I2C_SPEED                | These bits control at which speed the controller operates.                                                                                               | 0x2   |

**Final** 

| Bit | Mode | Symbol              | Description                                                                                                                                                                                                                                                                                                                                                                                                             | Reset |
|-----|------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                     | 1= standard mode (100 kbit/s)                                                                                                                                                                                                                                                                                                                                                                                           |       |
|     |      |                     | 2= fast mode (400 kbit/s)                                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |                     | Note: The actuall speed depends on the pcb traces capacitance as well as on the values of the external pull-up resistorts. For an exact speed match, trimming might be required, by adjusting the values of I2C_SS_SCL_HCNT_REG, I2C_SS_SCL_LCNT_REG, I2C_FS_SCL_HCNT_REG, I2C_FS_SCL_LCNT_REG registers. The reset values of those registers were calculated with the assumption of 4.3 kΩ external pull-up resistors. |       |
| 0   | R/W  | I2C_MASTER_MOD<br>E | This bit controls whether the controller master is enabled.                                                                                                                                                                                                                                                                                                                                                             | 0x1   |
|     |      |                     | 0= master disabled                                                                                                                                                                                                                                                                                                                                                                                                      |       |
|     |      |                     | 1= master enabled                                                                                                                                                                                                                                                                                                                                                                                                       |       |
|     |      |                     | Software should ensure that if this bit is written with "1" then bit 6 should also be written with a "1".                                                                                                                                                                                                                                                                                                               |       |

## Table 222: I2C\_TAR\_REG (0x50001304)

| Bit   | Mode | Symbol      | Description                                                                                                                                                                                                                                                                                               | Reset |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:12 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                  | 0x0   |
| 11    | R/W  | SPECIAL     | This bit indicates whether software performs a General Call or                                                                                                                                                                                                                                            | 0x0   |
|       |      |             | START BYTE command.                                                                                                                                                                                                                                                                                       |       |
|       |      |             | 0: ignore bit 10 GC_OR_START and use IC_TAR normally                                                                                                                                                                                                                                                      |       |
|       |      |             | 1: perform special I2C command as specified in GC_OR_START                                                                                                                                                                                                                                                |       |
|       |      |             | bit                                                                                                                                                                                                                                                                                                       |       |
| 10    | R/W  | GC_OR_START | If bit 11 (SPECIAL) is set to 1, then this bit indicates whether a General Call or START byte command is to be performed by the controller.                                                                                                                                                               | 0x0   |
|       |      |             | 0: General Call Address - after issuing a General Call, only writes may be performed. Attempting to issue a read command results in setting bit 6 (TX_ABRT) of the IC_RAW_INTR_STAT register. The controller remains in General Call mode until the SPECIAL bit value (bit 11) is cleared.  1: START BYTE |       |
| 9:0   | R/W  | IC_TAR      | This is the target address for any master transaction. When transmitting a General Call, these bits are ignored. To generate a START BYTE, the CPU needs to write only once into these bits.                                                                                                              | 0x55  |
|       |      |             | Note: If the IC_TAR and IC_SAR are the same, loopback exists but the FIFOs are shared between master and slave, so full loopback is not feasible. Only one direction loopback mode is supported (simplex), not duplex. A master cannot transmit to itself; it can transmit to only a slave                |       |

**Final** 

Table 223: I2C\_SAR\_REG (0x50001308)

| Bit   | Mode | Symbol | Description                                                                                                                                                                                                                                                                                      | Reset |
|-------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:10 | -    | -      | Reserved                                                                                                                                                                                                                                                                                         | 0x0   |
| 9:0   | R/W  | IC_SAR | The IC_SAR holds the slave address when the I2C is operating as a slave. For 7-bit addressing, only IC_SAR[6:0] is used. This register can be written only when the I2C interface is disabled, which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. | 0x55  |

## Table 224: I2C\_DATA\_CMD\_REG (0x50001310)

| Bit   | Mode | Symbol      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:11 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0   |
| 10    | R/W  | I2C_RESTART | This bit controls whether a RESTART is issued before the byte is sent or received. If IC_RESTART_EN is 1, a RESTART is issued before the data is sent/received (according to the value of CMD), regardless of whether or not the transfer direction is changing from the previous command; if IC_RESTART_EN is 0, a STOP followed by a START is issued instead. If IC_RESTART_EN is 1, a RESTART is issued only if the transfer direction is changing from the previous command; if IC_RESTART_EN is 0, a STOP followed by a START is issued instead. Reset value: 0x0                                                                                                                   | 0x0   |
| 9     | R/W  | I2C_STOP    | This bit controls whether a STOP is issued after the byte is sent or received. STOP is issued after this byte, regardless of whether or not the Tx FIFO is empty. If the Tx FIFO is not empty, the master immediately tries to start a new transfer by issuing a START and arbitrating for the bus. STOP is not issued after this byte, regardless of whether or not the Tx FIFO is empty. If the Tx FIFO is not empty, the master continues the current transfer by sending/receiving data bytes according to the value of the CMD bit. If the Tx FIFO is empty, the master holds the SCL line low and stalls the bus until a new command is available in the Tx FIFO. Reset value: 0x0 | 0x0   |
| 8     | R/W  | I2C_CMD     | This bit controls whether a read or a write is performed. This bit does not control the direction when the I2C Ctrl acts as a slave. It controls only the direction when it acts as a master.  1 = Read  0 = Write  When a command is entered in the TX FIFO, this bit distinguishes the write and read commands. In slave-receiver mode, this bit is a "don't care" because writes to this register are not required. In slave-transmitter mode, a "0" indicates that CPU                                                                                                                                                                                                               | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                      | Reset |
|-----|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | data is to be transmitted and as DAT or IC_DATA_CMD[7:0]. When programming this bit, you should remember the following: attempting to perform a read operation after a General Call command has been sent results in a TX_ABRT interrupt (bit 6 of the I2C_RAW_INTR_STAT_REG), unless bit 11 (SPECIAL) in the I2C_TAR register has been cleared. |       |
|     |      |        | If a "1" is written to this bit after receiving a RD_REQ interrupt, then a TX_ABRT interrupt occurs.                                                                                                                                                                                                                                             |       |
|     |      |        | NOTE: It is possible that while attempting a master I2C read transfer on the controller, a RD_REQ interrupt may have occurred simultaneously due to a remote I2C master addressing the controller. In this type of scenario, it ignores the I2C_DATA_CMD write, generates a TX_ABRT interrupt, and waits to service the RD_REQ interrupt         |       |
| 7:0 | R/W  | DAT    | This register contains the data to be transmitted or received on the I2C bus. If you are writing to this register and want to perform a read, bits 7:0 (DAT) are ignored by the controller. However, when you read this register, these bits return the value of data received on the controller's interface.                                    | 0x0   |

### Table 225: I2C\_SS\_SCL\_HCNT\_REG (0x50001314)

| Bit  | Mode | Symbol         | Description                                                                                                                                                                                                                                                                                                                 | Reset |
|------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | IC_SS_SCL_HCNT | This register must be set before any I2C bus transaction can take place to ensure proper I/O timing. This register sets the SCL clock highperiod count for standard speed. This register can be written only when the I2C interface is disabled which corresponds to the IC_ENABLE register being set to 0. Writes at other | 0x48  |
|      |      |                | times have no effect.  The minimum valid value is 6; hardware prevents values less than this being written, and if attempted results in 6 being set.                                                                                                                                                                        |       |
|      |      |                | NOTE: This register must not be programmed to a value higher than 65525, because the controller uses a 16-bit counter to flag an I2C bus idle condition when this counter reaches a value of IC_SS_SCL_HCNT + 10.                                                                                                           |       |

## Table 226: I2C\_SS\_SCL\_LCNT\_REG (0x50001318)

| Bit  | Mode | Symbol         | Description                                                                                  | Reset |
|------|------|----------------|----------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | IC_SS_SCL_LCNT | This register must be set before any I2C bus transaction can take place to ensure proper I/O | 0x4F  |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                             | Reset |
|-----|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | timing. This register sets the SCL clock low period count for standard speed.                                                                                           |       |
|     |      |        | This register can be written only when the I2C interface is disabled which corresponds to the I2C_ENABLE register being set to 0. Writes at other times have no effect. |       |
|     |      |        | The minimum valid value is 8; hardware prevents values less than this being written, and if attempted, results in 8 being set.                                          |       |

## Table 227: I2C\_FS\_SCL\_HCNT\_REG (0x5000131C)

| Bit  | Mode | Symbol         | Description                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | IC_FS_SCL_HCNT | This register must be set before any I2C bus transaction can take place to ensure proper I/O timing. This register sets the SCL clock highperiod count for fast speed. It is used in high-speed mode to send the Master Code and START BYTE or General CALL. This register can be written only when the I2C interface is disabled, which corresponds to the I2C_ENABLE register being set to 0. Writes at other times have no effect. | 0x8   |
|      |      |                | The minimum valid value is 6; hardware prevents values less than this being written, and if attempted results in 6 being set.                                                                                                                                                                                                                                                                                                         |       |

### Table 228: I2C\_FS\_SCL\_LCNT\_REG (0x50001320)

| Bit  | Mode | Symbol         | Description                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | R/W  | IC_FS_SCL_LCNT | This register must be set before any I2C bus transaction can take place to ensure proper I/O timing. This register sets the SCL clock low-period count for fast speed. It is used in high-speed mode to send the Master Code and START BYTE or General CALL. This register can be written only when the I2C interface is disabled, which corresponds to the I2C_ENABLE register being set to 0. Writes at other times have no effect. | 0x17  |
|      |      |                | The minimum valid value is 8; hardware prevents values less than this being written, and if attempted results in 8 being set. For designs with APB_DATA_WIDTH = 8 the order of programming is important to ensure the correct operation of the controller. The lower byte must be programmed first. Then the upper byte is programmed.                                                                                                |       |

**Final** 

### Table 229: I2C\_INTR\_STAT\_REG (0x5000132C)

| Bit   | Mode | Symbol      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:12 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 11    | R    | R_GEN_CALL  | Set only when a General Call address is received and it is acknowledged. It stays set until it is cleared either by disabling controller or when the CPU reads bit 0 of the I2C_CLR_GEN_CALL register. The controller stores the received data in the Rx buffer.                                                                                                                                                                                                                                                                                                                                                                                               | 0x0   |
| 10    | R    | R_START_DET | Indicates whether a START or RESTART condition has occurred on the I2C interface regardless of whether controller is operating in slave or master mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 9     | R    | R_STOP_DET  | Indicates whether a STOP condition has occurred on the I2C interface regardless of whether controller is operating in slave or master mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
| 8     | R    | R_ACTIVITY  | This bit captures I2C Ctrl activity and stays set until it is cleared. There are four ways to clear it:  => Disabling the I2C Ctrl  => Reading the IC_CLR_ACTIVITY register  => Reading the IC_CLR_INTR register  => System reset  Once this bit is set, it stays set unless one of the four methods is used to clear it. Even if the controller module is idle, this bit remains set until cleared, indicating that there was activity on the bus.                                                                                                                                                                                                            | 0x0   |
| 7     | R    | R_RX_DONE   | When the controller is acting as a slave-<br>transmitter, this bit is set to 1 if the master does<br>not acknowledge a transmitted byte. This occurs<br>on the last byte of the transmission, indicating that<br>the transmission is done.                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0   |
| 6     | R    | R_TX_ABRT   | This bit indicates if the controller, as an I2C transmitter, is unable to complete the intended actions on the contents of the transmit FIFO. This situation can occur both as an I2C master or an I2C slave, and is referred to as a "transmit abort". When this bit is set to 1, the I2C_TX_ABRT_SOURCE register indicates the reason why the transmit abort takes places.  NOTE: The controller flushes/resets/empties the TX FIFO whenever this bit is set. The TX FIFO remains in this flushed state until the register I2C_CLR_TX_ABRT is read. Once this read is performed, the TX FIFO is then ready to accept more data bytes from the APB interface. | 0x0   |
| 5     | R    | R_RD_REQ    | This bit is set to 1 when the controller is acting as a slave and another I2C master is attempting to read data from the controller. The controller holds the I2C bus in a wait state (SCL=0) until this interrupt is serviced, which means that the slave has been addressed by a remote master that is asking for data to be transferred. The processor must respond to this interrupt and then write the requested data to the I2C_DATA_CMD register.                                                                                                                                                                                                       | 0x0   |

**Final** 

| Bit | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|-----|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |            | This bit is set to 0 just after the processor reads the I2C_CLR_RD_REQ register                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
| 4   | R    | R_TX_EMPTY | This bit is set to 1 when the transmit buffer is at or below the threshold value set in the I2C_TX_TL register. It is automatically cleared by hardware when the buffer level goes above the threshold. When the IC_ENABLE bit 0 is 0, the TX FIFO is flushed and held in reset. There the TX FIFO looks like it has no data within it, so this bit is set to 1, provided there is activity in the master or slave state machines. When there is no longer activity, then with ic_en=0, this bit is set to 0. | 0x0   |
| 3   | R    | R_TX_OVER  | Set during transmit if the transmit buffer is filled to 32 and the processor attempts to issue another I2C command by writing to the IC_DATA_CMD register. When the module is disabled, this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared                                                                                                                                                                                   | 0x0   |
| 2   | R    | R_RX_FULL  | Set when the receive buffer reaches or goes above the RX_TL threshold in the I2C_RX_TL register. It is automatically cleared by hardware when buffer level goes below the threshold. If the module is disabled (I2C_ENABLE[0]=0), the RX FIFO is flushed and held in reset; therefore the RX FIFO is not full. So this bit is cleared once the I2C_ENABLE bit 0 is programmed with a 0, regardless of the activity that continues.                                                                            | 0x0   |
| 1   | R    | R_RX_OVER  | Set if the receive buffer is completely filled to 32 and an additional byte is received from an external I2C device. The controller acknowledges this, but any data bytes received after the FIFO is full are lost. If the module is disabled (I2C_ENABLE[0]=0), this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared.                                                                                                         | 0x0   |
| 0   | R    | R_RX_UNDER | Set if the processor attempts to read the receive buffer when it is empty by reading from the IC_DATA_CMD register. If the module is disabled (I2C_ENABLE[0]=0), this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared.                                                                                                                                                                                                         | 0x0   |

## Table 230: I2C\_INTR\_MASK\_REG (0x50001330)

| Bit   | Mode | Symbol      | Description                                                                              | Reset |
|-------|------|-------------|------------------------------------------------------------------------------------------|-------|
| 15:12 | -    | -           | Reserved                                                                                 | 0x0   |
| 11    | R/W  | M_GEN_CALL  | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 10    | R/W  | M_START_DET | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x0   |
| 9     | R/W  | M_STOP_DET  | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x0   |

**Final** 

| Bit | Mode | Symbol     | Description                                                                              | Reset |
|-----|------|------------|------------------------------------------------------------------------------------------|-------|
| 8   | R/W  | M_ACTIVITY | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x0   |
| 7   | R/W  | M_RX_DONE  | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 6   | R/W  | M_TX_ABRT  | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 5   | R/W  | M_RD_REQ   | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 4   | R/W  | M_TX_EMPTY | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 3   | R/W  | M_TX_OVER  | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 2   | R/W  | M_RX_FULL  | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 1   | R/W  | M_RX_OVER  | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |
| 0   | R/W  | M_RX_UNDER | These bits mask their corresponding interrupt status bits in the I2C_INTR_STAT register. | 0x1   |

## Table 231: I2C\_RAW\_INTR\_STAT\_REG (0x50001334)

| Bit   | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:12 | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0   |
| 11    | R    | GEN_CALL  | Set only when a General Call address is received and it is acknowledged. It stays set until it is cleared either by disabling controller or when the CPU reads bit 0 of the I2C_CLR_GEN_CALL register. I2C Ctrl stores the received data in the Rx buffer.                                                                                                                                                                                          | 0x0   |
| 10    | R    | START_DET | Indicates whether a START or RESTART condition has occurred on the I2C interface regardless of whether controller is operating in slave or master mode.                                                                                                                                                                                                                                                                                             | 0x0   |
| 9     | R    | STOP_DET  | Indicates whether a STOP condition has occurred on the I2C interface regardless of whether controller is operating in slave or master mode.                                                                                                                                                                                                                                                                                                         | 0x0   |
| 8     | R    | ACTIVITY  | This bit captures I2C Ctrl activity and stays set until it is cleared. There are four ways to clear it:  => Disabling the I2C Ctrl  => Reading the IC_CLR_ACTIVITY register  => Reading the IC_CLR_INTR register  => System reset  Once this bit is set, it stays set unless one of the four methods is used to clear it. Even if the controller module is idle, this bit remains set until cleared, indicating that there was activity on the bus. | 0x0   |
| 7     | R    | RX_DONE   | When the controller is acting as a slave-<br>transmitter, this bit is set to 1 if the master does                                                                                                                                                                                                                                                                                                                                                   | 0x0   |

Final

| Bit | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-----|------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |          | not acknowledge a transmitted byte. This occurs on the last byte of the transmission, indicating that the transmission is done.                                                                                                                                                                                                                                                                                                                                                                                                    |       |
| 6   | R    | TX_ABRT  | This bit indicates if the controller, as an I2C transmitter, is unable to complete the intended actions on the contents of the transmit FIFO. This situation can occur both as an I2C master or an I2C slave, and is referred to as a "transmit abort".                                                                                                                                                                                                                                                                            | 0x0   |
|     |      |          | When this bit is set to 1, the I2C_TX_ABRT_SOURCE register indicates the reason why the transmit abort takes places.                                                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |          | NOTE: The controller flushes/resets/empties the TX FIFO whenever this bit is set. The TX FIFO remains in this flushed state until the register I2C_CLR_TX_ABRT is read. Once this read is performed, the TX FIFO is then ready to accept more data bytes from the APB interface.                                                                                                                                                                                                                                                   |       |
| 5   | R    | RD_REQ   | This bit is set to 1 when I2C Ctrl is acting as a slave and another I2C master is attempting to read data from the controller. The controller holds the I2C bus in a wait state (SCL=0) until this interrupt is serviced, which means that the slave has been addressed by a remote master that is asking for data to be transferred. The processor must respond to this interrupt and then write the requested data to the I2C_DATA_CMD register. This bit is set to 0 just after the processor reads the I2C_CLR_RD_REQ register | 0x0   |
| 4   | R    | TX_EMPTY | This bit is set to 1 when the transmit buffer is at or below the threshold value set in the I2C_TX_TL register. It is automatically cleared by hardware when the buffer level goes above the threshold. When the IC_ENABLE bit 0 is 0, the TX FIFO is flushed and held in reset. There the TX FIFO looks like it has no data within it, so this bit is set to 1, provided there is activity in the master or slave state machines. When there is no longer activity, then with ic_en=0, this bit is set to 0.                      | 0x0   |
| 3   | R    | TX_OVER  | Set during transmit if the transmit buffer is filled to 32 and the processor attempts to issue another I2C command by writing to the IC_DATA_CMD register. When the module is disabled, this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared                                                                                                                                                                                                        | 0x0   |
| 2   | R    | RX_FULL  | Set when the receive buffer reaches or goes above the RX_TL threshold in the I2C_RX_TL register. It is automatically cleared by hardware when buffer level goes below the threshold. If the module is disabled (I2C_ENABLE[0]=0), the RX FIFO is flushed and held in reset; therefore the RX FIFO is not full. So this bit is cleared once the I2C_ENABLE bit 0 is programmed with a 0, regardless of the activity that continues.                                                                                                 | 0x0   |
| 1   | R    | RX_OVER  | Set if the receive buffer is completely filled to 32 and an additional byte is received from an external I2C device. The controller acknowledges this, but any data bytes received after the FIFO is full are                                                                                                                                                                                                                                                                                                                      | 0x0   |



**Final** 

| Bit | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                           | Reset |
|-----|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |          | lost. If the module is disabled (I2C_ENABLE[0]=0), this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared.                                                                                                               |       |
| 0   | R    | RX_UNDER | Set if the processor attempts to read the receive buffer when it is empty by reading from the IC_DATA_CMD register. If the module is disabled (I2C_ENABLE[0]=0), this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared. | 0x0   |

### Table 232: I2C\_RX\_TL\_REG (0x50001338)

| Bit  | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|------|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:5 | -    | -      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| 4:0  | R/W  | RX_TL  | Receive FIFO Threshold Level Controls the level of entries (or above) that triggers the RX_FULL interrupt (bit 2 in I2C_RAW_INTR_STAT register). The valid range is 0-31, with the additional restriction that hardware does not allow this value to be set to a value larger than the depth of the buffer. If an attempt is made to do that, the actual value set will be the maximum depth of the buffer. A value of 0 sets the threshold for 1 entry, and a value of 31 sets the threshold for 32 entries. | 0x0   |

### Table 233: I2C\_TX\_TL\_REG (0x5000133C)

| Bit  | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:5 | -    | -      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x0   |
| 4:0  | R/W  | RX_TL  | Transmit FIFO Threshold Level Controls the level of entries (or below) that trigger the TX_EMPTY interrupt (bit 4 in I2C_RAW_INTR_STAT register). The valid range is 0-31, with the additional restriction that it may not be set to value larger than the depth of the buffer. If an attempt is made to do that, the actual value set will be the maximum depth of the buffer. A value of 0 sets the threshold for 0 entries, and a value of 31 sets the threshold for 32 entries | 0x0   |

## Table 234: I2C\_CLR\_INTR\_REG (0x50001340)

| Bit  | Mode | Symbol   | Description                                                                                                                       | Reset |
|------|------|----------|-----------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -        | Reserved                                                                                                                          | 0x0   |
| 0    | R    | CLR_INTR | Read this register to clear the combined interrupt, all individual interrupts, and the I2C_TX_ABRT_SOURCE register. This bit does | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                  | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | not clear hardware clearable interrupts but software clearable interrupts. Refer to Bit 9 of the I2C_TX_ABRT_SOURCE register for an exception to clearing I2C_TX_ABRT_SOURCE |       |

### Table 235: I2C\_CLR\_RX\_UNDER\_REG (0x50001344)

| Bit  | Mode | Symbol       | Description                                                                                   | Reset |
|------|------|--------------|-----------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -            | Reserved                                                                                      | 0x0   |
| 0    | R    | CLR_RX_UNDER | Read this register to clear the RX_UNDER interrupt (bit 0) of the I2C_RAW_INTR_STAT register. | 0x0   |

### Table 236: I2C\_CLR\_RX\_OVER\_REG (0x50001348)

| Bit  | Mode | Symbol      | Description                                                                                  | Reset |
|------|------|-------------|----------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -           | Reserved                                                                                     | 0x0   |
| 0    | R    | CLR_RX_OVER | Read this register to clear the RX_OVER interrupt (bit 1) of the I2C_RAW_INTR_STAT register. | 0x0   |

### Table 237: I2C\_CLR\_TX\_OVER\_REG (0x5000134C)

| Bit  | Mode | Symbol      | Description                                                                                  | Reset |
|------|------|-------------|----------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -           | Reserved                                                                                     | 0x0   |
| 0    | R    | CLR_TX_OVER | Read this register to clear the TX_OVER interrupt (bit 3) of the I2C_RAW_INTR_STAT register. | 0x0   |

### Table 238: I2C\_CLR\_RD\_REQ\_REG (0x50001350)

| Bit  | Mode | Symbol     | Description                                                                                 | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -          | Reserved                                                                                    | 0x0   |
| 0    | R    | CLR_RD_REQ | Read this register to clear the RD_REQ interrupt (bit 5) of the I2C_RAW_INTR_STAT register. | 0x0   |

### Table 239: I2C\_CLR\_TX\_ABRT\_REG (0x50001354)

| Bit  | Mode | Symbol | Description | Reset |
|------|------|--------|-------------|-------|
| 15:1 | -    | -      | Reserved    | 0x0   |



**Final** 

| Bit | Mode | Symbol      | Description                                                                                                                                                                                                                                                         | Reset |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | R    | CLR_TX_ABRT | Read this register to clear the TX_ABRT interrupt (bit 6) of the                                                                                                                                                                                                    | 0x0   |
|     |      |             | IC_RAW_INTR_STAT register, and the I2C_TX_ABRT_SOURCE register. This also releases the TX FIFO from the flushed/reset state, allowing more writes to the TX FIFO. Refer to Bit 9 of the I2C_TX_ABRT_SOURCE register for an exception to clearing IC_TX_ABRT_SOURCE. |       |

### Table 240: I2C\_CLR\_RX\_DONE\_REG (0x50001358)

| Bit  | Mode | Symbol      | Description                                                                                  | Reset |
|------|------|-------------|----------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | •           | Reserved                                                                                     | 0x0   |
| 0    | R    | CLR_RX_DONE | Read this register to clear the RX_DONE interrupt (bit 7) of the I2C_RAW_INTR_STAT register. | 0x0   |

### Table 241: I2C\_CLR\_ACTIVITY\_REG (0x5000135C)

| Bit  | Mode | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                                                                              | Reset |
|------|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0   |
| 0    | R    | CLR_ACTIVITY | Reading this register clears the ACTIVITY interrupt if the I2C is not active anymore. If the I2C module is still active on the bus, the ACTIVITY interrupt bit continues to be set. It is automatically cleared by hardware if the module is disabled and if there is no further activity on the bus. The value read from this register to get status of the ACTIVITY interrupt (bit 8) of the IC_RAW_INTR_STAT register | 0x0   |

## Table 242: I2C\_CLR\_STOP\_DET\_REG (0x50001360)

| Bit  | Mode | Symbol       | Description                                                                                                   | Reset |
|------|------|--------------|---------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -            | Reserved                                                                                                      | 0x0   |
| 0    | R    | CLR_STOP_DET | Read this register to clear the STOP_DET interrupt (bit 9) of the IC_RAW_INTR_STAT register. Reset value: 0x0 | 0x0   |

### Table 243: I2C\_CLR\_START\_DET\_REG (0x50001364)

| Bit  | Mode | Symbol | Description | Reset |
|------|------|--------|-------------|-------|
| 15:1 | -    | •      | Reserved    | 0x0   |



**Final** 

| Bit | Mode | Symbol        | Description                                                                                    | Reset |
|-----|------|---------------|------------------------------------------------------------------------------------------------|-------|
| 0   | R    | CLR_START_DET | Read this register to clear the START_DET interrupt (bit 10) of the IC_RAW_INTR_STAT register. | 0x0   |

### Table 244: I2C\_CLR\_GEN\_CALL\_REG (0x50001368)

| Bit  | Mode | Symbol       | Description                                                    | Reset |
|------|------|--------------|----------------------------------------------------------------|-------|
| 15:1 | -    | -            | Reserved                                                       | 0x0   |
| 0    | R    | CLR_GEN_CALL | Read this register to clear the GEN_CALL interrupt (bit 11) of | 0x0   |
|      |      |              | I2C_RAW_INTR_STAT register.                                    |       |

## Table 245: I2C\_ENABLE\_REG (0x5000136C)

| Bit  | Mode | Symbol      | Description                                                                                                                                                                                                                                                                        | Reset |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:2 | -    | -           | Reserved                                                                                                                                                                                                                                                                           | 0x0   |
| 1    | R/W  | I2C_ABORT   | 0= ABORT not initiated or ABORT done 1= ABORT operation in progress                                                                                                                                                                                                                | 0x0   |
|      |      |             | The software can abort the I2C transfer in master mode by setting this bit. The software can set this bit only when ENABLE is already set; otherwise, the controller ignores any write to ABORT bit. The software cannot clear the ABORT bit once set. In response to              |       |
|      |      |             | an ABORT, the controller issues a STOP and flushes the Tx FIFO after completing the current transfer, then sets the TX_ABORT interrupt after the abort operation. The ABORT bit is cleared automatically after the abort operation.                                                |       |
| 0    | R/W  | CTRL_ENABLE | Controls whether the controller is enabled.  0: Disables the controller (TX and RX FIFOs are held in an erased state)                                                                                                                                                              | 0x0   |
|      |      |             | 1: Enables the controller                                                                                                                                                                                                                                                          |       |
|      |      |             | Software can disable the controller while it is active. However, it is important that care be taken to ensure that the controller is disabled properly. When the controller is disabled, the following occurs:                                                                     |       |
|      |      |             | * The TX FIFO and RX FIFO get flushed.                                                                                                                                                                                                                                             |       |
|      |      |             | * Status bits in the IC_INTR_STAT register are still active until the controller goes into IDLE state.                                                                                                                                                                             |       |
|      |      |             | If the module is transmitting, it stops as well as deletes the contents of the transmit buffer after the current transfer is complete. If the module is receiving, the controller stops the current transfer at the end of the current byte and does not acknowledge the transfer. |       |
|      |      |             | There is a two ic_clk delay when enabling or disabling the controller                                                                                                                                                                                                              |       |

**Final** 

## Table 246: I2C\_STATUS\_REG (0x50001370)

| Bit  | Mode | Symbol       | Description                                                                                                                                                                                                                                                                             | Reset |
|------|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:7 | -    | -            | Reserved                                                                                                                                                                                                                                                                                | 0x0   |
| 6    | R    | SLV_ACTIVITY | Slave FSM Activity Status. When the Slave Finite State Machine (FSM) is not in the IDLE state, this bit is set.  0: Slave FSM is in IDLE state so the Slave part of the controller is not Active  1: Slave FSM is not in IDLE state so the Slave part of the controller is Active       | 0x0   |
| 5    | R    | MST_ACTIVITY | Master FSM Activity Status. When the Master Finite State Machine (FSM) is not in the IDLE state, this bit is set.  0: Master FSM is in IDLE state so the Master part of the controller is not Active  1: Master FSM is not in IDLE state so the Master part of the controller is Active | 0x0   |
| 4    | R    | RFF          | Receive FIFO Completely Full. When the receive FIFO is completely full, this bit is set. When the receive FIFO contains one or more empty location, this bit is cleared.  0: Receive FIFO is not full  1: Receive FIFO is full                                                          | 0x0   |
| 3    | R    | RFNE         | Receive FIFO Not Empty. This bit is set when the receive FIFO contains one or more entries; it is cleared when the receive FIFO is empty.  0: Receive FIFO is empty  1: Receive FIFO is not empty                                                                                       | 0x0   |
| 2    | R    | TFE          | Transmit FIFO Completely Empty. When the transmit FIFO is completely empty, this bit is set. When it contains one or more valid entries, this bit is cleared. This bit field does not request an interrupt.  0: Transmit FIFO is not empty 1: Transmit FIFO is empty                    | 0x1   |
| 1    | R    | TFNF         | Transmit FIFO Not Full. Set when the transmit FIFO contains one or more empty locations, and is cleared when the FIFO is full.  0: Transmit FIFO is full  1: Transmit FIFO is not full                                                                                                  | 0x1   |
| 0    | R    | I2C_ACTIVITY | I2C Activity Status.                                                                                                                                                                                                                                                                    | 0x0   |

## Table 247: I2C\_TXFLR\_REG (0x50001374)

| Bit  | Mode | Symbol | Description                                                                                                                 | Reset |
|------|------|--------|-----------------------------------------------------------------------------------------------------------------------------|-------|
| 15:6 | -    | •      | Reserved                                                                                                                    | 0x0   |
| 5:0  | R    | TXFLR  | Transmit FIFO Level. Contains the number of valid data entries in the transmit FIFO. Size is constrained by the TXFLR value | 0x0   |

**Final** 

## Table 248: I2C\_RXFLR\_REG (0x50001378)

| Bit  | Mode | Symbol | Description                                                                                                               | Reset |
|------|------|--------|---------------------------------------------------------------------------------------------------------------------------|-------|
| 15:6 | -    | •      | Reserved                                                                                                                  | 0x0   |
| 5:0  | R    | RXFLR  | Receive FIFO Level. Contains the number of valid data entries in the receive FIFO. Size is constrained by the RXFLR value | 0x0   |

## Table 249: I2C\_SDA\_HOLD\_REG (0x5000137C)

| Bit  | Mode | Symbol      | Description   | Reset |
|------|------|-------------|---------------|-------|
| 15:0 | R/W  | IC_SDA_HOLD | SDA Hold time | 0x1   |

### Table 250: I2C\_TX\_ABRT\_SOURCE\_REG (0x50001380)

| Bit | Mode | Symbol                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                          | Reset |
|-----|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15  | R    | ABRT_SLVRD_INT X         | 1: When the processor side responds to a slave<br>mode request for data to be transmitted to a<br>remote master and user writes a 1 in CMD (bit 8)<br>of 2IC_DATA_CMD register                                                                                                                                                                                                                                                       | 0x0   |
| 14  | R    | ABRT_SLV_ARBLO<br>ST     | 1: Slave lost the bus while transmitting data to a remote master.  I2C_TX_ABRT_SOURCE[12] is set at the same time. Note: Even though the slave never "owns" the bus, something could go wrong on the bus. This is a fail safe check. For instance, during a data transmission at the low-to-high transition of SCL, if what is on the data bus is not what is supposed to be transmitted, then the controller no longer own the bus. | 0x0   |
| 13  | R    | ABRT_SLVFLUSH_<br>TXFIFO | 1: Slave has received a read command and some data exists in the TX FIFO so the slave issues a TX_ABRT interrupt to flush old data in TX FIFO.                                                                                                                                                                                                                                                                                       | 0x0   |
| 12  | R    | ARB_LOST                 | 1: Master has lost arbitration, or if I2C_TX_ABRT_SOURCE[14] is also set, then the slave transmitter has lost arbitration. Note: I2C can be both master and slave at the same time.                                                                                                                                                                                                                                                  | 0x0   |
| 11  | R    | ABRT_MASTER_DI<br>S      | User tries to initiate a Master operation with the Master mode disabled.                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
| 10  | R    | ABRT_10B_RD_NO<br>RSTRT  | 1: The restart is disabled (IC_RESTART_EN bit (I2C_CON[5]) = 0) and the master sends a read command in 10-bit addressing mode.                                                                                                                                                                                                                                                                                                       | 0x0   |
| 9   | R    | ABRT_SBYTE_NO<br>RSTRT   | To clear Bit 9, the source of the ABRT_SBYTE_NORSTRT must be fixed first; restart must be enabled (I2C_CON[5]=1), the SPECIAL bit must be cleared (I2C_TAR[11]), or the GC_OR_START bit must be cleared (I2C_TAR[10]). Once the source of the ABRT_SBYTE_NORSTRT is fixed, then this bit can be cleared in the same manner as other bits in this register. If the source of the                                                      | 0x0   |



**Final** 

| Bit | Mode | Symbol                 | Description                                                                                                                                                                                                                             | Reset |
|-----|------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                        | ABRT_SBYTE_NORSTRT is not fixed before attempting to clear this bit, bit 9 clears for one cycle and then gets re-asserted. 1: The restart is disabled (IC_RESTART_EN bit (I2C_CON[5]) = 0) and the user is trying to send a START Byte. |       |
| 8   | R    | ABRT_HS_NORST<br>RT    | 1: The restart is disabled (IC_RESTART_EN bit (I2C_CON[5]) = 0) and the user is trying to use the master to transfer data in High Speed mode                                                                                            | 0x0   |
| 7   | R    | ABRT_SBYTE_ACK<br>DET  | Master has sent a START Byte and the START Byte was acknowledged (wrong behavior).                                                                                                                                                      | 0x0   |
| 6   | R    | ABRT_HS_ACKDE<br>T     | Master is in High Speed mode and the High Speed Master code was acknowledged (wrong behavior).                                                                                                                                          | 0x0   |
| 5   | R    | ABRT_GCALL_REA<br>D    | 1: The controller in master mode sent a General Call but the user programmed the byte following the General Call to be a read from the bus (IC_DATA_CMD[9] is set to 1).                                                                | 0x0   |
| 4   | R    | ABRT_GCALL_NO<br>ACK   | The controller in master mode sent a General Call and no slave on the bus acknowledged the General Call.                                                                                                                                | 0x0   |
| 3   | R    | ABRT_TXDATA_N<br>OACK  | 1: This is a master-mode only bit. Master has received an acknowledgement for the address, but when it sent data byte(s) following the address, it did not receive an acknowledge from the remote slave(s).                             | 0x0   |
| 2   | R    | ABRT_10ADDR2_N<br>OACK | 1: Master is in 10-bit address mode and the second address byte of the 10-bit address was not acknowledged by any slave.                                                                                                                | 0x0   |
| 1   | R    | ABRT_10ADDR1_N<br>OACK | 1: Master is in 10-bit address mode and the first 10-bit address byte was not acknowledged by any slave.                                                                                                                                | 0x0   |
| 0   | R    | ABRT_7B_ADDR_N<br>OACK | Master is in 7-bit addressing mode and the address sent was not acknowledged by any slave.                                                                                                                                              | 0x0   |

### Table 251: I2C\_DMA\_CR\_REG (0x50001388)

| Bit | Mode | Symbol | Description                                                                                                                        | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------|-------|
| 1   | R/W  | TDMAE  | Transmit DMA Enable. //This bit enables/disables the transmit FIFO DMA channel. 0 = Transmit DMA disabled 1 = Transmit DMA enabled | 0x0   |
| 0   | R/W  | RDMAE  | Receive DMA Enable. This bit enables/disables the receive FIFO DMA channel. 0 = Receive DMA disabled 1 = Receive DMA enabled       | 0x0   |

## Table 252: I2C\_DMA\_TDLR\_REG (0x5000138C)

| Bit | Mode | Symbol | Description                                                                                  | Reset |
|-----|------|--------|----------------------------------------------------------------------------------------------|-------|
| 4:0 | R/W  | DMATDL | Transmit Data Level. This bit field controls the level at which a DMA request is made by the | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                      | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | transmit logic. It is equal to the watermark level; that is, the dma_tx_req signal is generated when the number of valid data entries in the transmit FIFO is equal to or below this field value, and TDMAE = 1. |       |

## Table 253: I2C\_DMA\_RDLR\_REG (0x50001390)

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 4:0 | R/W  | DMARDL | Receive Data Level. This bit field controls the level at which a DMA request is made by the receive logic. The watermark level = DMARDL+1; that is, dma_rx_req is generated when the number of valid data entries in the receive FIFO is equal to or more than this field value + 1, and RDMAE =1. For instance, when DMARDL is 0, then dma_rx_req is asserted when 1 or more data entries are present in the receive FIFO. | 0x0   |

### Table 254: I2C\_SDA\_SETUP\_REG (0x50001394)

| Bit  | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                     | Reset |
|------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 7:0  | R/W  | SDA_SETUP | SDA Setup. This register controls the amount of time delay (number of I2C clock periods) between the rising edge of SCL and SDA changing by holding SCL low when I2C block services a read request while operating as a slave-transmitter. The relevant I2C requirement is tSU:DAT (note 4) as detailed in the I2C Bus Specification. This register must be programmed with a value equal to or greater than 2. | 0x64  |
|      |      |           | It is recommended that if the required delay is 1000 ns, then for an I2C frequency of 10 MHz, IC_SDA_SETUP should be programmed to a value of 11.Writes to this register succeed only when IC_ENABLE[0] = 0.                                                                                                                                                                                                    |       |

### Table 255: I2C\_ACK\_GENERAL\_CALL\_REG (0x50001398)

| Bit  | Mode | Symbol       | Description                                                                                                                                                                                       | Reset |
|------|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -            | Reserved                                                                                                                                                                                          | 0x0   |
| 0    | R/W  | ACK_GEN_CALL | ACK General Call. When set to 1, I2C Ctrl responds with a ACK (by asserting ic_data_oe) when it receives a General Call. When set to 0, the controller does not generate General Call interrupts. | 0x0   |

**Final** 

### Table 256: I2C\_ENABLE\_STATUS\_REG (0x5000139C)

| Bit  | Mode | Symbol                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:3 | -    | -                           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 2    | R    | SLV_RX_DATA_LO<br>ST        | Slave Received Data Lost. This bit indicates if a Slave-Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
|      |      |                             | operation has been aborted with at least one data byte received from an I2C transfer due to the setting of IC_ENABLE from 1 to 0. When read as 1, the controller is deemed to have been actively engaged in an aborted I2C transfer (with matching address) and the data phase of the I2C transfer has been entered, even though a data byte has been responded with a NACK. NOTE: If the remote I2C master terminates the transfer with a STOP condition before the controller has a chance to NACK a transfer, and IC_ENABLE has been set to 0, then this bit is also set to 1. |       |
|      |      |                             | When read as 0, the controller is deemed to have been disabled without being actively involved in the data phase of a Slave-Receiver transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |
|      |      |                             | NOTE: The CPU can safely read this bit when IC_EN (bit 0) is read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |
| 1    | R    | SLV_DISABLED_W<br>HILE_BUSY | Slave Disabled While Busy (Transmit, Receive). This bit indicates if a potential or active Slave operation has been aborted due to the setting of the IC_ENABLE register from 1 to 0. This bit is set when the CPU writes a 0 to the IC_ENABLE register while:  (a) I2C Ctrl is receiving the address byte of the Slave-Transmitter operation from a remote master; OR,  (b) address and data bytes of the Slave-Receiver                                                                                                                                                         | 0x0   |
|      |      |                             | operation from a remote master. When read as 1, the controller is deemed to have forced a NACK during any part of an I2C transfer, irrespective of whether the I2C address matches the slave address set in I2C Ctrl (IC_SAR register) OR if the transfer is completed before IC_ENABLE is set to 0 but has not taken effect.                                                                                                                                                                                                                                                     |       |
|      |      |                             | NOTE: If the remote I2C master terminates the transfer with a STOP condition before the the controller has a chance to NACK a transfer, and IC_ENABLE has been set to 0, then this bit will also be set to 1.                                                                                                                                                                                                                                                                                                                                                                     |       |
|      |      |                             | When read as 0, the controller is deemed to have been disabled when there is master activity, or when the I2C bus is idle.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |
|      |      |                             | NOTE: The CPU can safely read this bit when IC_EN (bit 0) is read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |
| 0    | R    | IC_EN                       | ic_en Status. This bit always reflects the value driven on the output port ic_en. When read as 1, the controller is deemed to be in an enabled state.                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
|      |      |                             | When read as 0, the controller is deemed completely inactive.  NOTE: The CPU can safely read this bit anytime. When this bit is read as 0, the CPU can safely read SLV_RX_DATA_LOST (bit 2) and SLV_DISABLED_WHILE_BUSY (bit 1).                                                                                                                                                                                                                                                                                                                                                  |       |



**Final** 

## Table 257: I2C\_IC\_FS\_SPKLEN\_REG (0x500013A0)

| Bit  | Mode | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|------|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
| 7:0  | R/W  | IC_FS_SPKLEN | This register must be set before any I2C bus transaction can take place to ensure stable operation. This register sets the duration, measured in ic_clk cycles, of the longest spike in the SCL or SDA lines that will be filtered out by the spike suppression logic. This register can be written only when the I2C interface is disabled which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. The minimum valid value is 1; hardware prevents values less than this being written, and if attempted results in 1 being set. | 0x1   |

**Final** 

# 32.10 Keyboard Registers

## Table 258: Register map KBRD

| Address    | Register                    | Description                                  |
|------------|-----------------------------|----------------------------------------------|
| 0x50001400 | GPIO_IRQ0_IN_SEL_<br>REG    | GPIO interrupt selection for GPIO_IRQ0       |
| 0x50001402 | GPIO_IRQ1_IN_SEL_<br>REG    | GPIO interrupt selection for GPIO_IRQ1       |
| 0x50001404 | GPIO_IRQ2_IN_SEL_<br>REG    | GPIO interrupt selection for GPIO_IRQ2       |
| 0x50001406 | GPIO_IRQ3_IN_SEL_<br>REG    | GPIO interrupt selection for GPIO_IRQ3       |
| 0x50001408 | GPIO_IRQ4_IN_SEL_<br>REG    | GPIO interrupt selection for GPIO_IRQ4       |
| 0x5000140C | GPIO_DEBOUNCE_R<br>EG       | debounce counter value for GPIO inputs       |
| 0x5000140E | GPIO_RESET_IRQ_R<br>EG      | GPIO interrupt reset register                |
| 0x50001410 | GPIO_INT_LEVEL_CT<br>RL_REG | high or low level select for GPIO interrupts |
| 0x50001412 | KBRD_IRQ_IN_SEL0_<br>REG    | GPIO interrupt selection for KBRD_IRQ for P0 |
| 0x50001414 | KBRD_CTRL_REG               | GPIO Kbrd control register                   |

### Table 259: GPIO\_IRQ0\_IN\_SEL\_REG (0x50001400)

| Bit  | Mode | Symbol        | Description                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:6 | -    | -             | Reserved                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 3:0  | R/W  | KBRD_IRQ0_SEL | Input selection that can generate a GPIO interrupt 1: P0[0] is selected 2: P0[1] is selected 3: P0[2] is selected 4: P0[3] is selected 5: P0[4] is selected 6: P0[5] is selected 7: P0[6] is selected 8: P0[7] is selected 9: P0[8] is selected 10: P0[9] is selected 11: P0[10] is selected 12: P0[11] is selected all others: no input selected | 0x0   |



**Final** 

### Table 260: GPIO\_IRQ1\_IN\_SEL\_REG (0x50001402)

| Bit  | Mode | Symbol        | Description       | Reset |
|------|------|---------------|-------------------|-------|
| 15:6 | -    | -             | Reserved          | 0x0   |
| 3:0  | R/W  | KBRD_IRQ1_SEL | See KBRD_IRQ0_SEL | 0x0   |

#### Table 261: GPIO\_IRQ2\_IN\_SEL\_REG (0x50001404)

| Bit  | Mode | Symbol        | Description       | Reset |
|------|------|---------------|-------------------|-------|
| 15:6 | -    | -             | Reserved          | 0x0   |
| 3:0  | R/W  | KBRD_IRQ2_SEL | See KBRD_IRQ0_SEL | 0x0   |

#### Table 262: GPIO\_IRQ3\_IN\_SEL\_REG (0x50001406)

| Bit  | Mode | Symbol        | Description       | Reset |
|------|------|---------------|-------------------|-------|
| 15:6 | -    | -             | Reserved          | 0x0   |
| 3:0  | R/W  | KBRD_IRQ3_SEL | See KBRD_IRQ0_SEL | 0x0   |

### Table 263: GPIO\_IRQ4\_IN\_SEL\_REG (0x50001408)

| Bit  | Mode | Symbol        | Description       | Reset |
|------|------|---------------|-------------------|-------|
| 15:6 | -    | -             | Reserved          | 0x0   |
| 3:0  | R/W  | KBRD_IRQ4_SEL | See KBRD_IRQ0_SEL | 0x0   |

### Table 264: GPIO\_DEBOUNCE\_REG (0x5000140C)

| Bit | Mode | Symbol              | Description                                                                                               | Reset |
|-----|------|---------------------|-----------------------------------------------------------------------------------------------------------|-------|
| 11  | R/W  | DEB_ENABLE_KBR<br>D | Enables the debounce counter for the KBRD interface                                                       | 0x0   |
| 10  | R/W  | DEB_ENABLE4         | Enables the debounce counter for GPIO IRQ4                                                                | 0x0   |
| 9   | R/W  | DEB_ENABLE3         | Enables the debounce counter for GPIO IRQ3                                                                | 0x0   |
| 8   | R/W  | DEB_ENABLE2         | Enables the debounce counter for GPIO IRQ2                                                                | 0x0   |
| 7   | R/W  | DEB_ENABLE1         | Enables the debounce counter for GPIO IRQ1                                                                | 0x0   |
| 6   | R/W  | DEB_ENABLE0         | Enables the debounce counter for GPIO IRQ0                                                                | 0x0   |
| 5:0 | R/W  | DEB_VALUE           | Keyboard debounce time if enabled. Generate KEYB_INT after specified time.  Debounce time: N*1 ms. N =063 | 0x0   |

**Final** 

### Table 265: GPIO\_RESET\_IRQ\_REG (0x5000140E)

| Bit  | Mode | Symbol              | Description                                                          | Reset |
|------|------|---------------------|----------------------------------------------------------------------|-------|
| 15:6 | -    | -                   | Reserved                                                             | 0x0   |
| 5    | R0/W | RESET_KBRD_IRQ      | Writing a 1 to this bit will reset the KBRD IRQ. Reading returns 0.  | 0x0   |
| 4    | R0/W | RESET_GPIO4_IR<br>Q | Writing a 1 to this bit will reset the GPIO4 IRQ. Reading returns 0. | 0x0   |
| 3    | R0/W | RESET_GPIO3_IR<br>Q | Writing a 1 to this bit will reset the GPIO3 IRQ. Reading returns 0. | 0x0   |
| 2    | R0/W | RESET_GPIO2_IR<br>Q | Writing a 1 to this bit will reset the GPIO2 IRQ. Reading returns 0. | 0x0   |
| 1    | R0/W | RESET_GPIO1_IR<br>Q | Writing a 1 to this bit will reset the GPIO1 IRQ. Reading returns 0. | 0x0   |
| 0    | R0/W | RESET_GPIO0_IR<br>Q | Writing a 1 to this bit will reset the GPIO0 IRQ. Reading returns 0. | 0x0   |

### Table 266: GPIO\_INT\_LEVEL\_CTRL\_REG (0x50001410)

| Bit | Mode | Symbol       | Description                                                                                                             | Reset |
|-----|------|--------------|-------------------------------------------------------------------------------------------------------------------------|-------|
| 9   | R/W  | EDGE_LEVELn4 | See EDGE_LEVELn0, but for GPIO IRQ4                                                                                     | 0x0   |
| 8   | R/W  | EDGE_LEVELn3 | See EDGE_LEVELn0, but for GPIO IRQ3                                                                                     | 0x0   |
| 7   | R/W  | EDGE_LEVELn2 | See EDGE_LEVELn0, but for GPIO IRQ2                                                                                     | 0x0   |
| 6   | R/W  | EDGE_LEVELn1 | See EDGE_LEVELn0, but for GPIO IRQ1                                                                                     | 0x0   |
| 5   | R/W  | EDGE_LEVELn0 | 0: Do not wait for key release after interrupt was reset for GPIO IRQ0, so a new interrupt can be initiated immediately | 0x0   |
|     |      |              | 1: Wait for key release after interrupt was reset for IRQ0                                                              |       |
| 4   | R/W  | INPUT_LEVEL4 | See INPUT_LEVEL0, but for GPIO IRQ4                                                                                     | 0x0   |
| 3   | R/W  | INPUT_LEVEL3 | See INPUT_LEVEL0, but for GPIO IRQ3                                                                                     | 0x0   |
| 2   | R/W  | INPUT_LEVEL2 | See INPUT_LEVEL0, but for GPIO IRQ2                                                                                     | 0x0   |
| 1   | R/W  | INPUT_LEVEL1 | See INPUT_LEVEL0, but for GPIO IRQ1                                                                                     | 0x0   |
| 0   | R/W  | INPUT_LEVEL0 | 0 = Selected input will generate GPIO IRQ0 if that input is high                                                        | 0x0   |
|     |      |              | 1 = Selected input will generate GPIO IRQ0 if that input is low                                                         |       |

## Table 267: KBRD\_IRQ\_IN\_SEL0\_REG (0x50001412)

| Bi | it | Mode | Symbol      | Description                              | Reset |
|----|----|------|-------------|------------------------------------------|-------|
| 11 | 1  | R/W  | KBRD_P11_EN | Enable P0[11] for the keyboard interrupt | 0x0   |
| 10 | C  | R/W  | KBRD_P10_EN | Enable P0[10] for the keyboard interrupt | 0x0   |



**Final** 

| Bit | Mode | Symbol      | Description                             | Reset |
|-----|------|-------------|-----------------------------------------|-------|
| 9   | R/W  | KBRD_P09_EN | Enable P0[9] for the keyboard interrupt | 0x0   |
| 8   | R/W  | KBRD_P08_EN | Enable P0[8] for the keyboard interrupt | 0x0   |
| 7   | R/W  | KBRD_P07_EN | Enable P0[7] for the keyboard interrupt | 0x0   |
| 6   | R/W  | KBRD_P06_EN | Enable P0[6] for the keyboard interrupt | 0x0   |
| 5   | R/W  | KBRD_P05_EN | Enable P0[5] for the keyboard interrupt | 0x0   |
| 4   | R/W  | KBRD_P04_EN | Enable P0[4] for the keyboard interrupt | 0x0   |
| 3   | R/W  | KBRD_P03_EN | Enable P0[3] for the keyboard interrupt | 0x0   |
| 2   | R/W  | KBRD_P02_EN | Enable P0[2] for the keyboard interrupt | 0x0   |
| 1   | R/W  | KBRD_P01_EN | Enable P0[1] for the keyboard interrupt | 0x0   |
| 0   | R/W  | KBRD_P00_EN | Enable P0[0] for the keyboard interrupt | 0x0   |

## Table 268: KBRD\_CTRL\_REG (0x50001414)

| Bit | Mode | Symbol     | Description                                                                                                                                             | Reset |
|-----|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R/W  | KBRD_REL   | 0 = No interrupt on key release<br>1 = Interrupt also on key release (also debouncing<br>if enabled)                                                    | 0x0   |
| 6   | R/W  | KBRD_LEVEL | 0 = Enabled input will generate KBRD IRQ if that input is high 1 = Enabled input will generate KBRD IRQ if that input is low                            | 0x0   |
| 5:0 | R/W  | KEY_REPEAT | While key is pressed, automatically generate repeating KEYB_INT after specified time unequal to 0. Repeat time: N*1 ms. N =163, N=0 disables the timer. | 0x0   |

**Final** 

# **32.11 Miscellaneous Registers**

### Table 269: Register map CRG\_AON

| Address    | Register               | Description                                   |
|------------|------------------------|-----------------------------------------------|
| 0x50000300 | HWR_CTRL_REG           | Hardware Reset control register               |
| 0x50000304 | RESET_STAT_REG         | Reset status register                         |
| 0x50000308 | RAM_LPMX_REG           |                                               |
| 0x5000030C | PAD_LATCH_REG          | Control the state retention of the GPIO ports |
| 0x50000310 | HIBERN_CTRL_REG        | Hibernation control register                  |
| 0x50000320 | POWER_AON_CTRL_<br>REG |                                               |
| 0x50000324 | GP_DATA_REG            |                                               |

### Table 270: HWR\_CTRL\_REG (0x50000300)

| Bit | Mode | Symbol      | Description                           | Reset |
|-----|------|-------------|---------------------------------------|-------|
| 0   | R/W  | DISABLE_HWR | Disables the RST functionality on P00 | 0x0   |

### Table 271: RESET\_STAT\_REG (0x50000304)

| Bit | Mode | Symbol             | Description                                                                                                                                                                  | Reset |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 3   | R/W  | WDOGRESET_STA<br>T | Indicates that a Watchdog has happened. This bit is also set with a PowerOn Reset                                                                                            | 0x1   |
| 2   | R/W  | SWRESET_STAT       | Indicates that a SW Reset has been requested. The SW reset is requested by SYS_CTRL_REG[SW_RESET] or SCB->AIRCR inside the Cortex. This bit is also set with a PowerOn Reset | 0x1   |
| 1   | R/W  | HWRESET_STAT       | Indicates that a HW Reset has happened This bit is also set with a PowerOn Reset                                                                                             | 0x1   |
| 0   | R/W  | PORESET_STAT       | Indicates that a PowerOn Reset has happened                                                                                                                                  | 0x1   |

## Table 272: RAM\_LPMX\_REG (0x50000308)

| Bit | Mode | Symbol    | Description                                                                                                                                                         | Reset |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 2:0 | R/W  | RAMx_LPMX | RAM[3:1] Transparent Light Sleep (TLS) Core<br>Enable for System RAMs. Assert low to enable the<br>TLS core feature, which will result in lower<br>leakage current. | 0x7   |
|     |      |           | In case VDD is below 0.81 V, it is necessary to hold this pin high to maintain data retention.                                                                      |       |

**Final** 

## Table 273: PAD\_LATCH\_REG (0x5000030C)

| Bit | Mode | Symbol       | Description                                                                                                                                               | Reset |
|-----|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | R/W  | PAD_LATCH_EN | Controls the state retention of the pads.  0: latches are closed, pads retain their state.  1: latches are open, new control values have immediate effect | 0x1   |

### Table 274: HIBERN\_CTRL\_REG (0x50000310)

| Bit | Mode | Symbol                   | Description                                                                                                                                                                                                                                            | Reset |
|-----|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 6:2 | R/W  | HIBERN_WKUP_M<br>ASK     | Selects which pin to wake up from                                                                                                                                                                                                                      | 0x0   |
| 1   | R/W  | HIBERN_WKUP_P<br>OLARITY | Selects the polarity of the wakeup source. The polarity must be chosen such that the ANA_STATUS_REG[CLKLESS_WAKEUP_STAT] is "1". Any change on the selected GPIOs will make the CLKLESS_WAKEUP_STAT go to "0", and wakeup the system from hibernation. | 0x0   |
| 0   | R/W  | HIBERNATION_EN<br>ABLE   | Enables the hibernation mode when sleeping 0: deep sleep mode, PD_SLP remains on 1: hibernation mode, PD_SLP goes off. REMAP_ADR0 needs to be set to the correct source to boot from before going to sleep.                                            | 0x0   |

### Table 275: POWER\_AON\_CTRL\_REG (0x50000320)

| Bit   | Mode | Symbol                       | Description                                                                   | Reset |
|-------|------|------------------------------|-------------------------------------------------------------------------------|-------|
| 14    | R/W  | -                            | Reserved                                                                      | 0x0   |
| 13:10 | R/W  | LDO_RET_TRIM                 | VDD clamp level setting for hibernation mode                                  | 0x0   |
| 9     | R/W  | CMP_VCONT_SLP<br>_DISABLE    | Disable vcont comparator in SLP                                               | 0x0   |
| 8:7   | R/W  | BOOST_MODE_FO<br>RCE         | 0x:automatic selection of boost mode 11: force boost mode 10: force buck mode | 0x0   |
| 6     | R/W  | CHARGE_VBAT_DI<br>SABLE      | Do not charge vbat high in boost mode                                         | 0x0   |
| 5     | R/W  | -                            | Reserved                                                                      | 0x0   |
| 4     | R/W  | -                            | Reserved                                                                      | 0x0   |
| 3     | R/W  | POR_VBAT_HIGH_<br>RST_MASK   | Mask rst from por_vbat_high                                                   | 0x1   |
| 2     | R/W  | POR_VBAT_LOW_<br>RST_MASK    | Mask rst from por_vbat_low                                                    | 0x0   |
| 1:0   | R/W  | VBAT_HL_CONNE<br>CT_RES_CTRL | 00: OFF 01: Forced ON 10: Active: automatic control, Sleep: forced ON         | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description           | Reset |
|-----|------|--------|-----------------------|-------|
|     |      |        | 11: Automatic control |       |

## Table 276: GP\_DATA\_REG (0x50000324)

| Bit | Mode | Symbol             | Description                                                                                                                                                                              | Reset |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R/W  | P03_P04_FILT_DIS   | 0: RC filtered input enabled for P0_3 and P0_4 (for example, when used for wake-up) 1: RC filtered input disabled for P0_3 and P0_4 (for example, when used for external clk or XTAL32k) | 0x0   |
| 6   | R/W  | FORCE_RCX_VDD      | 0: RCX bias supply open (see FORCE_RCX_VREF) 1: RCX bias supply connected to VDD (use for sleep)                                                                                         | 0x0   |
| 5   | R/W  | FORCE_RCX_VRE<br>F | O: RCX bias supply connected to clamp and VDD via 400k resistor (old situation)  1: RCX bias supply connected to vref_0v75_0 (use for calibration)                                       | 0x0   |
| 4   | R/W  | -                  | Reserved                                                                                                                                                                                 | 0x0   |
| 3:0 | R/W  | SW_GP_DATA         |                                                                                                                                                                                          | 0x0   |

**Final** 

# **32.12 OTP Controller Registers**

### Table 277: Register map OTPC

| Address    | Register        | Description                                                                  |
|------------|-----------------|------------------------------------------------------------------------------|
| 0x07F40000 | OTPC_MODE_REG   | Mode register                                                                |
| 0x07F40004 | OTPC_STAT_REG   | Status register                                                              |
| 0x07F40008 | OTPC_PADDR_REG  | The address of the word that will be programmed, when the PROG mode is used. |
| 0x07F4000C | OTPC_PWORD_REG  | The 32-bit word that will be programmed, when the PROG mode is used.         |
| 0x07F40010 | OTPC_TIM1_REG   | Various timing parameters of the OTP cell.                                   |
| 0x07F40014 | OTPC_TIM2_REG   | Various timing parameters of the OTP cell.                                   |
| 0x07F40018 | OTPC_AHBADR_REG | AHB master start address                                                     |
| 0x07F4001C | OTPC_CELADR_REG | OTP cell start address                                                       |
| 0x07F40020 | OTPC_NWORDS_RE  | Number of words                                                              |

### Table 278: OTPC\_MODE\_REG (0x07F40000)

| Bit  | Mode | Symbol                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:8 | -    | -                         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:6  | R/W  | OTPC_MODE_PRG<br>_SEL     | Defines the part of the OTP cell that is programmed by the controller during the PROG mode, for each program request that is applied.  0x0: Both normal and redundancy arrays are programmed. This is the normal way of programming.  0x1: Only the normal array is programmed.  0x2: Only the redundancy array is programmed.  0x3: Reserved  The value of this configuration field can be modified only when the controller is in an inactive mode (DSTBY or STBY). The setting will take effect when will be enabled again the PROG mode.                          | 0x0   |
| 5    | R/W  | OTPC_MODE_HT_<br>MARG_EN  | Defines the temperature condition under which is performed a margin read. It affects only the initial margin read (RINI mode) and the programming verification margin read (PVFY).  0: Regular temperature condition (less than 85°C)  1: High temperature condition (85°C or more) The value of this configuration field can be modified only when the controller is in an inactive mode (DSTBY or STBY). The selection will take effect at the next PVFY or RINI mode that will be enabled. The READ mode is not affected by the setting of this configuration bit. | 0x0   |
| 4    | R/W  | OTPC_MODE_USE<br>_TST_ROW | Selects the memory area of the OTP cell that will be used.  0 - Uses the main memory area of the OTP cell                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |



**Final** 

| Bit | Mode | Symbol             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                    | 1 - Uses the test row of the OTP cell The value of this configuration field can be modified only when the controller is in an inactive mode (DSTBY or STBY). The selection will take effect at the next programming or reading mode that will be enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |
| 3   | -    | -                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| 2:0 | R/W  | OTPC_MODE_MO<br>DE | Defines the mode of operation of the OTPC controller. The encoding of the modes is as follows:  0x0: DSTBY. The OTP memory is in deep standby mode (power supply ON and internal LDO OFF).  0x1: STBY. The OTP memory is powered (power supply ON and internal LDO ON, but is not selected).  0x2: READ. The OTP memory is in the normal read mode.  0x3: PROG. The OTP memory is in programming mode.  0x4: PVFY. The OTP memory is in programming verification mode (margin read after programming).  0x5: RINI. The OTP memory is in initial read mode (initial margin read).  0x6: AREAD. Copying of data from the OTP memory to a system RAM by using the internal DMA. See also the registers  OTPC_AHBADR_REG, OTPC_CELADR_REG and OTPC_NWORDS_REG.  Whenever the OTPC_MODE_REG[MODE] is changing, the status bit  OTPC_STAT_REG[OTPC_STAT_MRDY] gets the value zero. The new mode will be ready for use when the OTPC_STAT_MRDY become again 1. During the mode transition the  OTPC_MODE_REG[MODE] become read only. Do not try to use or change any function of the controller until the OTPC_STAT_MRDY bit to become equal to 1.  The data transferring that is performed by using the AREAD mode is completed when OTPC_STAT_MRDY becomes again 1. The mode change automatically to DSTBY with the completion of the transfer. | 0x0   |

## Table 279: OTPC\_STAT\_REG (0x07F40004)

| Bit  | Mode | Symbol          | Description                                                                                                   | Reset |
|------|------|-----------------|---------------------------------------------------------------------------------------------------------------|-------|
| 31:3 | -    | -               | Reserved                                                                                                      | 0x0   |
| 2    | R    | OTPC_STAT_MRD Y | Indicates the progress of the transition from a mode of operation to a new mode of operation.                 | 0x1   |
|      |      |                 | 0 : There is a transition in progress in a new mode of operation . Wait until the transition to be completed. |       |

**Final** 

| Bit | Mode | Symbol                   | Description                                                                                                                                                                                      | Reset |
|-----|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                          | 1 : The transition to the new mode of operation has been completed. The function that has been enabled by the new mode can be used. A new mode can be applied.                                   |       |
|     |      |                          | This status bit gets the value zero every time where the OTPC_MODE_REG[MODE] is changing. Do not try to use or change any function of the controller until this status bit to become equal to 1. |       |
| 1   | R    | OTPC_STAT_PBUF<br>_EMPTY | Indicates the status of the programming buffer (PBUF).                                                                                                                                           | 0x1   |
|     |      |                          | 0 : The PBUF contains the address and the data of a programming request. The OTPC_PADDR_REG and the OTPC_PWORD_REG should not be written as long as this status bit is zero.                     |       |
|     |      |                          | 1 : The PBUF is empty and a new programming request can be registered in the PBUF by using the OTPC_PADDR_REG and the OTPC_PWORD_REG registers.                                                  |       |
|     |      |                          | This status bit gets the value zero every time where a programming is triggered by the OTPC_PADDR_REG (only if the PROG mode is active).                                                         |       |
| 0   | R    | OTPC_STAT_PRD<br>Y       | Indicates the state of the programming process.  0: The controller is busy. A programming is in progress                                                                                         | 0x1   |
|     |      |                          | 1: The logic which performs programming is idle                                                                                                                                                  |       |

### Table 280: OTPC\_PADDR\_REG (0x07F40008)

| Bit   | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:13 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0   |
| 12:0  | R/W  | OTPC_PADDR | The OTPC_PADDR_REG and the OTPC_PWORD_REG consist the PBUF buffer that keeps the information that will be programmed in the OTP, by using the PROG mode. The PBUF holds the address (OTPC_PADDR_REG) and the data (OTPC_PWORD_REG) of each of the programming requests that are applied in the OTP memory.  The OTPC_PADDR_REG refers to a word address. The OTPC_PADDR_REG has to be writen after the OTP_PWORD_REG and only if the OTPC_STAT_REG[OTPC_STAT_PBUF_EMPTY] = 1. The register is read only for as long the PBUF is not empty (OTPC_STAT_REG[OTPC_STAT_PBUF_EMPTY] = 0). A writting to the OTPC_PADDR_REG triggers the controller to start the programming procedure (only if the PROG mode is active). | 0x0   |

**Final** 

### Table 281: OTPC\_PWORD\_REG (0x07F4000C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reset |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:0 | R/W  | OTPC_PWORD | The OTPC_PADDR_REG and the OTPC_PWORD_REG consist the PBUF buffer that keeps the information that will be programmed in the OTP memory, by using the PROG mode. The PBUF holds the address (OTPC_PADDR_REG) and the data (OTPC_PWORD_REG) of each of the programming requests that are applied in the OTP memory.  The OTP_PWORD_REG must be written before the OTPC_PADDR_REG and only if OTPC_STAT_REG[OTPC_STAT_PBUF_EMPTY] = 1. The register is read only for as long the PBUF is not empty (OTPC_STAT_REG[OTPC_STAT_PBUF_EMPTY] ] = 0). | 0x0   |

### Table 282: OTPC\_TIM1\_REG (0x07F40010)

| Bit   | Mode | Symbol                  | Description                                                                                                                                                                                                                                                    | Reset |
|-------|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31    | -    | -                       | Reserved                                                                                                                                                                                                                                                       | 0x0   |
| 30:24 | R/W  | OTPC_TIM1_US_T<br>_CSP  | The number of microseconds (minus one) that are required after the selection of the OTP memory, until to be ready for programming. It must be: - at least 10 µs - no more than 100 µs                                                                          | 0x9   |
| 23:20 | R/W  | OTPC_TIM1_US_T<br>_CS   | The number of microseconds (minus one) that are required after the selection of the OTP memory, until to be ready for any kind of read. It must be at least 10 µs.                                                                                             | 0x9   |
| 19:16 | R/W  | OTPC_TIM1_US_T<br>_PL   | The number of microseconds (minus one) that are required until to be enabled the LDO of the OTP. It must be at least 10 µs.                                                                                                                                    | 0x9   |
| 15    | -    | -                       | Reserved                                                                                                                                                                                                                                                       | 0x0   |
| 14:12 | R/W  | OTPC_TIM1_CC_T<br>_RD   | The number of hclk_c clock periods (minus one) that give a time interval at least higher than 60 ns. This timing parameter refers to the access time of the OTP memory.                                                                                        | 0x0   |
| 11:10 | -    | -                       | Reserved                                                                                                                                                                                                                                                       | 0x0   |
| 9:8   | R/W  | OTPC_TIM1_CC_T<br>_20NS | The number of hclk_c clock periods (minus one) that give a time interval that is at least higher than 20 ns.                                                                                                                                                   | 0x0   |
| 7     | -    | -                       | Reserved                                                                                                                                                                                                                                                       | 0x0   |
| 6:0   | R/W  | OTPC_TIM1_CC_T<br>_1US  | The number of hclk_c clock periods (minus one) that give a time interval equal to 1 µs. This setting affects all the timing parameters that refer to microseconds, due to that defines the correspondence of a microsecond to a number of hclk_c clock cycles. | 0xF   |

**Final** 

# Table 283: OTPC\_TIM2\_REG (0x07F40014)

| Bit   | Mode | Symbol                     | Description                                                                                                                                                                                                             | Reset |
|-------|------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31    | R/W  | OTPC_TIM2_US_A<br>DD_CC_EN | Adds an additional hclk_c clock cycle at all the time intervals that count in microseconds.  0: The extra hclk_c clock cycle is not applied                                                                             | 0x1   |
|       |      |                            | 1 : The extra hclk_c clock cycle is applied                                                                                                                                                                             |       |
| 30:29 | R/W  | OTPC_TIM2_US_T<br>_SAS     | The number of microseconds (minus one) that are required after the exit from the deep sleep standby mode and before to become ready to enter in an active mode (reading or programming). It must be at least 2 µs.      | 0x1   |
| 28:24 | R/W  | OTPC_TIM2_US_T<br>_PPH     | The number of microseconds (minus one) that are required after the last programming pulse and before to be disabled the programming mode in the OTP memory. It must be: - at least 5 µs - no more than 20 µs            | 0x4   |
| 23:21 | R/W  | OTPC_TIM2_US_T<br>_VDS     | The number of microseconds (minus one) that are required after the enabling of the power supply of the OTP memory and before to become ready for the enabling of the internal LDO. It must be at least 1 µs.            | 0x0   |
| 20:16 | R/W  | OTPC_TIM2_US_T<br>_PPS     | The number of microseconds (minus one) that are required after the enabling of the programming in the OTP memory and before to be applied the first programming pulse. It must be: - at least 5 µs - no more than 20 µs | 0x4   |
| 15    | -    | -                          | Reserved                                                                                                                                                                                                                | 0x0   |
| 14:8  | R/W  | OTPC_TIM2_US_T<br>_PPR     | The number of microseconds (minus one) for recovery after a programming sequence. It must be: - at least 5 µs - no more than 100 µs                                                                                     | 0x4   |
| 7:5   | R/W  | OTPC_TIM2_US_T<br>_PWI     | The number of microseconds (minus one) between two consecutive programming pulses. It must be : - at least 1 µs - no more than 5 µs                                                                                     | 0x0   |
| 4:0   | R/W  | OTPC_TIM2_US_T<br>_PW      | The number of microseconds (minus one) that lasts the programming of each bit. It must be : - at least 10 µs - no more than 20 µs                                                                                       | 0x9   |

## Table 284: OTPC\_AHBADR\_REG (0x07F40018)

| Bit   | Mode | Symbol      | Description                                                                                          | Reset |
|-------|------|-------------|------------------------------------------------------------------------------------------------------|-------|
| 31:16 | -    | -           | Reserved                                                                                             | 0x0   |
| 15:2  | R/W  | OTPC_AHBADR | It is the AHB address used by the AHB master interface of the controller (the bits [15:2]). The bits | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                           | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------|-------|
|     |      |        | [1:0] of the address are considered always as equal to zero.                          |       |
|     |      |        | The value of the register remains unchanged, by the internal logic of the controller. |       |
| 1:0 | -    | -      | Reserved                                                                              | 0x0   |

### Table 285: OTPC\_CELADR\_REG (0x07F4001C)

| Bit   | Mode | Symbol      | Description                                                                                               | Reset |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------|-------|
| 31:13 | -    | -           | Reserved                                                                                                  | 0x0   |
| 12:0  | R/W  | OTPC_CELADR | Defines a word address inside the OTP cell that will be used during the AREAD mode and the OTP mirroring. | 0x0   |

## Table 286: OTPC\_NWORDS\_REG (0x07F40020)

| Bit   | Mode | Symbol      | Description                                                                                                                                             | Reset |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 31:13 | -    | -           | Reserved                                                                                                                                                | 0x0   |
| 12:0  | R/W  | OTPC_NWORDS | The number of words (minus one) that will be copied by the AREAD mode. During mirroring, this register reflects the amount of data that will be copied. | 0x0   |

**Final** 

## **32.13 Quadrature Decoder Registers**

### Table 287: Register map QDEC

| Address    | Register               | Description                          |
|------------|------------------------|--------------------------------------|
| 0x50000200 | QDEC_CTRL_REG          | Quad Decoder control register        |
| 0x50000202 | QDEC_XCNT_REG          | Counter value of the X Axis          |
| 0x50000204 | QDEC_YCNT_REG          | Counter value of the Y Axis          |
| 0x50000206 | QDEC_CLOCKDIV_R<br>EG  | Clock divider register               |
| 0x50000208 | QDEC_CTRL2_REG         | Quad Decoder port selection register |
| 0x5000020A | QDEC_ZCNT_REG          | Counter value of the Z Axis          |
| 0x5000020C | QDEC_EVENT_CNT_<br>REG | Event counter register               |

### Table 288: QDEC\_CTRL\_REG (0x50000200)

| Bit  | Mode  | Symbol                 | Description                                                                                                                                                  | Reset |
|------|-------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 10:3 | R/W   | QDEC_IRQ_THRES         | Defines the number of events on either counter (X or Y or Z) that need to be reached before an interrupt is generated. Events are equal to QDEC_IRQ_THRES+1. | 0x2   |
| 2    | R/W   | QDEC_IRQ_STATU<br>S    | <ul><li>1 = Interrupt is occured.</li><li>0 = No interrupt pending</li><li>Write 1 will clear the pending interrupt</li></ul>                                | 0x0   |
| 1    | R0/WC | QDEC_EVENT_CN<br>T_CLR | Writing 1 QDEC_EVENT_CNT_REG is cleared                                                                                                                      | 0x0   |
| 0    | R/W   | QDEC_IRQ_ENABL<br>E    | 0 = Interrupt is masked<br>1 = Interrupt is enabled                                                                                                          | 0x1   |

# Table 289: QDEC\_XCNT\_REG (0x50000202)

| Bit  | Mode | Symbol     | Description                                                          | Reset |
|------|------|------------|----------------------------------------------------------------------|-------|
| 15:0 | R    | QDEC_X_CNT | Contains a signed value of the events. Zero when channel is disabled | 0x0   |

# Table 290: **QDEC\_YCNT\_REG** (0x50000204)

| Bit  | Mode | Symbol     | Description                                                          | Reset |
|------|------|------------|----------------------------------------------------------------------|-------|
| 15:0 | R    | QDEC_Y_CNT | Contains a signed value of the events. Zero when channel is disabled | 0x0   |

**Final** 

### Table 291: QDEC\_CLOCKDIV\_REG (0x50000206)

| Bit | Mode | Symbol                | Description                                                                                                   | Reset |
|-----|------|-----------------------|---------------------------------------------------------------------------------------------------------------|-------|
| 10  | R/W  | QDEC_PRESCALE<br>R_EN | 0 = No prescaler enabled 1 = In sleep and active mode, quadrature clock is divided by 2                       | 0x0   |
| 9:0 | R/W  | QDEC_CLOCKDIV         | Contains the number of the input clock cycles minus one, that are required to generate one logic clock cycle. | 0x3E7 |
|     |      |                       | Clock divider is bypassed when system runs at LP_CLK                                                          |       |

#### Table 292: QDEC\_CTRL2\_REG (0x50000208)

| Bit | Mode | Symbol                  | Description                                                                                                                                                                                                                                                               | Reset |
|-----|------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 11  | R/W  | QDEC_CHZ_EVEN<br>T_MODE | 0 = Normal quadrature counting 1 = Counts rising and falling edge of both ports (if both ports change at the same time, counter increases by 1)                                                                                                                           | 0x1   |
| 10  | R/W  | QDEC_CHY_EVEN<br>T_MODE | 0 = Normal quadrature counting 1 = Counts rising and falling edge of both ports (if both ports change at the same time, counter increases by 1)                                                                                                                           | 0x1   |
| 9   | R/W  | QDEC_CHX_EVEN<br>T_MODE | 0 = Normal quadrature counting 1 = Counts rising and falling edge of both ports (if both ports change at the same time, counter increases by 1)                                                                                                                           | 0x1   |
| 8:6 | R/W  | QDEC_CHZ_PORT<br>_SEL   | Defines which GPIOs are mapped on Channel Z 0: none 1: P0[2] -> CHZ_A, P0[5] -> CHZ_B 2: P0[1] -> CHZ_A, P0[4] -> CHZ_B 3: P0[3] -> CHZ_A, P0[10] -> CHZ_B 4: P0[6] -> CHZ_A, P0[7] -> CHZ_B 5: P0[8] -> CHZ_A, P0[9] -> CHZ_B 6: P0[0] -> CHZ_A, P0[11] -> CHZ_B 7: none | 3     |
| 5:3 | R/W  | QDEC_CHY_PORT<br>_SEL   | Defines which GPIOs are mapped on Channel Y 0: none 1: P0[2] -> CHY_A, P0[5] -> CHY_B 2: P0[1] -> CHY_A, P0[4] -> CHY_B 3: P0[3] -> CHY_A, P0[10] -> CHY_B 4: P0[6] -> CHY_A, P0[7] -> CHY_B 5: P0[8] -> CHY_A, P0[9] -> CHY_B 6: P0[0] -> CHY_A, P0[11] -> CHY_B 7: none | 2     |
| 2:0 | R/W  | QDEC_CHX_PORT<br>_SEL   | Defines which GPIOs are mapped on Channel X 0: none 1: P0[2] -> CHX_A, P0[5] -> CHX_B 2: P0[1] -> CHX_A, P0[4] -> CHX_B                                                                                                                                                   | 1     |



**Final** 

| Bit | Mode | Symbol | Description                        | Reset |
|-----|------|--------|------------------------------------|-------|
|     |      |        | 3: P0[3] -> CHX_A, P0[10] -> CHX_B |       |
|     |      |        | 4: P0[6] -> CHX_A, P0[7] -> CHX_B  |       |
|     |      |        | 5: P0[8] -> CHX_A, P0[9] -> CHX_B  |       |
|     |      |        | 6: P0[0] -> CHX_A, P0[11] -> CHX_B |       |
|     |      |        | 7: none                            |       |

## Table 293: QDEC\_ZCNT\_REG (0x5000020A)

| Bit  | Mode | Symbol     | Description                                                          | Reset |
|------|------|------------|----------------------------------------------------------------------|-------|
| 15:0 | R    | QDEC_Z_CNT | Contains a signed value of the events. Zero when channel is disabled | 0     |

## Table 294: QDEC\_EVENT\_CNT\_REG (0x5000020C)

| Bit | Mode | Symbol             | Description                                 | Reset |
|-----|------|--------------------|---------------------------------------------|-------|
| 7:0 | R    | QDEC_EVENT_CN<br>T | Gives the number of events at all channels. | 0x0   |

**Final** 

# **32.14 Real Time Clock Registers**

### Table 295: Register map RTC

| Address    | Register                      | Description                    |
|------------|-------------------------------|--------------------------------|
| 0x50004100 | RTC_CONTROL_REG               | RTC Control Register           |
| 0x50004104 | RTC_HOUR_MODE_<br>REG         | RTC Hour Mode Register         |
| 0x50004108 | RTC_TIME_REG                  | RTC Time Register              |
| 0x5000410C | RTC_CALENDAR_RE<br>G          | RTC Calendar Register          |
| 0x50004110 | RTC_TIME_ALARM_R<br>EG        | RTC Time Alarm Register        |
| 0x50004114 | RTC_CALENDAR_AL<br>ARM_REG    | RTC Calendar Alram Register    |
| 0x50004118 | RTC_ALARM_ENABL<br>E_REG      | RTC Alarm Enable Register      |
| 0x5000411C | RTC_EVENT_FLAGS<br>_REG       | RTC Event Flags Register       |
| 0x50004120 | RTC_INTERRUPT_EN<br>ABLE_REG  | RTC Interrupt Enable Register  |
| 0x50004124 | RTC_INTERRUPT_DI<br>SABLE_REG | RTC Interrupt Disable Register |
| 0x50004128 | RTC_INTERRUPT_M<br>ASK_REG    | RTC Interrupt Mask Register    |
| 0x5000412C | RTC_STATUS_REG                | RTC Status Register            |
| 0x50004130 | RTC_KEEP_RTC_RE<br>G          | RTC Keep RTC Register          |

### Table 296: RTC\_CONTROL\_REG (0x50004100)

| Bit | Mode | Symbol               | Description                                                                | Reset |
|-----|------|----------------------|----------------------------------------------------------------------------|-------|
| 1   | R/W  | RTC_CAL_DISABL<br>E  | When this field is set high the RTC stops incrementing the calendar value. | 0x1   |
| 0   | R/W  | RTC_TIME_DISABL<br>E | When this field is set high the RTC stops incrementing the time value.     | 0x1   |

### Table 297: RTC\_HOUR\_MODE\_REG (0x50004104)

| Bit | Mode | Symbol  | Description                                                                                                       | Reset |
|-----|------|---------|-------------------------------------------------------------------------------------------------------------------|-------|
| 0   | R/W  | RTC_HMS | When this field is set high the RTC operates in 12 hour clock mode; otherwise, times are in 24 hour clock format. | 0x0   |

**Final** 

### Table 298: RTC\_TIME\_REG (0x50004108)

| Bit   | Mode | Symbol        | Description                                                             | Reset |
|-------|------|---------------|-------------------------------------------------------------------------|-------|
| 31    | R/W  | RTC_TIME_CH   | The value in this register has altered since last read. Read and clear. | 0x0   |
| 30    | R/W  | RTC_TIME_PM   | In 12 hour clock mode, indicates PM when set.                           | 0x0   |
| 29:28 | R/W  | RTC_TIME_HR_T | Hours tens. Represented in BCD digit (0-2).                             | 0x0   |
| 27:24 | R/W  | RTC_TIME_HR_U | Hours units. Represented in BCD digit (0-9).                            | 0x0   |
| 23    | -    | -             | Reserved                                                                | 0x0   |
| 22:20 | R/W  | RTC_TIME_M_T  | Minutes tens. Represented in BCD digit (0-5).                           | 0x0   |
| 19:16 | R/W  | RTC_TIME_M_U  | Minutes units. Represented in BCD digit (0-9).                          | 0x0   |
| 15    | -    | -             | Reserved                                                                | 0x0   |
| 14:12 | R/W  | RTC_TIME_S_T  | Seconds tens. Represented in BCD digit (0-9).                           | 0x0   |
| 11:8  | R/W  | RTC_TIME_S_U  | Seconds units. Represented in BCD digit (0-9).                          | 0x0   |
| 7:4   | R/W  | RTC_TIME_H_T  | Hundredths of a second tens. Represented in BCD digit (0-9).            | 0x0   |
| 3:0   | R/W  | RTC_TIME_H_U  | Hundredths of a second units. Represented in BCD digit (0-9).           | 0x0   |

#### Table 299: RTC\_CALENDAR\_REG (0x5000410C)

| Bit   | Mode | Symbol      | Description                                                            | Reset |
|-------|------|-------------|------------------------------------------------------------------------|-------|
| 31    | R/W  | RTC_CAL_CH  | The value in this register has altered since last read. Read and clear | 0x0   |
| 30    | -    | -           | Reserved                                                               | 0x0   |
| 29:28 | R/W  | RTC_CAL_C_T | Century tens. Represented in BCD digit (1-2).                          | 0x2   |
| 27:24 | R/W  | RTC_CAL_C_U | Century units. Represented in BCD digit (0-9).                         | 0x0   |
| 23:20 | R/W  | RTC_CAL_Y_T | Year tens. Represented in BCD digit (0-9).                             | 0x0   |
| 19:16 | R/W  | RTC_CAL_Y_U | Year units. Represented in BCD digit (0-9).                            | 0x0   |
| 15:14 | -    | -           | Reserved                                                               | 0x0   |
| 13:12 | R/W  | RTC_CAL_D_T | Date tens. Represented in BCD digit (0-3).                             | 0x0   |
| 11:8  | R/W  | RTC_CAL_D_U | Date units. Represented in BCD digit (0-9).                            | 0x1   |
| 7     | R/W  | RTC_CAL_M_T | Month tens. Represented in BCD digit (0-1).                            | 0x0   |
| 6:3   | R/W  | RTC_CAL_M_U | Month units. Represented in BCD digit (0-9).                           | 0x1   |
| 2:0   | R/W  | RTC_DAY     | Day of the week (arbitrary) units. Represented in BCD digit (0-7).     | 0x7   |

### Table 300: RTC\_TIME\_ALARM\_REG (0x50004110)

| Bit | Mode | Symbol | Description | Reset |
|-----|------|--------|-------------|-------|
| 31  | -    | -      | Reserved    | 0x0   |

**Final** 

| Bit   | Mode | Symbol        | Description                                                   | Reset |
|-------|------|---------------|---------------------------------------------------------------|-------|
| 30    | R/W  | RTC_TIME_PM   | In 12 hour clock mode, indicates PM when set.                 | 0x0   |
| 29:28 | R/W  | RTC_TIME_HR_T | Hours tens. Represented in BCD digit (0-2).                   | 0x0   |
| 27:24 | R/W  | RTC_TIME_HR_U | Hours units. Represented in BCD digit (0-9).                  | 0x0   |
| 23    | -    | -             | Reserved                                                      | 0x0   |
| 22:20 | R/W  | RTC_TIME_M_T  | Minutes tens. Represented in BCD digit (0-5).                 | 0x0   |
| 19:16 | R/W  | RTC_TIME_M_U  | Minutes units. Represented in BCD digit (0-9).                | 0x0   |
| 15    | -    | -             | Reserved                                                      | 0x0   |
| 14:12 | R/W  | RTC_TIME_S_T  | Seconds tens. Represented in BCD digit (0-9).                 | 0x0   |
| 11:8  | R/W  | RTC_TIME_S_U  | Seconds units. Represented in BCD digit (0-9).                | 0x0   |
| 7:4   | R/W  | RTC_TIME_H_T  | Hundredths of a second tens. Represented in BCD digit (0-9).  | 0x0   |
| 3:0   | R/W  | RTC_TIME_H_U  | Hundredths of a second units. Represented in BCD digit (0-9). | 0x0   |

### Table 301: RTC\_CALENDAR\_ALARM\_REG (0x50004114)

| Bit   | Mode | Symbol      | Description                                  | Reset |
|-------|------|-------------|----------------------------------------------|-------|
| 31:14 | R/W  | -           | Reserved                                     | 0x0   |
| 13:12 | R/W  | RTC_CAL_D_T | Date tens. Represented in BCD digit (0-3).   | 0x0   |
| 11:8  | R/W  | RTC_CAL_D_U | Date units. Represented in BCD digit (0-9).  | 0x0   |
| 7     | R/W  | RTC_CAL_M_T | Month tens. Represented in BCD digit (0-1).  | 0x0   |
| 6:3   | R/W  | RTC_CAL_M_U | Month units. Represented in BCD digit (0-9). | 0x0   |
| 2:0   | -    | -           | Reserved                                     | 0x0   |

# Table 302: RTC\_ALARM\_ENABLE\_REG (0x50004118)

| Bit | Mode | Symbol                | Description                                                                                                                    | Reset |
|-----|------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|-------|
| 5   | R/W  | RTC_ALARM_MNT<br>H_EN | Alarm on month enable. Enable to trigger alarm when data specified in Calendar Alarm Register (M_T and M_U) has been reached.  | 0x0   |
| 4   | R/W  | RTC_ALARM_DAT<br>E_EN | Alarm on date enable. Enable to trigger alarm when data specified in Calendar Alarm Register (D_T and D_U) has been reached.   | 0x0   |
| 3   | R/W  | RTC_ALARM_HOU<br>R_EN | Alarm on hour enable. Enable to trigger alarm when data specified in Time Alarm Register (PM, HR_T and HR_U) has been reached. | 0x0   |
| 2   | R/W  | RTC_ALARM_MIN_<br>EN  | Alarm on minute enable. Enable to trigger alarm when data specified in Time Alarm Register (M_T and M_U) has been reached.     | 0x0   |
| 1   | R/W  | RTC_ALARM_SEC<br>_EN  | Alarm on second enable. Enable to trigger alarm when data specified in Time Alarm Register (S_T and S_U) has been reached.     | 0x0   |



**Final** 

| Bit | Mode | Symbol               | Description                                                                                                                                | Reset |
|-----|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | R/W  | RTC_ALARM_HOS<br>_EN | Alarm on hundredths of a second enable. Enable to trigger alarm when data specified in Time Alarm Register (H_T and H_U) has been reached. | 0x0   |

### Table 303: RTC\_EVENT\_FLAGS\_REG (0x5000411C)

| Bit | Mode | Symbol             | Description                                                                                                             | Reset |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------------|-------|
| 6   | R    | RTC_EVENT_ALR<br>M | Alarm event flag. Indicate that alarm event occurred since the last reset.                                              | 0x0   |
| 5   | R    | RTC_EVENT_MNT<br>H | Month rolls over event flag. Indicate that month rolls over event occurred since the last reset.                        | 0x0   |
| 4   | R    | RTC_EVENT_DATE     | Date rolls over event flag. Indicate that date rolls over event occurred since the last reset.                          | 0x0   |
| 3   | R    | RTC_EVENT_HOU<br>R | Hour rolls over event flag. Indicate that hour rolls over event occurred since the last reset.                          | 0x0   |
| 2   | R    | RTC_EVENT_MIN      | Minute rolls over event flag. Indicate that minute rolls over event occurred since the last reset.                      | 0x0   |
| 1   | R    | RTC_EVENT_SEC      | Second rolls over event flag. Indicate that second rolls over event occurred since the last reset.                      | 0x0   |
| 0   | R    | RTC_EVENT_HOS      | Hundredths of a second event flag. Indicate that hundredths of a second rolls over event occurred since the last reset. | 0x0   |

## Table 304: RTC\_INTERRUPT\_ENABLE\_REG (0x50004120)

| Bit | Mode | Symbol              | Description                                                                                                           | Reset |
|-----|------|---------------------|-----------------------------------------------------------------------------------------------------------------------|-------|
| 6   | W    | RTC_ALRM_INT_E<br>N | Interrupt on alarm enable. Enable to issue the interrupt when alarm event occurred.                                   | 0x0   |
| 5   | W    | RTC_MNTH_INT_E<br>N | Interrupt on month enable. Enable to issue the interrupt when month event occurred.                                   | 0x0   |
| 4   | W    | RTC_DATE_INT_E<br>N | Interrupt on date enable. Enable to issue the interrupt when date event occurred.                                     | 0x0   |
| 3   | W    | RTC_HOUR_INT_E<br>N | Interrupt on hour enable. Enable to issue the interrupt when hour event occurred.                                     | 0x0   |
| 2   | W    | RTC_MIN_INT_EN      | Interrupt on minute enable. Enable to issue the interrupt when minute event occurred.                                 | 0x0   |
| 1   | W    | RTC_SEC_INT_EN      | Interrupt on second enable. Enable to issue the interrupt when second event occurred.                                 | 0x0   |
| 0   | W    | RTC_HOS_INT_EN      | Interrupt on hundredths of a second enable. Enable to issue the interrupt when hundredths of a second event occurred. | 0x0   |

**Final** 

## Table 305: RTC\_INTERRUPT\_DISABLE\_REG (0x50004124)

| Bit | Mode | Symbol               | Description                                                                                                             | Reset |
|-----|------|----------------------|-------------------------------------------------------------------------------------------------------------------------|-------|
| 6   | W    | RTC_ALRM_INT_DI<br>S | Interrupt on alarm disable. Disable to issue the interrupt when alarm event occurred.                                   | 0x0   |
| 5   | W    | RTC_MNTH_INT_D<br>IS | Interrupt on month disable. Disable to issue the interrupt when month event occurred.                                   | 0x0   |
| 4   | W    | RTC_DATE_INT_DI<br>S | Interrupt on date disable. Disable to issue the interrupt when date event occurred.                                     | 0x0   |
| 3   | W    | RTC_HOUR_INT_D<br>IS | Interrupt on hour disable. Disable to issue the interrupt when hour event occurred.                                     | 0x0   |
| 2   | W    | RTC_MIN_INT_DIS      | Interrupt on minute disable. Disable to issue the interrupt when minute event occurred.                                 | 0x0   |
| 1   | W    | RTC_SEC_INT_DIS      | Interrupt on second disable. Disable to issue the interrupt when second event occurred.                                 | 0x0   |
| 0   | W    | RTC_HOS_INT_DIS      | Interrupt on hundredths of a second disable. Disable to issue the interrupt when hundredths of a second event occurred. | 0x0   |

### Table 306: RTC\_INTERRUPT\_MASK\_REG (0x50004128)

| Bit | Mode | Symbol               | Description                                                                                                                                                  | Reset |
|-----|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 6   | R    | RTC_ALRM_INT_M<br>SK | Mask alarm interrupt. It can be cleared (set) by setting corresponding bit (ALRM) in Interrupt Enable Register (Interrupt Disable Register).                 | 0x1   |
| 5   | R    | RTC_MNTH_INT_M<br>SK | Mask month interrupt. It can be cleared (set) by setting corresponding bit (MNTH) in Interrupt Enable Register (Interrupt Disable Register).                 | 0x1   |
| 4   | R    | RTC_DATE_INT_M<br>SK | Mask date interrupt. It can be cleared (set) by setting corresponding bit (DATE) in Interrupt Enable Register (Interrupt Disable Register).                  | 0x1   |
| 3   | R    | RTC_HOUR_INT_M<br>SK | Mask hour interrupt. It can be cleared (set) by setting corresponding bit (HOUR) in Interrupt Enable Register (Interrupt Disable Register).                  | 0x1   |
| 2   | R    | RTC_MIN_INT_MS<br>K  | Mask minute interrupt. It can be cleared (set) by setting corresponding bit (MIN) in Interrupt Enable Register (Interrupt Disable Register).                 | 0x1   |
| 1   | R    | RTC_SEC_INT_MS<br>K  | Mask second interrupt. It can be cleared (set) by setting corresponding bit (SEC) in Interrupt Enable Register (Interrupt Disable Register).                 | 0x1   |
| 0   | R    | RTC_HOS_INT_MS<br>K  | Mask hundredths of a second interrupt. It can be cleared (set) by setting corresponding bit (HOS) in Interrupt Enable Register (Interrupt Disable Register). | 0x1   |



**Final** 

## Table 307: RTC\_STATUS\_REG (0x5000412C)

| Bit | Mode | Symbol                 | Description                                                                                                          | Reset |
|-----|------|------------------------|----------------------------------------------------------------------------------------------------------------------|-------|
| 3   | R    | RTC_VALID_CAL_<br>ALM  | Valid Calendar Alarm. If cleared then indicates that invalid entry occurred when writing to Calendar Alarm Register. | 0x1   |
| 2   | R    | RTC_VALID_TIME_<br>ALM | Valid Time Alarm. If cleared then indicates that invalid entry occurred when writing to Time Alarm Register.         | 0x1   |
| 1   | R    | RTC_VALID_CAL          | Valid Calendar. If cleared then indicates that invalid entry occurred when writing to Calendar Register.             | 0x1   |
| 0   | R    | RTC_VALID_TIME         | Valid Time. If cleared then indicates that invalid entry occurred when writing to Time Register.                     | 0x1   |

## Table 308: RTC\_KEEP\_RTC\_REG (0x50004130)

| Bit | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                           | Reset |
|-----|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | R/W  | RTC_KEEP | Keep RTC. When high, the time and calendar registers and any other registers which directly affect or are affected by the time and calendar registers are NOT reset when software reset is applied. When low, the software reset will reset every register except the keep RTC and control registers. | 0x1   |

**Final** 

# **32.15 SPI Interface Registers**

## Table 309: Register map SPI

| Address    | Register                  | Description                     |
|------------|---------------------------|---------------------------------|
| 0x50001200 | SPI_CTRL_REG              | Spi control register            |
| 0x50001204 | SPI_CONFIG_REG            | Spi control register            |
| 0x50001208 | SPI_CLOCK_REG             | Spi clock register              |
| 0x5000120C | SPI_FIFO_CONFIG_R<br>EG   | Spi fifo configuration register |
| 0x50001210 | SPI_IRQ_MASK_REG          | Spi interrupt mask register     |
| 0x50001214 | SPI_STATUS_REG            | Spi status register             |
| 0x50001218 | SPI_FIFO_STATUS_R<br>EG   | SPI RX/TX fifo status register  |
| 0x5000121C | SPI_FIFO_READ_RE<br>G     | Spi RX fifo read register       |
| 0x50001220 | SPI_FIFO_WRITE_RE<br>G    | Spi TX fifo wtite register      |
| 0x50001224 | SPI_CS_CONFIG_RE<br>G     | Spi cs configuration register   |
| 0x50001228 | SPI_FIFO_HIGH_REG         | Spi TX/RX High 16bit word       |
| 0x5000122C | SPI_TXBUFFER_FOR CE_L_REG | SPI TX buffer force low value   |
| 0x50001230 | SPI_TXBUFFER_FOR CE_H_REG | SPI TX buffer force high value  |

## Table 310: SPI\_CTRL\_REG (0x50001200)

| Bit | Mode | Symbol                       | Description                                                                                                                                                                                                            | Reset |
|-----|------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R/W  | SPI_SWAP_BYTES               | 0 = normal operation 1 = LSB and MSB are swaped in APB interface In case of 8-bit SPI interface, DMA/SPI can be configured in 16-bit mode to off load the bus. Enabling SPI_SWAP_BYTES bytes will read/write correctly | 0x0   |
| 6   | R/W  | SPI_CAPTURE_AT<br>_NEXT_EDGE | 0 = SPI captures data at correct clock edge 1 = SPI captures data at next clock edge. (only for Master mode and high clock)                                                                                            | 0x0   |
| 5   | R/W  | SPI_FIFO_RESET               | 0 = Fifo normal operation<br>1 = Fifo in reset state                                                                                                                                                                   | 0x0   |
| 4   | R/W  | SPI_DMA_RX_EN                | Applicable only when SPI_RX_EN = 1 0 = No DMA request for RX 1 = DMA request when SPI_STATUS_RX_FULL = 1                                                                                                               | 0x0   |
| 3   | R/W  | SPI_DMA_TX_EN                | Applicable only when SPI_TX_EN = 1 0 = No DMA request for TX                                                                                                                                                           | 0x0   |



**Final** 

| Bit | Mode | Symbol    | Description                                                                                                                                 | Reset |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |           | 1 = DMA request when SPI_STATUS_TX_EMPTY = 1                                                                                                |       |
| 2   | R/W  | SPI_RX_EN | 0 = RX path is disabled<br>1 = RX path is enabled<br>Note: if master clk async or spi mode = 1 or spi<br>mode = 3 readonly is not supported | 0x0   |
| 1   | R/W  | SPI_TX_EN | 0 = TX path is disabled<br>1 = TX path is enabled                                                                                           | 0x0   |
| 0   | R/W  | SPI_EN    | 0 = SPI module is disable<br>1 = SPI module is enable                                                                                       | 0x0   |

# Table 311: SPI\_CONFIG\_REG (0x50001204)

| Bit | Mode | Symbol              | Description                                                                                                                                                                                                                                                                                                   | Reset |
|-----|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R/W  | SPI_SLAVE_EN        | 0 = SPI module master mode<br>1 = SPI module slave mode                                                                                                                                                                                                                                                       | 0x0   |
| 6:2 | R/W  | SPI_WORD_LENG<br>TH | Define the spi word length = 1+<br>SPI_WORD_LENGTH (range 4 to 32)                                                                                                                                                                                                                                            | 0x0   |
| 1:0 | R/W  | SPI_MODE            | Define the spi mode (CPOL, CPHA)  0 = new data on falling, capture on rising, clk low in idle state  1 = new data on rising, capture on falling, Clk low in idle state  2 = new data on rising, capture on falling, Clk high in idle state  3 = new data on falling, capture on rising Clk high in idle state | 0x0   |

# Table 312: SPI\_CLOCK\_REG (0x50001208)

| Bit | Mode | Symbol                  | Description                                                                                                                                                                                          | Reset |
|-----|------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7   | R/W  | SPI_MASTER_CLK<br>_MODE | Should be always 1                                                                                                                                                                                   | 0x0   |
| 6:0 | R/W  | SPI_CLK_DIV             | Applicable only in master mode  Defines the SPI clock frequency in master only mode  SPI_CLK = module_clk / 2*(SPI_CLK_DIV+1) when SPI_CLK_DIV not 0x7F  if SPI_CLK_DIV=0x7F then SPI_CLK=module_clk | 0x0   |

**Final** 

### Table 313: SPI\_FIFO\_CONFIG\_REG (0x5000120C)

| Bit | Mode | Symbol    | Description                                                                                                                                                                                               | Reset |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7:4 | R/W  | SPI_RX_TL | Receive FIFO threshold level in bytes. Control the level of bytes in fifo that triggers the RX_FULL interrupt. IRQ is occurred when fifo level is more or equal to SPI_RX_TL+1. Fifo level is from 0 to 4 | 0x0   |
| 3:0 | R/W  | SPI_TX_TL | Transmit FIFO threshold level in bytes. Control the level of bytes in fifo that triggers the TX_EMPTY interrupt. IRQ is occurred when fifo level is less or equal to SPI_TX_TL. Fifo level is from 0 to 4 | 0x0   |

## Table 314: SPI\_IRQ\_MASK\_REG (0x50001210)

| Bit | Mode | Symbol                    | Description                                                        | Reset |
|-----|------|---------------------------|--------------------------------------------------------------------|-------|
| 1   | R/W  | SPI_IRQ_MASK_R<br>X_FULL  | 0 = FIFO RX full irq is masked<br>1 = FIFO RX full irq is enabled  | 0x0   |
| 0   | R/W  | SPI_IRQ_MASK_TX<br>_EMPTY | 0 = FIFO TX empty irq is masked<br>1 = FIFO TX empy irq is enabled | 0x0   |

## Table 315: SPI\_STATUS\_REG (0x50001214)

| Bit | Mode | Symbol                  | Description                                                                                               | Reset |
|-----|------|-------------------------|-----------------------------------------------------------------------------------------------------------|-------|
| 1   | R    | SPI_STATUS_RX_<br>FULL  | Auto clear  0 = RX fifo level is less than SPI_RX_TL+1  1 = RX fifo level is more or equal to SPI_RX_TL+1 | 0x0   |
| 0   | R    | SPI_STATUS_TX_E<br>MPTY | Auto clear  0 = TX fifo level is larger than SPI_TX_TL  1 = TX fifo level is less or equal to SPI_TX_TL   | 0x1   |

### Table 316: SPI\_FIFO\_STATUS\_REG (0x50001218)

| Bit | Mode | Symbol                     | Description                                                                                                                              | Reset |
|-----|------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15  | R    | SPI_TRANSACTIO<br>N_ACTIVE | In master mode  0 = spi transaction is inactive  1 = spi transaction is active                                                           | 0x0   |
| 14  | R    | SPI_RX_FIFO_OVF<br>L       | When 1, receive data is not written to fifo because fifo was full and interrupt is generated. It clears with SPI_CTRL_REG.SPI_FIFO_RESET | 0x0   |



**Final** 

| Bit  | Mode | Symbol                  | Description                                      | Reset |
|------|------|-------------------------|--------------------------------------------------|-------|
| 13   | R    | SPI_STATUS_TX_F<br>ULL  | 0 = TX fifo is not full<br>1 = TX fifo is full   | 0x0   |
| 12   | R    | SPI_STATUS_RX_<br>EMPTY | 0 = RX fifo is not empty<br>1 = RX fifo is empty | 0x1   |
| 11:6 | R    | SPI_TX_FIFO_LEV<br>EL   | Gives the number of bytes in TX fifo             | 0x0   |
| 5:0  | R    | SPI_RX_FIFO_LEV<br>EL   | Gives the number of bytes in RX fifo             | 0x0   |

#### Table 317: SPI\_FIFO\_READ\_REG (0x5000121C)

| Bit  | Mode | Symbol        | Description                                                                                  | Reset |
|------|------|---------------|----------------------------------------------------------------------------------------------|-------|
| 15:0 | R    | SPI_FIFO_READ | Read from RX fifo. Read access is permit only if SPI_STATUS_RX_EMPTY = 0. Returns the 16 LSb | 0x0   |

### Table 318: SPI\_FIFO\_WRITE\_REG (0x50001220)

| Bit  | Mode | Symbol         | Description                                                              | Reset |
|------|------|----------------|--------------------------------------------------------------------------|-------|
| 15:0 | R0/W | SPI_FIFO_WRITE | Write to TX fifo. Write access is permit only if SPI_STATUS_TX_FULL is 0 | 0x0   |

### Table 319: SPI\_CS\_CONFIG\_REG (0x50001224)

| Bit | Mode | Symbol        | Description                                                        | Reset |
|-----|------|---------------|--------------------------------------------------------------------|-------|
| 2:0 | R/W  | SPI_CS_SELECT | Control the cs output in master mode                               | 0x0   |
|     |      |               | 0 = none slave device selected                                     |       |
|     |      |               | 1 = selected slave device connected to GPIO with FUNC_MODE=SPI_CS0 |       |
|     |      |               | 2 = selected slave device connected to GPIO with FUNC_MODE=SPI_CS1 |       |
|     |      |               | 4 = selected slave device connected to GPIO with FUNC_MODE=GPIO    |       |

### Table 320: **SPI\_FIFO\_HIGH\_REG** (0x50001228)

| Bit  | Mode | Symbol        | Description                                                  | Reset |
|------|------|---------------|--------------------------------------------------------------|-------|
| 15:0 | R/W  | SPI_FIFO_HIGH | RX/TX fifo data. 16 MSb when spi word is larger than 16 bits | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                   | Reset |
|-----|------|--------|---------------------------------------------------------------|-------|
|     |      |        | This register has to be written before the SPI_FIFO_WRITE_REG |       |
|     |      |        | This register has to be read after the SPI_FIFO_READ_REG      |       |

### Table 321: SPI\_TXBUFFER\_FORCE\_L\_REG (0x5000122C)

| Bit  | Mode | Symbol                   | Description                                                                 | Reset |
|------|------|--------------------------|-----------------------------------------------------------------------------|-------|
| 15:0 | W    | SPI_TXBUFFER_F<br>ORCE_L | Write directly the tx buffer (2 LSB). It must to be used only in slave mode | 0x0   |

## Table 322: SPI\_TXBUFFER\_FORCE\_H\_REG (0x50001230)

| Bit  | Mode | Symbol                   | Description                                                                                                                                | Reset |
|------|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:0 | W    | SPI_TXBUFFER_F<br>ORCE_H | Write directly the tx buffer (2 MSB). It must to be used only in slave mode. This register has to be written before the SPI_FIFO_WRITE_REG | 0x0   |

**Final** 

# **32.16 Timer and Triple PWM Registers**

### Table 323: Register map Timer+3PWM

| Address    | Register                 | Description                       |
|------------|--------------------------|-----------------------------------|
| 0x50003400 | TIMER0_CTRL_REG          | Timer0 control register           |
| 0x50003402 | TIMER0_ON_REG            | Timer0 on control register        |
| 0x50003404 | TIMERO_RELOAD_M_<br>REG  | 16 bits reload value for Timer0   |
| 0x50003406 | TIMERO_RELOAD_N_<br>REG  | 16 bits reload value for Timer0   |
| 0x50003408 | TRIPLE_PWM_FREQ<br>UENCY | Frequency for PWM 2,3,4,5,6 and 7 |
| 0x5000340A | PWM2_START_CYCL<br>E     | Defines start Cycle for PWM2      |
| 0x5000340C | PWM3_START_CYCL<br>E     | Defines start Cycle for PWM3      |
| 0x5000340E | PWM4_START_CYCL<br>E     | Defines start Cycle for PWM4      |
| 0x50003410 | PWM5_START_CYCL<br>E     | Defines start Cycle for PWM5      |
| 0x50003412 | PWM6_START_CYCL<br>E     | Defines start Cycle for PWM6      |
| 0x50003414 | PWM7_START_CYCL<br>E     | Defines start Cycle for PWM7      |
| 0x50003416 | PWM2_END_CYCLE           | Defines end Cycle for PWM2        |
| 0x50003418 | PWM3_END_CYCLE           | Defines end Cycle for PWM3        |
| 0x5000341A | PWM4_END_CYCLE           | Defines end Cycle for PWM4        |
| 0x5000341C | PWM5_END_CYCLE           | Defines end Cycle for PWM5        |
| 0x5000341E | PWM6_END_CYCLE           | Defines end Cycle for PWM6        |
| 0x50003420 | PWM7_END_CYCLE           | Defines end Cycle for PWM7        |
| 0x50003422 | TRIPLE_PWM_CTRL_<br>REG  | PWM 2,3,4,5,6,7 Control           |

## Table 324: TIMER0\_CTRL\_REG (0x50003400)

| Bit  | Mode | Symbol       | Description                                                                                                                                                                                  | Reset |
|------|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:4 | -    | -            | Reserved                                                                                                                                                                                     | 0x0   |
| 3    | R/W  | PWM_MODE     | <ul> <li>0 = PWM signals are 1 during high time.</li> <li>1 = PWM signals send out the (fast) clock divided by 2 during high time. So it will be in the range of 1 to 8 MHz.</li> </ul>      | 0x0   |
| 2    | R/W  | TIM0_CLK_DIV | <ul> <li>1 = Timer0 uses selected clock frequency as is.</li> <li>0 = Timer0 uses selected clock frequency divided by 10.</li> <li>Note that this applies only to the ON-counter.</li> </ul> | 0x0   |



**Final** 

| Bit | Mode | Symbol       | Description                                                                              | Reset |
|-----|------|--------------|------------------------------------------------------------------------------------------|-------|
| 1   | R/W  | TIM0_CLK_SEL | 1 = Timer0 uses 16, 8, 4, or 2 MHz (fast) clock<br>frequency<br>0 = Timer0 uses LP clock | 0x0   |
| 0   | R/W  | TIM0_CTRL    | 0 = Timer0 is off and in reset state<br>1 = Timer0 is running                            | 0x0   |

#### Table 325: TIMERO\_ON\_REG (0x50003402)

| Bit  | Mode | Symbol  | Description                                     | Reset |
|------|------|---------|-------------------------------------------------|-------|
| 15:0 | R/W  | TIM0_ON | Timer0 On reload value:                         | 0x0   |
|      |      |         | If read the actual ON-counter value is returned |       |

### Table 326: TIMERO\_RELOAD\_M\_REG (0x50003404)

| Bit  | Mode | Symbol | Description                                     | Reset |
|------|------|--------|-------------------------------------------------|-------|
| 15:0 | R/W  | TIM0_M | Timer0 'high' reload value                      | 0x0   |
|      |      |        | If read the actual T0-counter value is returned |       |

### Table 327: TIMERO\_RELOAD\_N\_REG (0x50003406)

| Bit  | Mode | Symbol | Description                                     | Reset |
|------|------|--------|-------------------------------------------------|-------|
| 15:0 | R/W  | TIM0_N | Timer0 'low' reload value:                      | 0x0   |
|      |      |        | If read the actual T0-counter value is returned |       |

### Table 328: TRIPLE\_PWM\_FREQUENCY (0x50003408)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                             | Reset |
|------|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | PWM_FREQ | Defines the frequeancy of PWM 2,3,4,5,,6 and 7. pwm freq = module Frequency / (value+1) module frequency is the LP_CLK when TRIPLE_PWM_CLK_SEL=0 else is the sys_clk divided by TMR_DIV | 0x0   |

### Table 329: PWM2\_START\_CYCLE (0x5000340A)

| Bit  | Mode | Symbol      | Description                                                                                                                                   | Reset |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | START_CYCLE | Defines the cycle in which the PWM becomes high. if start_cycle is larger than freq or end_cycle is equal to start_cycle, pwm out is always 0 | 0x0   |



**Final** 

### Table 330: PWM3\_START\_CYCLE (0x5000340C)

| Bit  | Mode | Symbol      | Description                                                                                                                                   | Reset |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | START_CYCLE | Defines the cycle in which the PWM becomes high. if start_cycle is larger than freq or end_cycle is equal to start_cycle, pwm out is always 0 | 0x0   |

#### Table 331: PWM4\_START\_CYCLE (0x5000340E)

| Bit  | Mode | Symbol      | Description                                                                                                                                   | Reset |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | START_CYCLE | Defines the cycle in which the PWM becomes high. if start_cycle is larger than freq or end_cycle is equal to start_cycle, pwm out is always 0 | 0x0   |

#### Table 332: PWM5\_START\_CYCLE (0x50003410)

| Bit  | Mode | Symbol      | Description                                                                                                                                   | Reset |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | START_CYCLE | Defines the cycle in which the PWM becomes high. if start_cycle is larger than freq or end_cycle is equal to start_cycle, pwm out is always 0 | 0x0   |

### Table 333: PWM6\_START\_CYCLE (0x50003412)

| Bit  | Mode | Symbol      | Description                                                                                                                                   | Reset |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | START_CYCLE | Defines the cycle in which the PWM becomes high. if start_cycle is larger than freq or end_cycle is equal to start_cycle, pwm out is always 0 | 0x0   |

### Table 334: PWM7\_START\_CYCLE (0x50003414)

| Bit  | Mode | Symbol      | Description                                                                                                                                   | Reset |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | START_CYCLE | Defines the cycle in which the PWM becomes high. if start_cycle is larger than freq or end_cycle is equal to start_cycle, pwm out is always 0 | 0x0   |

#### Table 335: PWM2\_END\_CYCLE (0x50003416)

| Bit  | Mode | Symbol    | Description                                                                                                                                  | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | END_CYCLE | Defines the cycle in which the PWM becomes low. If end_cycle is larger then freq and start_cycle is not larger then freq, output is always 1 | 0x0   |

**Final** 

### Table 336: PWM3\_END\_CYCLE (0x50003418)

| Bit  | Mode | Symbol    | Description                                                                                                                                  | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | END_CYCLE | Defines the cycle in which the PWM becomes low. If end_cycle is larger then freq and start_cycle is not larger then freq, output is always 1 | 0x0   |

#### Table 337: PWM4\_END\_CYCLE (0x5000341A)

| Bit  | Mode | Symbol    | Description                                                                                                                                  | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | END_CYCLE | Defines the cycle in which the PWM becomes low. If end_cycle is larger then freq and start_cycle is not larger then freq, output is always 1 | 0x0   |

### Table 338: PWM5\_END\_CYCLE (0x5000341C)

| Bit  | Mode | Symbol    | Description                                                                                                                                  | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | END_CYCLE | Defines the cycle in which the PWM becomes low. If end_cycle is larger then freq and start_cycle is not larger then freq, output is always 1 | 0x0   |

### Table 339: PWM6\_END\_CYCLE (0x5000341E)

| Bit  | Mode | Symbol    | Description                                                                                                                                  | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | END_CYCLE | Defines the cycle in which the PWM becomes low. If end_cycle is larger then freq and start_cycle is not larger then freq, output is always 1 | 0x0   |

### Table 340: PWM7\_END\_CYCLE (0x50003420)

| Bit  | Mode | Symbol    | Description                                                                                                                                  | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 13:0 | R/W  | END_CYCLE | Defines the cycle in which the PWM becomes low. If end_cycle is larger then freq and start_cycle is not larger then freq, output is always 1 | 0x0   |

#### Table 341: TRIPLE\_PWM\_CTRL\_REG (0x50003422)

| Bit | Mode | Symbol                 | Description                                               | Reset |
|-----|------|------------------------|-----------------------------------------------------------|-------|
| 3   | R/W  | TRIPLE_PWM_CLK<br>_SEL | 1 = Timer2 uses 16, 8, 4, or 2 MHz (fast) clock frequency | 0x0   |
|     |      |                        | 0 = Timer2 uses LP clock                                  |       |
| 2   | R/W  | HW_PAUSE_EN            | 1 = HW can pause PWM 2,3,4,5,6,7                          | 0x1   |
| 1   | R/W  | SW_PAUSE_EN            | 1 = PWM 2 3 4 5 6 7 are paused                            | 0x0   |
| 0   | R/W  | TRIPLE_PWM_ENA<br>BLE  | 1 = Enable PWM 2 3 4 5 6 7                                | 0x0   |

**Final** 

# 32.17 Timer1 Registers

#### Table 342: Register map Timer1

| Address    | Register                     | Description                     |
|------------|------------------------------|---------------------------------|
| 0x50004000 | TIMER1_CTRL_REG              | Timer1 control register         |
| 0x50004004 | TIMER1_CAPTURE_R<br>EG       | Timer1 Capture control register |
| 0x50004008 | TIMER1_STATUS_RE G           | Timer1 counter value            |
| 0x5000400C | TIMER1_CAPCNT1_V<br>ALUE_REG | Timer1 value for event on GPIO1 |
| 0x50004010 | TIMER1_CAPCNT2_V<br>ALUE_REG | Timer1 value for event on GPIO2 |
| 0x50004014 | TIMER1_CLR_EVENT _REG        | Clear event register            |

#### Table 343: TIMER1\_CTRL\_REG (0x50004000)

| Bit  | Mode | Symbol                      | Description                                                                                                                                      | Reset |
|------|------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 16   | R/W  | TIMER1_CLK_EN               | 0 = timer1 clock is disabled<br>1 = timer1 clock is enabled                                                                                      | 0x0   |
| 15   | R/W  | TIMER1_USE_SYS<br>_CLK      | 0 = Timer1 use the clock LP clock 1 = Timer1 use the system clock                                                                                | 0x0   |
| 14   | R/W  | TIMER1_FREE_RU<br>N_MODE_EN | Applicable when timer counts up  1 = timer1 goes to zero when it reaches the max value  0 = timer1 goes to zero when it reaches the reload value | 0x0   |
| 13   | R/W  | TIMER1_IRQ_EN               | 0 = timer1 IRQ masked<br>1 = timer1 IRQ unmasked                                                                                                 | 0x0   |
| 12   | R/W  | TIMER1_COUNT_D<br>OWN_EN    | 0 = timer1 counts up<br>1 = timer1 counts down                                                                                                   | 0x0   |
| 11   | R/W  | TIMER1_ENABLE               | 0 = Timer1 disabled<br>1 = Timer1 enabled                                                                                                        | 0x0   |
| 10:0 | R/W  | TIMER1_RELOAD               | Reload or max value in timer mode. Actual delay is the register value plus synchronization time (3 clock cycles)                                 | 0x0   |

#### Table 344: TIMER1\_CAPTURE\_REG (0x50004004)

| Bit   | Mode | Symbol                    | Description                                                                             | Reset |
|-------|------|---------------------------|-----------------------------------------------------------------------------------------|-------|
| 27    | R/W  | TIMER1_IN2_STAM<br>P_TYPE | 0 = On each event store the counter value<br>1 = On each event store the RTC time stamp | 0x0   |
| 26:21 | R/W  | TIMER1_IN2_PERI<br>OD_MAX | Gives the number of periods +1 of IN2, in which module counts                           | 0x0   |



**Final** 

| Bit   | Mode | Symbol                       | Description                                                                                                                 | Reset |
|-------|------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------|
| 20    | R/W  | TIMER1_IN2_IRQ_<br>EN        | 1 = Interrupt is generated when capture is occurred or was counted<br>TIMER1_IN2_PERIOD_MAX                                 | 0x0   |
|       |      |                              | 0 = Interrupt is masked                                                                                                     |       |
| 19    | R/W  | TIMER1_IN2_COU               | 0 = Capture mode                                                                                                            | 0x0   |
|       |      | NT_EN                        | 1 = Count mode                                                                                                              |       |
| 18    | R/W  | TIMER1_IN2_EVEN<br>T_FALL_EN | 0 = Rising edge event 1 = Falling edge event it should be written when TIMER1_GPIO2_CONF=0 to prevent false events          | 0x0   |
| 17:14 | R/W  | TIMER1_GPIO2_C<br>ONF        | 0,13,14,15 = IN2 is not used 112 = Defines the P0 pin (011) module will use as IN2                                          | 0x0   |
| 13    | R/W  | TIMER1_IN1_STAM<br>P_TYPE    | 0 = On each event store the counter value<br>1 = On each event store the RTC time stamp                                     | 0x0   |
| 12:7  | R/W  | TIMER1_IN1_PERI<br>OD_MAX    | Gives the number of periods +1 of IN1, in which module counts                                                               | 0x0   |
| 6     | R/W  | TIMER1_IN1_IRQ_<br>EN        | 1 = Interrupt is generated when capture is occurred or was counted TIMER1_IN1_PERIOD_MAX 0 = Interrupt is masked            | 0x0   |
| 5     | R/W  | TIMER1_IN1_COU<br>NT_EN      | 0 = Capture mode<br>1 = Count mode                                                                                          | 0x0   |
| 4     | R/W  | TIMER1_IN1_EVEN<br>T_FALL_EN | 0 = Rising edge event<br>1 = Falling edge event<br>it should be written when<br>TIMER1_GPIO1_CONF=0 to prevent false events | 0x0   |
| 3:0   | R/W  | TIMER1_GPIO1_C<br>ONF        | 0,13,14,15 = IN1 is not used 112 = Defines the P0 pin (011) module will use as IN1                                          | 0x0   |

# Table 345: TIMER1\_STATUS\_REG (0x50004008)

| Bit | Mode | Symbol                 | Description                                                                                                                | Reset |
|-----|------|------------------------|----------------------------------------------------------------------------------------------------------------------------|-------|
| 15  | R    | TIMER1_IN2_OVRF<br>LW  | 1 = New IN2 event occurred while Interrupt was pending.  TIMER1_CAPCNT2_VALUE_REG gives the time stamp of the first event. | 0x0   |
| 14  | R    | TIMER1_IN1_OVRF<br>LW  | 1 = New IN1 event occurred while Interrupt was pending.  TIMER1_CAPCNT1_VALUE_REG gives the time stamp of the first event. | 0x0   |
| 13  | R    | TIMER1_IN2_EVEN<br>T   | 1 = Pending Capture 2 interrupt. It has be clear writing 1 to TIMER1_CLR_IN2_EVENT                                         | 0x0   |
| 12  | R    | TIMER1_IN1_EVEN<br>T   | 1 = Pending Capture 1 interrupt. It has be clear writing 1 to TIMER1_CLR_IN1_EVENT                                         | 0x0   |
| 11  | R    | TIMER1_TIMER_E<br>VENT | 1 = Pending Timer interrupt. it has be clear writing 1' to TIMER1_CLR_TIMER_EVENT                                          | 0x0   |



**Final** 

| Bit  | Mode | Symbol                 | Description                   | Reset |
|------|------|------------------------|-------------------------------|-------|
| 10:0 | R    | TIMER1_TIMER_V<br>ALUE | Gives the current timer value | 0x0   |

#### Table 346: TIMER1\_CAPCNT1\_VALUE\_REG (0x5000400C)

| Bit   | Mode | Symbol                      | Description                                                                                                                                                                                                                      | Reset |
|-------|------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 21:11 | R    | TIMER1_CAPCNT1<br>_RTC_HIGH | In Counter mode : Not used In Capture mode: Gives the RTC time stamp (high part) when an IN1 event was occurred                                                                                                                  | 0x0   |
| 10:0  | R    | TIMER1_CAPCNT1<br>_VALUE    | In Counter mode: Gives the number of timer clock cycles minus 1 which was measured during TIMER1_IN1_PERIOD_MAX periods of IN1 In Capture mode (TIMER1_IN1_STAMP_TYPE=0): Gives the Counter value when an IN1 event was occurred | 0x0   |
|       |      |                             | In Capture mode (TIMER1_IN1_STAMP_TYPE=1): Gives the RTC time stamp (low part) when an IN1 event was occurred                                                                                                                    |       |

## Table 347: TIMER1\_CAPCNT2\_VALUE\_REG (0x50004010)

| Bit   | Mode | Symbol                      | Description                                                                                                                                                                                                                                                                                                                                    | Reset |
|-------|------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 21:11 | R    | TIMER1_CAPCNT2<br>_RTC_HIGH | In Counter mode: Not used In Capture mode: Gives the RTC time stamp (high part) when an IN2 event was occurred                                                                                                                                                                                                                                 | 0x0   |
| 10:0  | R    | TIMER1_CAPCNT2<br>_VALUE    | In Counter mode: Gives the number of timer clock cycles minus 1 which was measured during TIMER1_IN2_PERIOD_MAX periods of IN2 In Capture mode (TIMER1_IN2_STAMP_TYPE=0): Gives the Counter value when an IN2 event was occurred In Capture mode (TIMER1_IN2_STAMP_TYPE=1): Gives the RTC time stamp (low part) when an IN2 event was occurred | 0x0   |

#### Table 348: TIMER1\_CLR\_EVENT\_REG (0x50004014)

| Bit | Mode  | Symbol                     | Description                                                 | Reset |
|-----|-------|----------------------------|-------------------------------------------------------------|-------|
| 2   | R0/WC | TIMER1_CLR_IN2_<br>EVENT   | Write 1 to clear the TIMER1_IN2_EVENT and TIMER1_IN2_OVRFLW | 0x0   |
| 1   | R0/WC | TIMER1_CLR_IN1_<br>EVENT   | Write 1 to clear the TIMER1_IN1_EVENT and TIMER1_IN1_OVRFLW | 0x0   |
| 0   | R0/WC | TIMER1_CLR_TIME<br>R_EVENT | Write 1 to clear the TIMER1_TIMER_EVENT                     | 0x0   |



**Final** 

# **32.18 UART Interface Registers**

## Table 349: Register map UART

| Address    | Register                 | Description                                                         |
|------------|--------------------------|---------------------------------------------------------------------|
| 0x50001000 | UART_RBR_THR_DL<br>L_REG | Receive Buffer Register/Transmit Holding Register/Divisor Latch Low |
| 0x50001004 | UART_IER_DLH_REG         | Interrupt Enable Register/Divisor Latch High                        |
| 0x50001008 | UART_IIR_FCR_REG         | Interrupt Identification Register/FIFO Control Register             |
| 0x5000100C | UART_LCR_REG             | Line Control Register                                               |
| 0x50001010 | UART_MCR_REG             | Modem Control Register                                              |
| 0x50001014 | UART_LSR_REG             | Line Status Register                                                |
| 0x50001018 | UART_MSR_REG             | Modem Status Register                                               |
| 0x5000101C | UART_SCR_REG             | Scratchpad Register                                                 |
| 0x50001030 | UART_SRBR_STHR0<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001034 | UART_SRBR_STHR1<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001038 | UART_SRBR_STHR2<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x5000103C | UART_SRBR_STHR3<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001040 | UART_SRBR_STHR4<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001044 | UART_SRBR_STHR5<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001048 | UART_SRBR_STHR6<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x5000104C | UART_SRBR_STHR7<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001050 | UART_SRBR_STHR8<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001054 | UART_SRBR_STHR9<br>_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001058 | UART_SRBR_STHR1<br>0_REG | Shadow Receive/Transmit Buffer Register                             |
| 0x5000105C | UART_SRBR_STHR1<br>1_REG | Shadow Receive/Transmit Buffer Register                             |
| 0x50001060 | UART_SRBR_STHR1<br>2_REG | Shadow Receive/Transmit Buffer Register                             |
| 0x50001064 | UART_SRBR_STHR1<br>3_REG | Shadow Receive/Transmit Buffer Register                             |
| 0x50001068 | UART_SRBR_STHR1<br>4_REG | Shadow Receive/Transmit Buffer Register                             |
| 0x5000106C | UART_SRBR_STHR1<br>5_REG | Shadow Receive/Transmit Buffer Register                             |
| 0x50001070 | UART_FAR_REG             | FIFO Access Register                                                |



**Final** 

| Address    | Register                  | Description                                                         |
|------------|---------------------------|---------------------------------------------------------------------|
| 0x5000107C | UART_USR_REG              | UART Status Register                                                |
| 0x50001080 | UART_TFL_REG              | Transmit FIFO Level                                                 |
| 0x50001084 | UART_RFL_REG              | Receive FIFO Level                                                  |
| 0x50001088 | UART_SRR_REG              | Software Reset Register.                                            |
| 0x5000108C | UART_SRTS_REG             | Shadow Request to Send                                              |
| 0x50001090 | UART_SBCR_REG             | Shadow Break Control Register                                       |
| 0x50001094 | UART_SDMAM_REG            | Shadow DMA Mode                                                     |
| 0x50001098 | UART_SFE_REG              | Shadow FIFO Enable                                                  |
| 0x5000109C | UART_SRT_REG              | Shadow RCVR Trigger                                                 |
| 0x500010A0 | UART_STET_REG             | Shadow TX Empty Trigger                                             |
| 0x500010A4 | UART_HTX_REG              | Halt TX                                                             |
| 0x500010A8 | UART_DMASA_REG            | DMA Software Acknowledge                                            |
| 0x500010C0 | UART_DLF_REG              | Divisor Latch Fraction Register                                     |
| 0x500010F8 | UART_UCV_REG              | Component Version                                                   |
| 0x500010FA | UART_UCV_HIGH_R<br>EG     | Component Version                                                   |
| 0x500010FC | UART_CTR_REG              | Component Type Register                                             |
| 0x500010FE | UART_CTR_HIGH_R<br>EG     | Component Type Register                                             |
| 0x50001100 | UART2_RBR_THR_D<br>LL_REG | Receive Buffer Register/Transmit Holding Register/Divisor Latch Low |
| 0x50001104 | UART2_IER_DLH_RE<br>G     | Interrupt Enable Register/Divisor Latch High                        |
| 0x50001108 | UART2_IIR_FCR_RE<br>G     | Interrupt Identification Register/FIFO Control Register             |
| 0x5000110C | UART2_LCR_REG             | Line Control Register                                               |
| 0x50001110 | UART2_MCR_REG             | Modem Control Register                                              |
| 0x50001114 | UART2_LSR_REG             | Line Status Register                                                |
| 0x5000111C | UART2_SCR_REG             | Scratchpad Register                                                 |
| 0x50001130 | UART2_SRBR_STHR<br>0_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001134 | UART2_SRBR_STHR<br>1_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001138 | UART2_SRBR_STHR<br>2_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x5000113C | UART2_SRBR_STHR<br>3_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001140 | UART2_SRBR_STHR<br>4_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001144 | UART2_SRBR_STHR<br>5_REG  | Shadow Receive/Transmit Buffer Register                             |
| 0x50001148 | UART2_SRBR_STHR<br>6_REG  | Shadow Receive/Transmit Buffer Register                             |

**Final** 

| Address    | Register                  | Description                             |
|------------|---------------------------|-----------------------------------------|
| 0x5000114C | UART2_SRBR_STHR<br>7_REG  | Shadow Receive/Transmit Buffer Register |
| 0x50001150 | UART2_SRBR_STHR<br>8_REG  | Shadow Receive/Transmit Buffer Register |
| 0x50001154 | UART2_SRBR_STHR<br>9_REG  | Shadow Receive/Transmit Buffer Register |
| 0x50001158 | UART2_SRBR_STHR<br>10_REG | Shadow Receive/Transmit Buffer Register |
| 0x5000115C | UART2_SRBR_STHR<br>11_REG | Shadow Receive/Transmit Buffer Register |
| 0x50001160 | UART2_SRBR_STHR<br>12_REG | Shadow Receive/Transmit Buffer Register |
| 0x50001164 | UART2_SRBR_STHR<br>13_REG | Shadow Receive/Transmit Buffer Register |
| 0x50001168 | UART2_SRBR_STHR<br>14_REG | Shadow Receive/Transmit Buffer Register |
| 0x5000116C | UART2_SRBR_STHR<br>15_REG | Shadow Receive/Transmit Buffer Register |
| 0x50001170 | UART2_FAR_REG             | FIFO Access Register                    |
| 0x5000117C | UART2_USR_REG             | UART Status Register                    |
| 0x50001180 | UART2_TFL_REG             | Transmit FIFO Level                     |
| 0x50001184 | UART2_RFL_REG             | Receive FIFO Level                      |
| 0x50001188 | UART2_SRR_REG             | Software Reset Register.                |
| 0x50001190 | UART2_SBCR_REG            | Shadow Break Control Register           |
| 0x50001194 | UART2_SDMAM_REG           | Shadow DMA Mode                         |
| 0x50001198 | UART2_SFE_REG             | Shadow FIFO Enable                      |
| 0x5000119C | UART2_SRT_REG             | Shadow RCVR Trigger                     |
| 0x500011A0 | UART2_STET_REG            | Shadow TX Empty Trigger                 |
| 0x500011A4 | UART2_HTX_REG             | Halt TX                                 |
| 0x500011A8 | UART2_DMASA_REG           | DMA Software Acknowledge                |
| 0x500011C0 | UART2_DLF_REG             | Divisor Latch Fraction Register         |
| 0x500011F8 | UART2_UCV_REG             | Component Version                       |
| 0x500011FA | UART2_UCV_HIGH_R<br>EG    | Component Version                       |
| 0x500011FC | UART2_CTR_REG             | Component Type Register                 |
| 0x500011FE | UART2_CTR_HIGH_R<br>EG    | Component Type Register                 |

#### Table 350: **UART\_RBR\_THR\_DLL\_REG** (0x50001000)

| Bit  | Mode | Symbol      | Description                     | Reset |
|------|------|-------------|---------------------------------|-------|
| 15:8 | -    | -           | Reserved                        | 0x0   |
| 7:0  | R/W  | RBR_THR_DLL | Receive Buffer Register: (RBR). | 0x0   |

**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|-----|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | This register contains the data byte received on the serial input port (sin) in UART mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. |       |
|     |      |        | Transmit Holding Register: (THR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |        | This register contains data to be transmitted on the serial output port (sout) in UART mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, 16 number of characters of data may be written to the THR before the FIFO is full results in the write data being lost.                                                                                                                 |       |
|     |      |        | Divisor Latch (Low): (DLL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |
|     |      |        | This register makes up the lower 8-bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set. The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows:                                                                                                                                                                                                                                                                                                                                                    |       |
|     |      |        | baud rate = (serial clock freq) / (16 * divisor)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |        | Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications will occur. Also, once the Divisor Latch is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.                                                                                                                                                                                                                                                                                                                                                                                                              |       |
|     |      |        | For the Divisor Latch (High) bits, see register UART_IER_DLH_REG.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |

# Table 351: UART\_IER\_DLH\_REG (0x50001004)

| Bit  | Mode | Symbol     | Description                                                                                                                                                           | Reset |
|------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                              | 0x0   |
| 7    | R/W  | PTIME_dlh7 | Interrupt Enable Register: PTIME, Programmable THRE Interrupt Mode Enable. This is used to enable/disable the generation of THRE Interrupt. 0 = disabled 1 = enabled. | 0x0   |
|      |      |            | Divisor Latch (High): DLH7, Bit 7 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This            |       |



Final

| Bit | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |            | register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                                                                                                                                                                                                 |       |
| 6:4 | R/W  | dlh6_4     | Divisor Latch (High): DLH6 to DLH4, Bits 6 to 4 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set, otherwise, this field is reserved. See register UART_RBR_THR_DLL_REG.     | 0x0   |
| 3   | R/W  | EDSSI_dlh3 | Interrupt Enable Register: EDSSI, Enable Modem Status Interrupt. This is used to enable/disable the generation of Modem Status Interrupt. This is the fourth highest priority interrupt. 0 = disabled 1 = enabled                                                                                                   | 0x0   |
|     |      |            | Divisor Latch (High): DLH3, Bit 3 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                                      |       |
| 2   | R/W  | ELSI_dhl2  | Interrupt Enable Register: ELSI, Enable Receiver Line Status Interrupt. This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt. 0 = disabled 1 = enabled                                                                                           | 0x0   |
|     |      |            | Divisor Latch (High): DLH2, Bit 2 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                                      |       |
| 1   | R/W  | ETBEI_dlh1 | Interrupt Enable Register: ETBEI, Enable Transmit Holding Register Empty Interrupt. This is used to enable/disable the generation of Transmitter Holding Register Empty Interrupt. This is the third highest priority interrupt. 0 = disabled 1 = enabled                                                           | 0x0   |
|     |      |            | Divisor Latch (High): DLH1, Bit 1 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                                      |       |
| 0   | R/W  | ERBFI_dlh0 | Interrupt Enable Register: ERBFI, Enable Received Data Available Interrupt. This is used to enable/disable the generation of Received Data Available Interrupt and the Character Timeout Interrupt (if in FIFO mode and FIFO's enabled). These are the second highest priority interrupts. 0 = disabled 1 = enabled | 0x0   |
|     |      |            | Divisor Latch (High): DLH0, Bit 0 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                                      |       |

**Final** 

## Table 352: **UART\_IIR\_FCR\_REG** (0x50001008)

| Bit | Mode | Symbol          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset |
|-----|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7:6 | R/W  | UART_FIFOSE_RT  | On read FIFO's Enabled (or FIFOSE): This is used to indicate whether the FIFO's are enabled or disabled. 00 = disabled. 11 = enabled. On write RCVR Trigger (or RT):. This is used to select the                                                                                                                                                                                                                                                | 0x0   |
|     |      |                 | trigger level in the receiver FIFO at which the Received Data Available Interrupt will be generated. In auto flow control mode it is used to determine when the rts_n signal will be deasserted. It also determines when the dma_rx_req_n signal will be asserted when in certain modes of operation. The following trigger levels are supported: 00 = 1 character in the FIFO 01 = FIFO 1/4 full 10 = FIFO 1/2 full 11 = FIFO 2 less than full |       |
| 5:4 | R0/W | UART_TET        | On read                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
|     |      |                 | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |
|     |      |                 | On Write  TX Empty Trigger (or TET): This is used to select the empty threshold level at which the THRE Interrupts will be generated when the mode is active. It also determines when the dma_tx_req_n signal will be asserted when in certain modes of operation. The following trigger levels are supported: 00 = FIFO empty 01 = 2 characters in the FIFO 10 = FIFO 1/4 full 11 = FIFO 1/2 full                                              |       |
| 3   | R/W  | UART_IID3_DMAM  | On Read (Bit3)                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
|     |      |                 | Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:                                                                                                                                                                                                                                                                                                                           |       |
|     |      |                 | 0001 = no interrupt pending.                                                                                                                                                                                                                                                                                                                                                                                                                    |       |
|     |      |                 | 0010 = THR empty.                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |                 | 0100 = received data available.                                                                                                                                                                                                                                                                                                                                                                                                                 |       |
|     |      |                 | 0110 = receiver line status.<br>0111 = busy detect.                                                                                                                                                                                                                                                                                                                                                                                             |       |
|     |      |                 | 1100 = character timeout.                                                                                                                                                                                                                                                                                                                                                                                                                       |       |
|     |      |                 | On Write                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |
|     |      |                 | DMA Mode (or DMAM): This determines the DMA signalling mode used for the dma_tx_req_n and dma_rx_req_n output signals. 0 = mode 0 1 = mode 1                                                                                                                                                                                                                                                                                                    |       |
| 2   | R/W  | UART_IID2_XFIFO | On Read (Bit2)                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
|     |      | R               | Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:                                                                                                                                                                                                                                                                                                                           |       |
|     |      |                 | 0001 = no interrupt pending.                                                                                                                                                                                                                                                                                                                                                                                                                    |       |
|     |      |                 | 0010 = THR empty.                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |                 | 0100 = received data available.                                                                                                                                                                                                                                                                                                                                                                                                                 |       |
|     |      |                 | 0110 = receiver line status.                                                                                                                                                                                                                                                                                                                                                                                                                    |       |
|     |      |                 | 0111 = busy detect.<br>1100 = character timeout.                                                                                                                                                                                                                                                                                                                                                                                                |       |
|     |      |                 | i ioo = character timeout.                                                                                                                                                                                                                                                                                                                                                                                                                      |       |



**Final** 

| Bit | Mode | Symbol               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset |
|-----|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                      | On Write  XMIT FIFO Reset (or XFIFOR): This resets the control portion of the transmit FIFO and treats the FIFO as empty. Note that this bit is 'self-clearing' and it is not necessary to clear this bit.                                                                                                                                                                                                                                                                                                              |       |
| 1   | R/W  | UART_IID1_RFIFO<br>E | On Read (Bit1) Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:  0001 = no interrupt pending.  0010 = THR empty.  0100 = received data available.  0110 = receiver line status.  0111 = busy detect.  1100 = character timeout.  On Write  RCVR FIFO Reset (or RFIFOR): This resets the control portion of the receive FIFO and treats the FIFO as empty. Note that this bit is 'self-clearing' and it is not necessary to clear this bit.         | 0x0   |
| 0   | R/W  | UART_IID0_FIFOE      | On Read (Bit0) Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:  0001 = no interrupt pending.  0010 = THR empty.  0100 = received data available.  0110 = receiver line status.  0111 = busy detect.  1100 = character timeout.  On Write FIFO Enable (or FIFOE): This enables/disables the transmit (XMIT) and receive (RCVR) FIFO's. Whenever the value of this bit is changed both the XMIT and RCVR controller portion of FIFO's will be reset | 0x1   |

## Table 353: UART\_LCR\_REG (0x5000100C)

| Bit  | Mode | Symbol    | Description                                                                                                                                           | Reset |
|------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -         | Reserved                                                                                                                                              | 0x0   |
| 7    | R/W  | UART_DLAB | Divisor Latch Access Bit. Writeable only when UART is not busy (USR[0] is zero).                                                                      | 0x0   |
|      |      |           | This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART.                          |       |
|      |      |           | This bit must be cleared after initial baud rate setup in order to access other registers.                                                            |       |
| 6    | R/W  | UART_BC   | Break Control Bit.                                                                                                                                    | 0x0   |
|      |      |           | This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) |       |

**Final** 

| Bit | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |           | state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If active (MCR[6] set to one) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low.                                                                                                                                                                                                                                                                          |       |
| 5   | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0   |
| 4   | R/W  | UART_EPS  | Even Parity Select. Writeable only when UART is not busy (USR[0] is zero).  This is used to select between even and odd parity, when parity is enabled (PEN set to one). If set to one, an even number of logic 1 s is transmitted or checked. If set to zero, an odd number of logic 1 s is transmitted or checked.                                                                                                                                                                                                                                                                                | 0x0   |
| 3   | R/W  | UART_PEN  | Parity Enable. Writeable only when UART is not busy (USR[0] is zero)  This bit is used to enable and disable parity generation and detection in transmitted and received serial character respectively.  0 = parity disabled  1 = parity enabled                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
| 2   | R/W  | UART_STOP | Number of stop bits.Writeable only when UART is not busy (USR[0] is zero).  This is used to select the number of stop bits per character that the peripheral transmits and receives. If set to zero, one stop bit is transmitted in the serial data.  If set to one and the data bits are set to 5 (LCR[1:0] set to zero) one and a half stop bits is transmitted. Otherwise, two stop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.  0 = 1 stop bit  1 = 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit | 0x0   |
| 1:0 | R/W  | UART_DLS  | Data Length Select.Writeable only when UART is not busy (USR[0] is zero).  This is used to select the number of data bits per character that the peripheral transmits and receives. The number of bit that may be selected areas follows:  00 = 5 bits 01 = 6 bits 10 = 7 bits 11 = 8 bits                                                                                                                                                                                                                                                                                                          | 0x0   |

#### Table 354: UART\_MCR\_REG (0x50001010)

| Bit  | Mode | Symbol | Description | Reset |
|------|------|--------|-------------|-------|
| 15:7 | -    | -      | Reserved    | 0x0   |
| 6    | -    | -      | Reserved    | 0x0   |



**Final** 

| Bit | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 5   | R/W  | UART_AFCE | Auto Flow Control Enable.  When FIFOs are enabled and the Auto Flow Control Enable (AFCE) bit is set, Auto Flow Control features are enabled.  0 = Auto Flow Control Mode disabled 1 = Auto Flow Control Mode enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0   |
| 4   | R/W  | UART_LB   | LoopBack Bit.  This is used to put the UART into a diagnostic mode for test purposes.  If operating in UART mode (SIR_MODE not active, MCR[6] set to zero), data on the sout line is held high, while serial data output is looped back to the sin line, internally. In this mode all the interrupts are fully functional. Also, in loopback mode, the modem control inputs (dsr_n, cts_n, ri_n, dcd_n) are disconnected and the modem control outputs (dtr_n, rts_n, out1_n, out2_n) are looped back to the inputs, internally.  If operating in infrared mode (SIR_MODE active, MCR[6] set to one), data on the sir_out_n line is held low, while serial data output is inverted and looped back to the sir_in line.                                                                                                                              | 0x0   |
| 3   | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0   |
| 2   | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0   |
| 1   | R/W  | UART_RTS  | Request to Send.  This is used to directly control the Request to Send (rts_n) output. The Request To Send (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data.  When Auto RTS Flow Control is not enabled (MCR[5] set to zero), the rts_n signal is set low by programming MCR[1] (RTS) to a high.In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] set to one) and FIFOs enable (FCR[0] set to one), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold). The rts_n signal is de-asserted when MCR[1] is set low.  Note that in Loopback mode (MCR[4] set to one), the rts_n output is held inactive high while the value of this location is internally looped back to an input. | 0x0   |
| 0   | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0   |

## Table 355: UART\_LSR\_REG (0x50001014)

| Mode | Symbol         | Description                                                               | Reset                                         |
|------|----------------|---------------------------------------------------------------------------|-----------------------------------------------|
| -    | 1              | Reserved                                                                  | 0x0                                           |
| R    | UART_RFE       | Receiver FIFO Error bit. This bit is only relevant when FIFOs are enabled | 0x0                                           |
|      | Mode<br>-<br>R |                                                                           | Reserved  R UART_RFE Receiver FIFO Error bit. |



Final

| Bit | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                  | Reset |
|-----|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |           | there is at least one parity error, framing error, or break indication in the FIFO.                                                                                                                                                                                                                                                                                                                          |       |
|     |      |           | 0 = no error in RX FIFO                                                                                                                                                                                                                                                                                                                                                                                      |       |
|     |      |           | 1 = error in RX FIFO                                                                                                                                                                                                                                                                                                                                                                                         |       |
|     |      |           | This bit is cleared when the LSR is read and the character with the error is at the top of the receiver FIFO and there are no subsequent errors in the FIFO.                                                                                                                                                                                                                                                 |       |
| 6   | R    | UART_TEMT | Transmitter Empty bit.                                                                                                                                                                                                                                                                                                                                                                                       | 0x1   |
|     |      |           | If FIFOs enabled (FCR[0] set to one), this bit is set whenever the Transmitter Shift Register and the FIFO are both empty. If FIFOs are disabled, this bit is set whenever the Transmitter Holding Register(THR) and the Transmitter Shift Register are both empty.                                                                                                                                          |       |
| 5   | R    | UART_THRE | Transmit Holding Register Empty bit.                                                                                                                                                                                                                                                                                                                                                                         | 0x1   |
|     |      |           | If THRE mode is disabled (IER[7] set to zero) and regardless of FIFO's being implemented/enabled or not, this bit indicates that the THR or TX FIFO is empty.                                                                                                                                                                                                                                                |       |
|     |      |           | This bit is set whenever data is transferred from the THR or TX FIFO to the transmitter shift                                                                                                                                                                                                                                                                                                                |       |
|     |      |           | register and no new data has been written to the THR or TX FIFO. This also causes a THRE Interrupt to occur, if the THRE Interrupt is enabled. If both modes are active (IER[7] set to one and FCR[0] set to one respectively), the functionality is switched to indicate the transmitter FIFO is full, and no longer controls THRE interrupts, which are then controlled by the FCR[5:4] threshold setting. |       |
| 4   | R    | UART_BI   | Break Interrupt bit.                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
|     |      |           | This is used to indicate the detection of a break sequence on the serial input data.                                                                                                                                                                                                                                                                                                                         |       |
|     |      |           | If in UART mode (SIR_MODE == Disabled), it is set whenever the serial input, sin, is held in a logic '0' state for longer than the sum of start time + data bits + parity + stop bits.                                                                                                                                                                                                                       |       |
|     |      |           | If in infrared mode (SIR_MODE == Enabled), it is set whenever the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of start time + data bits + parity + stop bits. A break condition on serial input causes one and only one character, consisting of all zeros, to be received by the UART.                                                                                |       |
|     |      |           | In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO.                                                                                                                                                                                                                                                |       |
|     |      |           | Reading the LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the LSR is read.                                                                                                                                                                                                                                                                            |       |
| 3   | R    | UART_FE   | Framing Error bit.                                                                                                                                                                                                                                                                                                                                                                                           | 0x0   |
|     |      |           | This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data.                                                                                                                                                                                                                                  |       |



Final

| Bit | Mode | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-----|------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |         | In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO.                                                                                                                                                                                                                             |       |
|     |      |         | When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).        |       |
|     |      |         | 0 = no framing error                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |         | 1 = framing error                                                                                                                                                                                                                                                                                                                                                                                  |       |
|     |      |         | Reading the LSR clears the FE bit.                                                                                                                                                                                                                                                                                                                                                                 |       |
| 2   | R    | UART_PE | Parity Error bit.                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
|     |      |         | This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set.                                                                                                                                                                                                                                                                          |       |
|     |      |         | In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO.                                                                                                                                                                                                                          |       |
|     |      |         | It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).                                                                                                                                                                                                                                            |       |
|     |      |         | 0 = no parity error                                                                                                                                                                                                                                                                                                                                                                                |       |
|     |      |         | 1 = parity error                                                                                                                                                                                                                                                                                                                                                                                   |       |
|     |      |         | Reading the LSR clears the PE bit.                                                                                                                                                                                                                                                                                                                                                                 |       |
| 1   | R    | UART_OE | Overrun error bit.                                                                                                                                                                                                                                                                                                                                                                                 | 0x0   |
|     |      |         | This is used to indicate the occurrence of an overrun error.                                                                                                                                                                                                                                                                                                                                       |       |
|     |      |         | This occurs if a new data character was received before the previous data was read.                                                                                                                                                                                                                                                                                                                |       |
|     |      |         | In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the RBR. When this happens, the data in the RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost. |       |
|     |      |         | 0 = no overrun error                                                                                                                                                                                                                                                                                                                                                                               |       |
|     |      |         | 1 = overrun error                                                                                                                                                                                                                                                                                                                                                                                  |       |
|     |      |         | Reading the LSR clears the OE bit.                                                                                                                                                                                                                                                                                                                                                                 |       |
| 0   | R    | UART_DR | Data Ready bit.                                                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
|     |      |         | This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.                                                                                                                                                                                                                                                                                        |       |
|     |      |         | 0 = no data ready                                                                                                                                                                                                                                                                                                                                                                                  |       |
|     |      |         | 1 = data ready                                                                                                                                                                                                                                                                                                                                                                                     |       |
|     |      |         | This bit is cleared when the RBR is read in non-<br>FIFO mode, or when the receiver FIFO is empty,<br>in FIFO mode.                                                                                                                                                                                                                                                                                |       |

**Final** 

## Table 356: UART\_MSR\_REG (0x50001018)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset |
|------|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:5 | -    | -        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 4    | R    | UART_CTS | Clear to Send.  This is used to indicate the current state of the modem control line cts_n. This bit is the complement of cts_n. When the Clear to Send input (cts_n) is asserted it is an indication that the modem or data set is ready to exchange data with the UART Ctrl.  0 = cts_n input is de-asserted (logic 1)  1 = cts_n input is asserted (logic 0)  In Loopback Mode (MCR[4] = 1), CTS is the same as MCR[1] (RTS). | 0x1   |
| 3:1  | -    | -        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 0    | -    | -        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |

#### Table 357: **UART\_SCR\_REG** (0x5000101C)

| Bit  | Mode | Symbol               | Description                                                                                                       | Reset |
|------|------|----------------------|-------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -                    | Reserved                                                                                                          | 0x0   |
| 7:0  | R/W  | UART_SCRATCH_<br>PAD | This register is for programmers to use as a temporary storage space. It has no defined purpose in the UART Ctrl. | 0x0   |

## Table 358: UART\_SRBR\_STHR0\_REG (0x50001030)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data being lost. |       |

## Table 359: UART\_SRBR\_STHR1\_REG (0x50001034)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data being lost. | 0x0   |

**Final** 

#### Table 360: UART\_SRBR\_STHR2\_REG (0x50001038)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 361: UART\_SRBR\_STHR3\_REG (0x5000103C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data being lost. |       |

## Table 362: UART\_SRBR\_STHR4\_REG (0x50001040)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 363: UART\_SRBR\_STHR5\_REG (0x50001044)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

**Final** 

#### Table 364: UART\_SRBR\_STHR6\_REG (0x50001048)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 365: UART\_SRBR\_STHR7\_REG (0x5000104C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in | 0x0   |

**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 366: UART\_SRBR\_STHR8\_REG (0x50001050)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 367: UART\_SRBR\_STHR9\_REG (0x50001054)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

**Final** 

#### Table 368: UART\_SRBR\_STHR10\_REG (0x50001058)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 369: UART\_SRBR\_STHR11\_REG (0x5000105C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 370: UART\_SRBR\_STHR12\_REG (0x50001060)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 371: UART\_SRBR\_STHR13\_REG (0x50001064)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

**Final** 

#### Table 372: UART\_SRBR\_STHR14\_REG (0x50001068)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 373: UART\_SRBR\_STHR15\_REG (0x5000106C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in | 0x0   |

**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

#### Table 374: UART\_FAR\_REG (0x50001070)

| Bit | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|-----|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | R    | UART_FAR | Description: Writes will have no effect when FIFO_ACCESS == No, always readable. This register is use to enable a FIFO access mode for testing, so that the receive FIFO can be written by the master and the transmit FIFO can be read by the master when FIFO's are implemented and enabled. When FIFO's are not implemented or not enabled it allows the RBR to be written by the master and the THR to be read by the master. 0 = FIFO access mode disabled 1 = FIFO access mode enabled Note, that when the FIFO access mode is enabled/disabled, the control portion of the receive FIFO and transmit FIFO is reset and the FIFO's are treated as empty. | 0x0   |

## Table 375: **UART\_USR\_REG** (0x5000107C)

| Bit  | Mode | Symbol   | Description                                                                                                                              | Reset |
|------|------|----------|------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:5 | -    | -        | Reserved                                                                                                                                 | 0x0   |
| 4    | R    | UART_RFF | Receive FIFO Full.  This is used to indicate that the receive FIFO is completely full.  0 = Receive FIFO not full  1 = Receive FIFO Full | 0x0   |



**Final** 

| Bit | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |           | This bit is cleared when the RX FIFO is no longer full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |
| 3   | R    | UART_RFNE | Receive FIFO Not Empty.  This is used to indicate that the receive FIFO contains one or more entries.  0 = Receive FIFO is empty  1 = Receive FIFO is not empty  This bit is cleared when the RX FIFO is empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 2   | R    | UART_TFE  | Transmit FIFO Empty. This is used to indicate that the transmit FIFO is completely empty.  0 = Transmit FIFO is not empty  1 = Transmit FIFO is empty This bit is cleared when the TX FIFO is no longer empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x1   |
| 1   | R    | UART_TFNF | Transmit FIFO Not Full. This is used to indicate that the transmit FIFO in not full.  0 = Transmit FIFO is full 1 = Transmit FIFO is not full This bit is cleared when the TX FIFO is full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x1   |
| 0   | R    | UART_BUSY | UART Busy. This indicates that a serial transfer is in progress, when cleared indicates that the DW_apb_uart is idle or inactive. 0 - DW_apb_uart is idle or inactive 1 - DW_apb_uart is busy (actively transferring data) Note that it is possible for the UART Busy bit to be cleared even though a new character may have been sent from another device. That is, if the DW_apb_uart has no data in the THR and RBR and there is no transmission in progress and a start bit of a new character has just reached the DW_apb_uart. This is due to the fact that a valid start is not seen until the middle of the bit period and this duration is dependent on the baud divisor that has been programmed. If a second system clock has been implemented (CLOCK_MODE == Enabled) the assertion of this bit will also be delayed by several cycles of the slower clock. | 0x0   |

## Table 376: UART\_TFL\_REG (0x50001080)

| Bit | Mode | Symbol                       | Description                                                                              | Reset |
|-----|------|------------------------------|------------------------------------------------------------------------------------------|-------|
| 4:0 | R    | UART_TRANSMIT_<br>FIFO_LEVEL | Transmit FIFO Level.  This is indicates the number of data entries in the transmit FIFO. | 0x0   |

**Final** 

## Table 377: UART\_RFL\_REG (0x50001084)

| Bit | Mode | Symbol                      | Description                                                                            | Reset |
|-----|------|-----------------------------|----------------------------------------------------------------------------------------|-------|
| 4:0 | R    | UART_RECEIVE_FI<br>FO_LEVEL | Receive FIFO Level.  This is indicates the number of data entries in the receive FIFO. | 0x0   |

#### Table 378: UART\_SRR\_REG (0x50001088)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:3 | -    | -        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| 2    | W    | UART_XFR | XMIT FIFO Reset.  This is a shadow register for the XMIT FIFO Reset bit (FCR[2]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the transmit FIFO. This resets the control portion of the transmit FIFO and treats the FIFO as empty. Note that this bit is 'self-clearing'. It is not necessary to clear this bit. | 0x0   |
| 1    | W    | UART_RFR | RCVR FIFO Reset.  This is a shadow register for the RCVR FIFO Reset bit (FCR[1]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the receive FIFO This resets the control portion of the receive FIFO and treats the FIFO as empty.  Note that this bit is 'self-clearing'. It is not necessary to clear this bit.   | 0x0   |
| 0    | W    | UART_UR  | UART Reset. This asynchronously resets the UART Ctrl and synchronously removes the reset assertion. For a two clock implementation both pclk and sclk domains are reset.                                                                                                                                                                                                                                      | 0x0   |

#### Table 379: **UART\_SRTS\_REG** (0x5000108C)

| Bit  | Mode | Symbol                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|------|------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -                                   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| 0    | R/W  | UART_SHADOW_R<br>EQUEST_TO_SEN<br>D | Shadow Request to Send.  This is a shadow register for the RTS bit (MCR[1]), this can be used to remove the burden of having to performing a read-modify-write on the MCR. This is used to directly control the Request to Send (rts_n) output. The Request To Send (rts_n) output is used to inform the modem or data set that the UART Ctrl is ready to exchange data.  When Auto RTS Flow Control is not enabled (MCR[5] = 0), the rts_n signal is set low by programming MCR[1] (RTS) to a high.  In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] = 1) and FIFOs enable (FCR[0] = 1), the rts_n output is controlled in the | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                             | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold).                                 |       |
|     |      |        | Note that in Loopback mode (MCR[4] = 1), the rts_n output is held inactive-high while the value of this location is internally looped back to an input. |       |

#### Table 380: UART\_SBCR\_REG (0x50001090)

| Bit  | Mode | Symbol                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -                             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 0    | R/W  | UART_SHADOW_B<br>REAK_CONTROL | Shadow Break Control Bit.  This is a shadow register for the Break bit (LCR[6]), this can be used to remove the burden of having to performing a read modify write on the LCR. This is used to cause a break condition to be transmitted to the receiving device.  If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared.  If SIR_MODE active (MCR[6] = 1) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver. | 0x0   |

## Table 381: UART\_SDMAM\_REG (0x50001094)

| Bit  | Mode | Symbol                   | Description                                                                                                                                                                                                                                                                                                                                                                                | Reset |
|------|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -                        | Reserved                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| 0    | R/W  | UART_SHADOW_D<br>MA_MODE | Shadow DMA Mode.  This is a shadow register for the DMA mode bit (FCR[3]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the DMA Mode bit gets updated. This determines the DMA signalling mode used for the dma_tx_req_n and dma_rx_req_n output signals.  0 = mode 0  1 = mode 1 | 0x0   |

## Table 382: UART\_SFE\_REG (0x50001098)

| Bit  | Mode | Symbol        | Description                                                                                                                                                                                                                                                                                               | Reset |
|------|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -             | Reserved                                                                                                                                                                                                                                                                                                  | 0x0   |
| 0    | R/W  | UART_SHADOW_F | Shadow FIFO Enable.                                                                                                                                                                                                                                                                                       | 0x0   |
|      |      | IFO_ENABLE    | This is a shadow register for the FIFO enable bit (FCR[0]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the FIFO enable bit gets updated. This enables/disables the transmit (XMIT) and receive |       |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                | Reset |
|-----|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | (RCVR) FIFOs. If this bit is set to zero (disabled) after being enabled then both the XMIT and RCVR controller portion of FIFOs are reset. |       |

## Table 383: UART\_SRT\_REG (0x5000109C)

| Bit  | Mode | Symbol                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset |
|------|------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:2 | -    | -                            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 1:0  | R/W  | UART_SHADOW_R<br>CVR_TRIGGER | Shadow RCVR Trigger.  This is a shadow register for the RCVR trigger bits (FCR[7:6]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the RCVR trigger bit gets updated.  This is used to select the trigger level in the receiver FIFO at which the Received Data Available Interrupt is generated. It also determines when the dma_rx_req_n signal is asserted when DMA Mode (FCR[3]) = 1. The following trigger levels are supported:  00 = 1 character in the FIFO  01 = FIFO ½ full  10 = FIFO ½ full | 0x0   |
|      |      |                              | 11 = FIFO 2 less than full                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |

## Table 384: **UART\_STET\_REG** (0x500010A0)

| Bit  | Mode | Symbol                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset |
|------|------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:2 | -    | -                                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 1:0  | R/W  | UART_SHADOW_T<br>X_EMPTY_TRIGGE<br>R | Shadow TX Empty Trigger.  This is a shadow register for the TX empty trigger bits (FCR[5:4]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the TX empty trigger bit gets updated.  This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. The following trigger levels are supported:  00 = FIFO empty  01 = 2 characters in the FIFO  10 = FIFO ½ full  11 = FIFO ½ full | 0x0   |

**Final** 

#### Table 385: **UART\_HTX\_REG** (0x500010A4)

| Bit  | Mode | Symbol       | Description                                                                                                                                           | Reset |
|------|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -            | Reserved                                                                                                                                              | 0x0   |
| 0    | R/W  | UART_HALT_TX | This register is use to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled. | 0x0   |
|      |      |              | 0 = Halt TX disabled                                                                                                                                  |       |
|      |      |              | 1 = Halt TX enabled                                                                                                                                   |       |
|      |      |              | Note, if FIFOs are implemented and not enabled, the setting of the halt TX register has no effect on operation.                                       |       |

#### Table 386: UART\_DMASA\_REG (0x500010A8)

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                      | Reset |
|-----|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | W    | DMASA  | This register is use to perform DMA software acknowledge if a transfer needs to be terminated due to an error condition. For example, if the DMA disables the channel, then the DW_apb_uart should clear its request. This will cause the TX request, TX single, RX request and RX single signals to de-assert. Note that this bit is 'self-clearing' and it is not necessary to clear this bit. | 0x0   |

#### Table 387: UART\_DLF\_REG (0x500010C0)

| Bit | Mode | Symbol   | Description                                                                                           | Reset |
|-----|------|----------|-------------------------------------------------------------------------------------------------------|-------|
| 3:0 | R/W  | UART_DLF | The fractional value is added to integer value set by DLH, DLL. Fractional value is equal UART_DLF/16 | 0x0   |

#### Table 388: **UART\_UCV\_REG** (0x500010F8)

| Bit  | Mode | Symbol | Description       | Reset  |
|------|------|--------|-------------------|--------|
| 15:0 | R    | UCV    | Component Version | 0x352A |

#### Table 389: UART\_UCV\_HIGH\_REG (0x500010FA)

| Bit  | Mode | Symbol | Description       | Reset  |
|------|------|--------|-------------------|--------|
| 15:0 | R    | UCV    | Component Version | 0x3331 |

#### Table 390: UART\_CTR\_REG (0x500010FC)

| Bit  | Mode | Symbol | Description             | Reset |
|------|------|--------|-------------------------|-------|
| 15:0 | R    | CTR    | Component Type Register | 0x110 |



**Final** 

## Table 391: UART\_CTR\_HIGH\_REG (0x500010FE)

| Bit  | Mode | Symbol | Description             | Reset  |
|------|------|--------|-------------------------|--------|
| 15:0 | R    | CTR    | Component Type Register | 0x4457 |

#### Table 392: UART2\_RBR\_THR\_DLL\_REG (0x50001100)

| Bit  | Mode | Symbol      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 7:0  | R/W  | RBR_THR_DLL | Receive Buffer Register: (RBR).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x0   |
|      |      |             | This register contains the data byte received on the serial input port (sin) in UART mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. |       |
|      |      |             | Transmit Holding Register: (THR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
|      |      |             | This register contains data to be transmitted on the serial output port (sout) in UART mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, 16 number of characters of data may be written to the THR before the FIFO is full. Any attempt to write data when the FIFO is full results in the write data being lost.                                                                |       |
|      |      |             | Divisor Latch (Low): (DLL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |
|      |      |             | This register makes up the lower 8-bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set. The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows:                                                                                                                                                                                                                                                                                                                                                    |       |
|      |      |             | baud rate = (serial clock freq) / (16 * divisor)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
|      |      |             | Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications will occur. Also, once the Divisor Latch is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.                                                                                                                                                                                                                                                                                                                                                                                                              |       |
|      |      |             | For the Divisor Latch (High) bits, see register UART_IER_DLH_REG.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |

**Final** 

Table 393: UART2\_IER\_DLH\_REG (0x50001104)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset |
|------|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0   |
| 7    | R/W  | PTIME_dlh7 | Interrupt Enable Register: PTIME, Programmable THRE Interrupt Mode Enable. This is used to enable/disable the generation of THRE Interrupt. 0 = disabled 1 = enabled.                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
|      |      |            | Divisor Latch (High): DLH7, Bit 7 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                                                                                                                                                                                                                                           |       |
| 6:4  | R/W  | dlh6_4     | Divisor Latch (High): DLH6 to DLH4, Bits 6 to 4 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set, otherwise, this field is reserved. See register UART_RBR_THR_DLL_REG.                                                                                                                                                                                                          | 0x0   |
| 3    | R/W  | EDSSI_dlh3 | Interrupt Enable Register: EDSSI, Enable Modem Status Interrupt. This is used to enable/disable the generation of Modem Status Interrupt. This is the fourth highest priority interrupt. 0 = disabled 1 = enabled  Divisor Latch (High): DLH3, Bit 3 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                        | 0x0   |
| 2    | R/W  | ELSI_dhl2  | Interrupt Enable Register: ELSI, Enable Receiver Line Status Interrupt. This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt. 0 = disabled 1 = enabled  Divisor Latch (High): DLH2, Bit 2 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG.                                | 0x0   |
| 1    | R/W  | ETBEI_dlh1 | Interrupt Enable Register: ETBEI, Enable Transmit Holding Register Empty Interrupt. This is used to enable/disable the generation of Transmitter Holding Register Empty Interrupt. This is the third highest priority interrupt. 0 = disabled 1 = enabled Divisor Latch (High): DLH1, Bit 1 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG. | 0x0   |
| 0    | R/W  | ERBFI_dlh0 | Interrupt Enable Register: ERBFI, Enable Received Data Available Interrupt. This is used to enable/disable the generation of Received Data                                                                                                                                                                                                                                                                                                                                                                               | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                    | Reset |
|-----|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | Available Interrupt and the Character Timeout Interrupt (if in FIFO mode and FIFO's enabled). These are the second highest priority interrupts. 0 = disabled 1 = enabled                                                                                       |       |
|     |      |        | Divisor Latch (High): DLH0, Bit 0 of the upper part of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may be accessed only when the DLAB bit (LCR[7]) is set. See register UART_RBR_THR_DLL_REG. |       |

#### Table 394: UART2\_IIR\_FCR\_REG (0x50001108)

| Bit | Mode | Symbol         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset |
|-----|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 7:6 | R/W  | UART_FIFOSE_RT | On read FIFO's Enabled (or FIFOSE): This is used to indicate whether the FIFO's are enabled or disabled. 00 = disabled. 11 = enabled. On write RCVR Trigger (or RT):. This is used to select the trigger level in the receiver FIFO at which the Received Data Available Interrupt will be generated. In auto flow control mode it is used to determine when the rts_n signal will be deasserted. It also determines when the dma_rx_req_n signal will be asserted when in certain modes of operation. The following trigger levels are supported: 00 = 1 character in the FIFO 01 = FIFO 1/4 full 10 = FIFO 1/2 full 11 = FIFO 2 less than full | 0x0   |
| 5:4 | R0/W | UART_TET       | On read reserved On Write TX Empty Trigger (or TET): This is used to select the empty threshold level at which the THRE Interrupts will be generated when the mode is active. It also determines when the dma_tx_req_n signal will be asserted when in certain modes of operation. The following trigger levels are supported: 00 = FIFO empty 01 = 2 characters in the FIFO 10 = FIFO 1/4 full 11 = FIFO 1/2 full                                                                                                                                                                                                                               | 0x0   |
| 3   | R/W  | UART_IID3_DMAM | On Read (Bit3) Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:  0001 = no interrupt pending.  0010 = THR empty.  0100 = received data available.  0110 = receiver line status.  0111 = busy detect.  1100 = character timeout.  On Write                                                                                                                                                                                                                                                                                                                                   | 0x0   |



**Final** 

| Bit | Mode | Symbol               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset |
|-----|------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |                      | DMA Mode (or DMAM): This determines the DMA signalling mode used for the dma_tx_req_n and dma_rx_req_n output signals. 0 = mode 0 1 = mode 1                                                                                                                                                                                                                                                                                                                                                                              |       |
| 2   | R/W  | UART_IID2_XFIFO<br>R | On Read (Bit2) Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:  0001 = no interrupt pending.  0010 = THR empty.  0100 = received data available.  0110 = receiver line status.  0111 = busy detect.  1100 = character timeout.  On Write  XMIT FIFO Reset (or XFIFOR): This resets the control portion of the transmit FIFO and treats the FIFO as empty. Note that this bit is 'self-clearing' and it is not necessary to clear this bit.          | 0x0   |
| 1   | R/W  | UART_IID1_RFIFO<br>E | On Read (Bit1) Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:  0001 = no interrupt pending.  0010 = THR empty.  0100 = received data available.  0110 = receiver line status.  0111 = busy detect.  1100 = character timeout.  On Write  RCVR FIFO Reset (or RFIFOR): This resets the control portion of the receive FIFO and treats the FIFO as empty. Note that this bit is 'self-clearing' and it is not necessary to clear this bit.           | 0x0   |
| 0   | R/W  | UART_IID0_FIFOE      | On Read (Bit0) Interrupt ID (or IID): This indicates the highest priority pending interrupt which can be one of the following types:  0001 = no interrupt pending.  0010 = THR empty.  0100 = received data available.  0110 = receiver line status.  0111 = busy detect.  1100 = character timeout.  On Write  FIFO Enable (or FIFOE): This enables/disables the transmit (XMIT) and receive (RCVR) FIFO's.  Whenever the value of this bit is changed both the XMIT and RCVR controller portion of FIFO's will be reset | 0x1   |

**Final** 

## Table 395: UART2\_LCR\_REG (0x5000110C)

| Bit  | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset |
|------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 7    | R/W  | UART_DLAB | Divisor Latch Access Bit.Writeable only when UART is not busy (USR[0] is zero).                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
|      |      |           | This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART.                                                                                                                                                                                                                                                                                                                                                     |       |
|      |      |           | This bit must be cleared after initial baud rate setup in order to access other registers.                                                                                                                                                                                                                                                                                                                                                                                       |       |
| 6    | R/W  | UART_BC   | Break Control Bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0   |
|      |      |           | This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If active (MCR[6] set to one) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low. |       |
| 5    | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |
| 4    | R/W  | UART_EPS  | Even Parity Select. Writeable only when UART is not busy (USR[0] is zero).                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
|      |      |           | This is used to select between even and odd parity, when parity is enabled (PEN set to one). If set to one, an even number of logic 1s is transmitted or checked. If set to zero, an odd number of logic 1s is transmitted or checked.                                                                                                                                                                                                                                           |       |
| 3    | R/W  | UART_PEN  | Parity Enable. Writeable only when UART is not busy (USR[0] is zero)                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
|      |      |           | This bit is used to enable and disable parity generation and detection in transmitted and received serial character respectively.                                                                                                                                                                                                                                                                                                                                                |       |
|      |      |           | 0 = parity disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |
|      |      |           | 1 = parity enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |
| 2    | R/W  | UART_STOP | Number of stop bits. Writeable only when UART is not busy (USR[0] is zero).                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
|      |      |           | This is used to select the number of stop bits per character that the peripheral transmits and receives. If set to zero, one stop bit is transmitted in the serial data.                                                                                                                                                                                                                                                                                                         |       |
|      |      |           | If set to one and the data bits are set to 5 (LCR[1:0] set to zero) one and a half stop bits is transmitted. Otherwise, two stop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.                                                                                                                                                                                                                    |       |
|      |      |           | 0 = 1 stop bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |
|      |      |           | 1 = 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit                                                                                                                                                                                                                                                                                                                                                                                                                   |       |
| 1:0  | R/W  | UART_DLS  | Data Length Select.Writeable only when UART is not busy (USR[0] is zero).                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
|      |      |           | This is used to select the number of data bits per character that the peripheral transmits and                                                                                                                                                                                                                                                                                                                                                                                   |       |



**Final** 

| Bit | Mode | Symbol | Description                                                     | Reset |
|-----|------|--------|-----------------------------------------------------------------|-------|
|     |      |        | receives. The number of bit that may be selected areas follows: |       |
|     |      |        | 00 = 5 bits                                                     |       |
|     |      |        | 01 = 6 bits                                                     |       |
|     |      |        | 10 = 7 bits                                                     |       |
|     |      |        | 11 = 8 bits                                                     |       |

## Table 396: UART2\_MCR\_REG (0x50001110)

| Bit  | Mode | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset |
|------|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:5 | -    | -       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0   |
| 4    | R/W  | UART_LB | LoopBack Bit.  This is used to put the UART into a diagnostic mode for test purposes.  If operating in UART mode (SIR_MODE not active, MCR[6] set to zero), data on the sout line is held high, while serial data output is looped back to the sin line, internally. In this mode all the interrupts are fully functional. Also, in loopback mode, the modem control inputs (dsr_n, cts_n, ri_n, dcd_n) are disconnected and the modem control outputs (dtr_n, rts_n, out1_n, out2_n) are looped back to the inputs, internally.  If operating in infrared mode (SIR_MODE active, MCR[6] set to one), data on the sir_out_n line is held low, while serial data output is inverted and looped back to the sir_in line. | 0x0   |
| 3:0  | -    | -       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0   |

## Table 397: UART2\_LSR\_REG (0x50001114)

| Bit  | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                  | Reset |
|------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0   |
| 7    | R    | UART_RFE  | Receiver FIFO Error bit.  This bit is only relevant when FIFOs are enabled (FCR[0] set to one). This is used to indicate if there is at least one parity error, framing error, or break indication in the FIFO.  0 = no error in RX FIFO  1 = error in RX FIFO  This bit is cleared when the LSR is read and the character with the error is at the top of the receiver FIFO and there are no subsequent errors in the FIFO. | 0x0   |
| 6    | R    | UART_TEMT | Transmitter Empty bit.  If FIFOs enabled (FCR[0] set to one), this bit is set whenever the Transmitter Shift Register and the FIFO are both empty. If FIFOs are disabled, this bit is set whenever the Transmitter Holding                                                                                                                                                                                                   | 0x1   |



**Final** 

| Bit | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |           | Register(THR) and the Transmitter Shift Register are both empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |
| 5   | R    | UART_THRE | Transmit Holding Register Empty bit.  If THRE mode is disabled (IER[7] set to zero) and regardless of FIFO's being implemented/enabled or not, this bit indicates that the THR or TX FIFO is empty.  This bit is set whenever data is transferred from the THR or TX FIFO to the transmitter shift register and no new data has been written to the THR or TX FIFO. This also causes a THRE Interrupt to occur, if the THRE Interrupt is enabled. If both modes are active (IER[7] set to one and FCR[0] set to one respectively), the functionality is switched to indicate the transmitter FIFO is full, and no longer controls THRE interrupts, which are then controlled by the FCR[5:4] threshold setting.                                                                                                                                                                                                                     | 0x1   |
| 4   | R    | UART_BI   | Break Interrupt bit.  This is used to indicate the detection of a break sequence on the serial input data.  If in UART mode (SIR_MODE == Disabled), it is set whenever the serial input, sin, is held in a logic '0' state for longer than the sum of start time + data bits + parity + stop bits.  If in infrared mode (SIR_MODE == Enabled), it is set whenever the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of start time + data bits + parity + stop bits. A break condition on serial input causes one and only one character, consisting of all zeros, to be received by the UART.  In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO.  Reading the LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the LSR is read. | 0x0   |
| 3   | R    | UART_FE   | Framing Error bit.  This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data.  In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO.  When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).  0 = no framing error  1 = framing error                                                                                                                       | 0x0   |



**Final** 

| Bit | Mode | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|-----|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |         | Reading the LSR clears the FE bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |
| 2   | R    | UART_PE | Parity Error bit.  This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set.  In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO.  It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).  0 = no parity error  1 = parity error                                                                                                                                                               | 0x0   |
| 1   | R    | UART_OE | Reading the LSR clears the PE bit.  Overrun error bit. This is used to indicate the occurrence of an overrun error. This occurs if a new data character was received before the previous data was read. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the RBR. When this happens, the data in the RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost.  0 = no overrun error 1 = overrun error Reading the LSR clears the OE bit. | 0x0   |
| 0   | R    | UART_DR | Data Ready bit.  This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.  0 = no data ready  1 = data ready  This bit is cleared when the RBR is read in non-FIFO mode, or when the receiver FIFO is empty, in FIFO mode.                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0   |

## Table 398: UART2\_SCR\_REG (0x5000111C)

| Bit  | Mode | Symbol               | Description                                                                                                       | Reset |
|------|------|----------------------|-------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -                    | Reserved                                                                                                          | 0x0   |
| 7:0  | R/W  | UART_SCRATCH_<br>PAD | This register is for programmers to use as a temporary storage space. It has no defined purpose in the UART Ctrl. | 0x0   |

**Final** 

## Table 399: UART2\_SRBR\_STHR0\_REG (0x50001130)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 400: UART2\_SRBR\_STHR1\_REG (0x50001134)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data | 0x0   |

**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

Table 401: UART2\_SRBR\_STHR2\_REG (0x50001138)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 402: UART2\_SRBR\_STHR3\_REG (0x5000113C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

**Final** 

## Table 403: UART2\_SRBR\_STHR4\_REG (0x50001140)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 404: UART2\_SRBR\_STHR5\_REG (0x50001144)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in | 0x0   |

**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 405: UART2\_SRBR\_STHR6\_REG (0x50001148)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 406: UART2\_SRBR\_STHR7\_REG (0x5000114C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data being lost. | 0x0   |

**Final** 

## Table 407: UART2\_SRBR\_STHR8\_REG (0x50001150)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 408: UART2\_SRBR\_STHR9\_REG (0x50001154)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|------|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data | 0x0   |

**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|-----|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

# Table 409: UART2\_SRBR\_STHR10\_REG (0x50001158)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset |
|------|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset |
|-----|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 410: UART2\_SRBR\_STHR11\_REG (0x5000115C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 7:0  | R/W  | SRBR_STHRX | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | OxO   |

**Final** 

Table 411: UART2\_SRBR\_STHR12\_REG (0x50001160)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

## Table 412: UART2\_SRBR\_STHR13\_REG (0x50001164)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|------|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 413: UART2\_SRBR\_STHR14\_REG (0x50001168)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-----|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |       |

## Table 414: UART2\_SRBR\_STHR15\_REG (0x5000116C)

| Bit  | Mode | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|------|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | -    | -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0   |
| 7:0  | R/W  | SRBR_STHRx | Shadow Receive Buffer Register x: This is a shadow register for the RBR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it will be overwritten, resulting in an overrun error. If FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO will be preserved but any incoming data will be lost. An overrun error will also occur. Shadow Transmit Holding Register 0: This is a shadow register for the THR and has been allocated sixteen 32-bit locations so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If FIFO's are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If FIFO's are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. | 0x0   |

**Final** 

Table 415: UART2\_FAR\_REG (0x50001170)

| Bit | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|-----|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | R    | UART_FAR | Description: Writes will have no effect when FIFO_ACCESS == No, always readable. This register is use to enable a FIFO access mode for testing, so that the receive FIFO can be written by the master and the transmit FIFO can be read by the master when FIFO's are implemented and enabled. When FIFO's are not implemented or not enabled it allows the RBR to be written by the master and the THR to be read by the master. 0 = FIFO access mode disabled 1 = FIFO access mode enabled Note, that when the FIFO access mode is enabled/disabled, the control portion of the receive FIFO and transmit FIFO is reset and the FIFO's are treated as empty. | 0x0   |

## Table 416: UART2\_USR\_REG (0x5000117C)

| Bit  | Mode | Symbol    | Description                                                                                                                                                                                                                                                                                           | Reset |
|------|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:5 | -    | -         | Reserved                                                                                                                                                                                                                                                                                              | 0x0   |
| 4    | R    | UART_RFF  | Receive FIFO Full.                                                                                                                                                                                                                                                                                    | 0x0   |
|      |      |           | This is used to indicate that the receive FIFO is completely full.                                                                                                                                                                                                                                    |       |
|      |      |           | 0 = Receive FIFO not full                                                                                                                                                                                                                                                                             |       |
|      |      |           | 1 = Receive FIFO Full                                                                                                                                                                                                                                                                                 |       |
|      |      |           | This bit is cleared when the RX FIFO is no longer full.                                                                                                                                                                                                                                               |       |
| 3    | R    | UART_RFNE | Receive FIFO Not Empty.                                                                                                                                                                                                                                                                               | 0x0   |
|      |      |           | This is used to indicate that the receive FIFO contains one or more entries.                                                                                                                                                                                                                          |       |
|      |      |           | 0 = Receive FIFO is empty                                                                                                                                                                                                                                                                             |       |
|      |      |           | 1 = Receive FIFO is not empty                                                                                                                                                                                                                                                                         |       |
|      |      |           | This bit is cleared when the RX FIFO is empty.                                                                                                                                                                                                                                                        |       |
| 2    | R    | UART_TFE  | Transmit FIFO Empty.                                                                                                                                                                                                                                                                                  | 0x1   |
|      |      |           | This is used to indicate that the transmit FIFO is completely empty.                                                                                                                                                                                                                                  |       |
|      |      |           | 0 = Transmit FIFO is not empty                                                                                                                                                                                                                                                                        |       |
|      |      |           | 1 = Transmit FIFO is empty                                                                                                                                                                                                                                                                            |       |
|      |      |           | This bit is cleared when the TX FIFO is no longer empty.                                                                                                                                                                                                                                              |       |
| 1    | R    | UART_TFNF | Transmit FIFO Not Full.                                                                                                                                                                                                                                                                               | 0x1   |
|      |      |           | This is used to indicate that the transmit FIFO in not full.                                                                                                                                                                                                                                          |       |
|      |      |           | 0 = Transmit FIFO is full                                                                                                                                                                                                                                                                             |       |
|      |      |           | 1 = Transmit FIFO is not full                                                                                                                                                                                                                                                                         |       |
|      |      |           | This bit is cleared when the TX FIFO is full.                                                                                                                                                                                                                                                         |       |
| 0    | R    | UART_BUSY | UART Busy. This indicates that a serial transfer is in progress, when cleared indicates that the DW_apb_uart is idle or inactive. 0 - DW_apb_uart is idle or inactive 1 - DW_apb_uart is busy (actively transferring data) Note that it is possible for the UART Busy bit to be cleared even though a | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|-----|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | new character may have been sent from another device. That is, if the DW_apb_uart has no data in the THR and RBR and there is no transmission in progress and a start bit of a new character has just reached the DW_apb_uart. This is due to the fact that a valid start is not seen until the middle of the bit period and this duration is dependent on the baud divisor that has been programmed. If a second system clock has been implemented (CLOCK_MODE == Enabled) the assertion of this bit will also be delayed by several cycles of the slower clock. |       |

## Table 417: UART2\_TFL\_REG (0x50001180)

| Bit | Mode | Symbol                       | Description                                                                              | Reset |
|-----|------|------------------------------|------------------------------------------------------------------------------------------|-------|
| 4:0 | R    | UART_TRANSMIT_<br>FIFO_LEVEL | Transmit FIFO Level.  This is indicates the number of data entries in the transmit FIFO. | 0x0   |

## Table 418: UART2\_RFL\_REG (0x50001184)

| Bit | Mode | Symbol                      | Description                                                                            | Reset |
|-----|------|-----------------------------|----------------------------------------------------------------------------------------|-------|
| 4:0 | R    | UART_RECEIVE_FI<br>FO_LEVEL | Receive FIFO Level.  This is indicates the number of data entries in the receive FIFO. | 0x0   |

## Table 419: UART2\_SRR\_REG (0x50001188)

| Bit  | Mode | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                  | Reset |
|------|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:3 | -    | -        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0   |
| 2    | W    | UART_XFR | XMIT FIFO Reset. This is a shadow register for the XMIT FIFO Reset bit (FCR[2]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the transmit FIFO. This resets the control portion of the transmit FIFO and treats the FIFO as empty. Note that this bit is 'self-clearing'. It is not necessary to clear this bit. | 0x0   |
| 1    | W    | UART_RFR | RCVR FIFO Reset.  This is a shadow register for the RCVR FIFO Reset bit (FCR[1]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the receive FIFO This resets the control portion of the receive FIFO and treats the FIFO as empty.  Note that this bit is 'self-clearing'. It is not necessary to clear this bit.  | 0x0   |
| 0    | W    | UART_UR  | UART Reset. This asynchronously resets the UART Ctrl and synchronously removes the reset                                                                                                                                                                                                                                                                                                                     | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                     | Reset |
|-----|------|--------|---------------------------------------------------------------------------------|-------|
|     |      |        | assertion. For a two clock implementation both pclk and sclk domains are reset. |       |

## Table 420: UART2\_SBCR\_REG (0x50001190)

| Bit  | Mode | Symbol                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -                             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 0    | R/W  | UART_SHADOW_B<br>REAK_CONTROL | Shadow Break Control Bit.  This is a shadow register for the Break bit (LCR[6]), this can be used to remove the burden of having to performing a read modify write on the LCR. This is used to cause a break condition to be transmitted to the receiving device.  If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared.  If SIR_MODE active (MCR[6] = 1) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver. | 0x0   |

## Table 421: UART2\_SDMAM\_REG (0x50001194)

| Bit  | Mode | Symbol                   | Description                                                                                                                                                                                                                                                                                                                                                                                | Reset |
|------|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -                        | Reserved                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| 0    | R/W  | UART_SHADOW_D<br>MA_MODE | Shadow DMA Mode.  This is a shadow register for the DMA mode bit (FCR[3]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the DMA Mode bit gets updated. This determines the DMA signalling mode used for the dma_tx_req_n and dma_rx_req_n output signals.  0 = mode 0  1 = mode 1 | 0x0   |

#### Table 422: UART2\_SFE\_REG (0x50001198)

| Bit  | Mode | Symbol                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset |
|------|------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -                           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0   |
| 0    | R/W  | UART_SHADOW_F<br>IFO_ENABLE | Shadow FIFO Enable. This is a shadow register for the FIFO enable bit (FCR[0]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the FIFO enable bit gets updated. This enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. If this bit is set to zero (disabled) after being enabled then both the XMIT and RCVR controller portion of FIFOs are reset. | 0x0   |

**Final** 

## Table 423: UART2\_SRT\_REG (0x5000119C)

| Bit  | Mode | Symbol                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset |
|------|------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:2 | -    | -                            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
| 1:0  | R/W  | UART_SHADOW_R<br>CVR_TRIGGER | Shadow RCVR Trigger.  This is a shadow register for the RCVR trigger bits (FCR[7:6]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the RCVR trigger bit gets updated.  This is used to select the trigger level in the receiver FIFO at which the Received Data Available Interrupt is generated. It also determines when the dma_rx_req_n signal is asserted when DMA Mode (FCR[3]) = 1. The following trigger levels are supported:  00 = 1 character in the FIFO 01 = FIFO ½ full 10 = FIFO ½ full 11 = FIFO 2 less than full | 0x0   |

## Table 424: **UART2\_STET\_REG** (0x500011A0)

| Bit  | Mode | Symbol                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset |
|------|------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:2 | -    | -                                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x0   |
| 1:0  | R/W  | UART_SHADOW_T<br>X_EMPTY_TRIGGE<br>R | Shadow TX Empty Trigger.  This is a shadow register for the TX empty trigger bits (FCR[5:4]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the TX empty trigger bit gets updated.  This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. The following trigger levels are supported:  00 = FIFO empty  01 = 2 characters in the FIFO  10 = FIFO ½ full | 0x0   |

## Table 425: UART2\_HTX\_REG (0x500011A4)

| Bit  | Mode | Symbol       | Description                                                                                                                                                                                      | Reset |
|------|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:1 | -    | -            | Reserved                                                                                                                                                                                         | 0x0   |
| 0    | R/W  | UART_HALT_TX | This register is use to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled.  0 = Halt TX disabled  1 = Halt TX enabled | 0x0   |



**Final** 

| Bit | Mode | Symbol | Description                                                                                                     | Reset |
|-----|------|--------|-----------------------------------------------------------------------------------------------------------------|-------|
|     |      |        | Note, if FIFOs are implemented and not enabled, the setting of the halt TX register has no effect on operation. |       |

#### Table 426: UART2\_DMASA\_REG (0x500011A8)

| Bit | Mode | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                      | Reset |
|-----|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 0   | W    | DMASA  | This register is use to perform DMA software acknowledge if a transfer needs to be terminated due to an error condition. For example, if the DMA disables the channel, then the DW_apb_uart should clear its request. This will cause the TX request, TX single, RX request and RX single signals to de-assert. Note that this bit is 'self-clearing' and it is not necessary to clear this bit. | 0x0   |

## Table 427: UART2\_DLF\_REG (0x500011C0)

| Bit | Mode | Symbol   | Description                                                                                           | Reset |
|-----|------|----------|-------------------------------------------------------------------------------------------------------|-------|
| 3:0 | R/W  | UART_DLF | The fractional value is added to integer value set by DLH, DLL. Fractional value is equal UART_DLF/16 | 0x0   |

## Table 428: UART2\_UCV\_REG (0x500011F8)

| Bit  | Mode | Symbol | Description       | Reset  |
|------|------|--------|-------------------|--------|
| 15:0 | R    | UCV    | Component Version | 0x352A |

## Table 429: UART2\_UCV\_HIGH\_REG (0x500011FA)

| Bit  | Mode | Symbol | Description       | Reset  |
|------|------|--------|-------------------|--------|
| 15:0 | R    | UCV    | Component Version | 0x3331 |

## Table 430: UART2\_CTR\_REG (0x500011FC)

| Bit  | Mode | Symbol | Description             | Reset |
|------|------|--------|-------------------------|-------|
| 15:0 | R    | CTR    | Component Type Register | 0x110 |

#### Table 431: UART2\_CTR\_HIGH\_REG (0x500011FE)

| Bit  | Mode | Symbol | Description             | Reset  |
|------|------|--------|-------------------------|--------|
| 15:0 | R    | CTR    | Component Type Register | 0x4457 |



**Final** 

## **32.19 Chip Version Registers**

#### Table 432: Register map Version

| Address    | Register     | Description                     |
|------------|--------------|---------------------------------|
| 0x50003200 | CHIP_ID1_REG | Chip identification register 1. |
| 0x50003204 | CHIP_ID2_REG | Chip identification register 2. |
| 0x50003208 | CHIP_ID3_REG | Chip identification register 3. |
| 0x5000320C | CHIP_ID4_REG | Chip identification register 4. |

## Table 433: CHIP\_ID1\_REG (0x50003200)

| Bit | Mode | Symbol   | Description                                     | Reset |
|-----|------|----------|-------------------------------------------------|-------|
| 7:0 | R    | CHIP_ID1 | First character of device type "2632" in ASCII. | 0x32  |

#### Table 434: CHIP\_ID2\_REG (0x50003204)

| Е | Bit         | Mode | Symbol   | Description                                      | Reset |
|---|-------------|------|----------|--------------------------------------------------|-------|
| 7 | <b>'</b> :0 | R    | CHIP_ID2 | Second character of device type "2632" in ASCII. | 0x36  |

## Table 435: CHIP\_ID3\_REG (0x50003208)

| Bit | Mode | Symbol   | Description                                     | Reset |
|-----|------|----------|-------------------------------------------------|-------|
| 7:0 | R    | CHIP_ID3 | Third character of device type "2632" in ASCII. | 0x33  |

## Table 436: CHIP\_ID4\_REG (0x5000320C)

| Bit | Mode | Symbol   | Description                                      | Reset |
|-----|------|----------|--------------------------------------------------|-------|
| 7:0 | R    | CHIP_ID4 | Fourth character of device type "2632" in ASCII. | 0x32  |

**Final** 

## 32.20 Wake-Up Registers

## Table 437: Register map WKUP

| Address    | Register                  | Description                                               |
|------------|---------------------------|-----------------------------------------------------------|
| 0x50000100 | WKUP_CTRL_REG             | Control register for the wakeup counter                   |
| 0x50000102 | WKUP_COMPARE_R<br>EG      | Number of events before wakeup interrupt                  |
| 0x50000104 | WKUP_IRQ_STATUS<br>_REG   | Reset wakeup interrupt                                    |
| 0x50000106 | WKUP_COUNTER_R<br>EG      | Actual number of events of the wakeup counter             |
| 0x50000108 | WKUP_SELECT_GPI<br>O_REG  | Select which inputs from P0 port can trigger wkup counter |
| 0x5000010A | WKUP2_SELECT_GPI<br>O_REG | Select which inputs from P1 port can trigger wkup counter |
| 0x5000010C | WKUP_POL_GPIO_R<br>EG     | Select the sensitivity polarity for each P0 input         |
| 0x5000010E | WKUP2_POL_GPIO_<br>REG    | Select the sensitivity polarity for each P1 input         |

## Table 438: WKUP\_CTRL\_REG (0x50000100)

| Bit | Mode | Symbol               | Description                                                                                                                                                                      | Reset |
|-----|------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 8   | R/W  | WKUP2_ENABLE_I<br>RQ | 0 = No interrupt will be generated 1 = If the event counter2 reaches the value set by WKUP_COMPARE_REG an IRQ will be generated                                                  | 0x0   |
| 7   | R/W  | WKUP_ENABLE_IR<br>Q  | 0 = No interrupt will be generated 1 = If the event counter reaches the value set by WKUP_COMPARE_REG an IRQ will be generated                                                   | 0x0   |
| 6   | R/W  | WKUP_SFT_KEYHI<br>T  | 0 = No effect 1 = Emulate key hit. The event counter and counter2 will increment by 1 (after debouncing if enabled). First make this bit 0 before any new key hit can be sensed. | 0x0   |
| 5:0 | R/W  | WKUP_DEB_VALU<br>E   | Keyboard debounce time (N*1 ms with N = 1 to 63).  0x0: no debouncing  0x1 to 0x3F: 1 ms to 63 ms debounce time                                                                  | 0x0   |

## Table 439: WKUP\_COMPARE\_REG (0x50000102)

| Bit | Mode | Symbol       | Description                                                                                                                  | Reset |
|-----|------|--------------|------------------------------------------------------------------------------------------------------------------------------|-------|
| 7:0 | R/W  | WKUP_COMPARE | Defines the number of events -1 that have to be counted before the wake-up interrupt will be given. value 0 means one event. | 0x0   |

**Final** 

## Table 440: WKUP\_IRQ\_STATUS\_REG (0x50000104)

| Bit | Mode | Symbol               | Description                                                                    | Reset |
|-----|------|----------------------|--------------------------------------------------------------------------------|-------|
| 3   | R0/W | WKUP2_CNTR_RS<br>T   | Writing 1 will reset the event2 counter                                        | 0x0   |
| 2   | R0/W | WKUP_CNTR_RST        | Writing 1 will reset the event counter                                         | 0x0   |
| 1   | R/W  | WKUP2_IRQ_STAT<br>US | Gives 1 when there is a wkup2 pending IRQ. Writing 1 will reset the interrupt. | 0x0   |
| 0   | R/W  | WKUP_IRQ_STATU<br>S  | Gives 1 when there is a wkup pending IRQ. Writing 1 will reset the interrupt.  | 0x0   |

## Table 441: WKUP\_COUNTER\_REG (0x50000106)

| Bit  | Mode | Symbol       | Description                                                                                                                                                      | Reset |
|------|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:8 | R    | EVENT2_VALUE | This value represents the number of events that have been counted so far. It will be reset by writting to the WKUP_CNTR_RST bit field of the WKUP_IRQ_STATUS_REG | 0x0   |
| 7:0  | R    | EVENT_VALUE  |                                                                                                                                                                  |       |

## Table 442: WKUP\_SELECT\_GPIO\_REG (0x50000108)

| Bit  | Mode | Symbol               | Description                                                                                               | Reset |
|------|------|----------------------|-----------------------------------------------------------------------------------------------------------|-------|
| 11:0 | R/W  | WKUP_SELECT_G<br>PIO | 0 = Input P0x is not enabled for wake-up event counter 1 = Input P0x is enabled for wake-up event counter | 0x0   |

## Table 443: WKUP2\_SELECT\_GPIO\_REG (0x5000010A)

| Bit  | Mode | Symbol                | Description                                                                                               | Reset |
|------|------|-----------------------|-----------------------------------------------------------------------------------------------------------|-------|
| 11:0 | R/W  | WKUP2_SELECT_<br>GPIO | 0 = Input P0x is not enabled for wake-up event counter 1 = Input P0x is enabled for wake-up event counter | 0x0   |

## Table 444: WKUP\_POL\_GPIO\_REG (0x5000010C)

| Bit  | Mode | Symbol        | Description                                                                                                                                                  | Reset |
|------|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 11:0 | R/W  | WKUP_POL_GPIO | 0 = The enabled input P0x increments the event counter if that input goes high 1 = The enabled input P0x increments the event counter if that input goes low | 0x0   |



**Final** 

## Table 445: WKUP2\_POL\_GPIO\_REG (0x5000010E)

| Bit  | Mode | Symbol         | Description                                                                                                                                                    | Reset |
|------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 11:0 | R/W  | WKUP2_POL_GPIO | 0 = The enabled input P0x increments the event2 counter if that input goes high 1 = The enabled input P0x increments the event2 counter if that input goes low | 0x0   |

**Final** 

# 32.21 Watchdog Registers

## Table 446: Register map WDOG

| Address    | Register              | Description                |
|------------|-----------------------|----------------------------|
| 0x50003100 | WATCHDOG_REG          | Watchdog timer register.   |
| 0x50003102 | WATCHDOG_CTRL_<br>REG | Watchdog control register. |

## Table 447: WATCHDOG\_REG (0x50003100)

| Bit  | Mode | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|------|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:9 | R0/W | WDOG_WEN     | 0000.000 = Write enable for Watchdog timer else Write disable. This filter prevents unintentional presetting the watchdog with a SW run-away.                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| 8    | R/W  | WDOG_VAL_NEG | <ul><li>0 = Watchdog timer value is positive.</li><li>1 = Watchdog timer value is negative.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| 7:0  | R/W  | WDOG_VAL     | Write: Watchdog timer reload value. Note that all bits 15-9 must be 0 to reload this register. Read: Actual Watchdog timer value. Decremented by 1 every 10.24 ms. Bit 8 indicates a negative counter value. 2, 1, 0, 1FF16, 1FE16 and so on. An NMI or WDOG (SYS) reset is generated under the following conditions: If WATCHDOG_CTRL_REG[NMI_RST] = 0 then If WDOG_VAL = 0 -> NMI (Non Maskable Interrupt) if WDOG_VAL = 1F016 -> WDOG reset -> reload FF16 If WATCHDOG_CTRL_REG[NMI_RST] = 1 then if WDOG_VAL <= 0 -> WDOG reset -> reload FF16 | 0xFF  |

## Table 448: WATCHDOG\_CTRL\_REG (0x50003102)

| Bit  | Mode | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                               | Reset |
|------|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 15:2 | -    | -       |                                                                                                                                                                                                                                                                                                                                                                           | 0x0   |
| 1    | R/W  | -       |                                                                                                                                                                                                                                                                                                                                                                           | 0x0   |
| 0    | R/W  | NMI_RST | 0 = Watchdog timer generates NMI at value 0, and WDOG (SYS) reset at <=-16. Timer can be frozen /resumed using SET_FREEZE_REG[FRZ_WDOG]/ RESET_FREEZE_REG[FRZ_WDOG].  1 = Watchdog timer generates a WDOG (SYS) reset at value 0 and can not be frozen by Software.  Note that this bit can only be set to 1 by SW and only be reset with a WDOG (SYS) reset or SW reset. | 0x0   |
|      |      |         | The watchdog is always frozen when the Cortex-M0 is halted in DEBUG State.                                                                                                                                                                                                                                                                                                |       |

**Final** 

# 33 Ordering Information

## **Table 449: Ordering Information (Samples)**

| Part Number      | Package  | Size (mm)     | Shipment Form | Pack Quantity |
|------------------|----------|---------------|---------------|---------------|
| DA14531-00000FX2 | FCGQFN24 | 2.2 × 3.0     | Reel          | 100/1000      |
| DA14531-00000OG2 | WLCSP17  | 1.694 × 2.032 | Reel          | 100/1000      |
| DA14531-01000FX2 | FCGQFN24 | 2.2 × 3.0     | Reel          | 100/1000      |
| DA14531-01000OG2 | WLCSP17  | 1.694 × 2.032 | Reel          | 100/1000      |

## **Table 450: Ordering Information (Production)**

| Part Number      | Package  | Size (mm)     | Shipment Form | Pack Quantity |
|------------------|----------|---------------|---------------|---------------|
| DA14531-00000FX2 | FCGQFN24 | 2.2 × 3.0     | Reel          | 4000          |
| DA14531-00000OG2 | WLCSP17  | 1.694 × 2.032 | Reel          | 4000          |
| DA14531-01000FX2 | FCGQFN24 | 2.2 × 3.0     | Reel          | 4000          |
| DA14531-01000OG2 | WLCSP17  | 1.694 × 2.032 | Reel          | 4000          |

#### Part Number Legend:

DA14531-RRXXXYYZ

RR: chip revision number

XXX: variant (000: No Flash)

YY: package code (FX: FCGQFN24, OG: WLCSP17)

Z: packing method (1: Tray, 2: Reel, A: Mini-Reel)

**Final** 

## 34 Package Information

### 34.1 Moisture Sensitivity Level (MSL)

The MSL is an indicator for the maximum allowable time period (floor life time) in which a moisture sensitive plastic device, once removed from the dry bag, can be exposed to an environment with a maximum temperature of 30 °C and a maximum relative humidity of 60 % relative humidity (RH.) before the solder reflow process.

WLCSP packages are qualified for MSL 1.

FCGQFN packages are qualified for MSL 1.

**Table 451: MSL Classification** 

| MSL Level | Floor Lifetime | Conditions  |
|-----------|----------------|-------------|
| MSL 4     | 72 hours       | 30°C/60% RH |
| MSL 3     | 168 hours      | 30°C/60% RH |
| MSL 2A    | 4 weeks        | 30°C/60% RH |
| MSL 2     | 1 year         | 30°C/60% RH |
| MSL 1     | Unlimited      | 30°C/85% RH |

## 34.2 WLCSP Handling

Manual handling of WLCSP packages should be reduced to the absolute minimum. In cases where it is still necessary, a vacuum pick-up tool should be used. In extreme cases plastic tweezers could be used, but metal tweezers are not acceptable, since contact may easily damage the silicon chip.

Removal will cause damage to the solder balls and therefore a removed sample cannot be reused.

The WLCSP package has been coated to reduce exposure to ambient light, however WLCSP packages can remain sensitive to visible and infrared light. It is recommended to take precautions to properly shield the chip in the final product.

## 34.3 Soldering Information

Refer to the JEDEC standard J-STD-020 for relevant soldering information. This document can be downloaded from <a href="http://www.jedec.org">http://www.jedec.org</a>.

#### 34.4 Package Outlines





Figure 85: WLCSP17 Package Outline Drawing





Figure 86: FCGQFN24 Package Outline Drawing

# RENESAS

## **Ultra Low Power Bluetooth 5.1 SoC**

Final

# **Revision History**

| Revision                                                     | Date                                                                                                                                                                                                                                             | Description                                                                                                                                                              |  |  |  |
|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 3.6                                                          | 26-Sep-2022                                                                                                                                                                                                                                      | Datasheet status: Final. Product status: Production                                                                                                                      |  |  |  |
| <ul><li>Fixed Figure</li><li>Updated Tab</li></ul>           | 21 in v3.5<br>ble 31 in v3.5 Wake up                                                                                                                                                                                                             | codes, variant description)  from column in extended sleep  Extended Sleep and Deep Sleep Modes subsection                                                               |  |  |  |
| 3.5                                                          | 04-Mar-2022 Datasheet status: Final. Product status: Production                                                                                                                                                                                  |                                                                                                                                                                          |  |  |  |
| Changelog:  • Changed VE                                     | BAT_HIGH supplies ope                                                                                                                                                                                                                            | erating condition MAX value to 3.6 V (from 3.3 V)                                                                                                                        |  |  |  |
| 3.4                                                          | 30-Aug-2021                                                                                                                                                                                                                                      | Datasheet status: Final. Product status: Production                                                                                                                      |  |  |  |
| STBY mode                                                    |                                                                                                                                                                                                                                                  | er Programming, OTPC_MODE_REG[OTPC_MODE_MODE]=0x1 for table, V <sub>ESD_HBM_FCGQFN24</sub> is reduced to 2.5 kV for RFIOp and RFIOm pins                                 |  |  |  |
| 3.3                                                          | 09-Mar-2021                                                                                                                                                                                                                                      | Datasheet status: Final. Product status: Production                                                                                                                      |  |  |  |
| <ul><li>Removed du</li><li>Removed m</li></ul>               | plicated register names                                                                                                                                                                                                                          | n Recommended Operating Conditions s in "Reset Signals and Registers" table TP operation from front page er chapter  Datasheet status: Final. Product status: Production |  |  |  |
|                                                              | 00 001 2020                                                                                                                                                                                                                                      | Datasticat status. I mai. I roduct status. I roduction                                                                                                                   |  |  |  |
| -                                                            | e Sensor specification p<br>: Features updated                                                                                                                                                                                                   | parameter updated                                                                                                                                                        |  |  |  |
| 3.1                                                          | 09-Jul-2020                                                                                                                                                                                                                                      | Datasheet status: Final. Product status: Production                                                                                                                      |  |  |  |
| <ul><li>V<sub>BAT_X</sub>, GPA</li><li>SPI Chapter</li></ul> | Changelog:  • WLCSP17 and FCGQFN24 Package Outline Diagram updated  • V <sub>BAT_X</sub> , GPADC, Temperature Sensor and XTAL32K specification parameters updated  • SPI Chapter: Features updated  • Buck, Boost and Bypass PMU figures updated |                                                                                                                                                                          |  |  |  |
| 3.0                                                          | 12-Mar-2020                                                                                                                                                                                                                                      | Datasheet status: Final.                                                                                                                                                 |  |  |  |
| -                                                            | Various updates in figures and text                                                                                                                                                                                                              |                                                                                                                                                                          |  |  |  |
| 2.1                                                          | 17-Oct-2019                                                                                                                                                                                                                                      | Datasheet status: Preliminary.                                                                                                                                           |  |  |  |
|                                                              | Changelog:  Product status update and Datasheet status update  VDD_Clamp recommended setting across temperature added                                                                                                                            |                                                                                                                                                                          |  |  |  |
| 2.0                                                          | 13-Oct-2019                                                                                                                                                                                                                                      | Datasheet status: Preliminary.                                                                                                                                           |  |  |  |
| Changelog:  • Specification                                  | ns                                                                                                                                                                                                                                               |                                                                                                                                                                          |  |  |  |
|                                                              |                                                                                                                                                                                                                                                  |                                                                                                                                                                          |  |  |  |



Final

| Revision                                                                                   | Date        | Description              |  |  |  |
|--------------------------------------------------------------------------------------------|-------------|--------------------------|--|--|--|
| Changelog:                                                                                 |             |                          |  |  |  |
| Ordering Information (Production): Pack Quantity                                           |             |                          |  |  |  |
| Complies with BLE 5.1                                                                      |             |                          |  |  |  |
| 1.4                                                                                        | 03-Jun-2019 | Datasheet status: Target |  |  |  |
| Changelog:                                                                                 |             |                          |  |  |  |
| BooterROM Sequence                                                                         |             |                          |  |  |  |
| PMU Programming                                                                            |             |                          |  |  |  |
| Temperature Sensor: routine for TS reading                                                 |             |                          |  |  |  |
| PMU: Buck, Boost, By-pass block diagram updated: SWs added, LDO_LOW_RET renamed to LDO_LOW |             |                          |  |  |  |
| RCX programming                                                                            |             |                          |  |  |  |
| CLC filter at RFIOp                                                                        |             |                          |  |  |  |
| 1.3                                                                                        | 25-Jan-2019 | Datasheet status: Target |  |  |  |
| Changelog:                                                                                 |             |                          |  |  |  |
| Various Updates                                                                            |             |                          |  |  |  |
| 1.2                                                                                        | 02-Oct-2018 | Datasheet status: Target |  |  |  |
| Changelog:                                                                                 |             |                          |  |  |  |
| FCGQFN24 Package Outline updated                                                           |             |                          |  |  |  |
| 1.1                                                                                        | 30-Aug-2018 | Datasheet status: Target |  |  |  |
| 1.0                                                                                        | 29-Jun-2018 | Datasheet status: Target |  |  |  |

© 2022 Renesas Electronics



**Final** 

#### **Status Definitions**

| Revision   | Datasheet Status | Product Status | Definition                                                                                                                                                                                                                                                                                                                                        |
|------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1. <n></n> | Target           | Development    | This datasheet contains the design specifications for product development.  Specifications may be changed in any manner without notice.                                                                                                                                                                                                           |
| 2. <n></n> | Preliminary      | Qualification  | This datasheet contains the specifications and preliminary characterization data for products in pre-production. Specifications may be changed at any time without notice in order to improve the design.                                                                                                                                         |
| 3. <n></n> | Final            | Production     | This datasheet contains the final specifications for products in volume production. The specifications may be changed at any time in order to improve the design, manufacturing and supply. Major specification changes are communicated via Customer Product Notifications. Datasheet changes are communicated via www.dialog-semiconductor.com. |
| 4. <n></n> | Obsolete         | Archived       | This datasheet contains the specifications for discontinued products. The information is provided for reference only.                                                                                                                                                                                                                             |

#### **RoHS Compliance**

Dialog Semiconductor's suppliers certify that its products are in compliance with the requirements of Directive 2011/65/EU of the European Parliament on the restriction of the use of certain hazardous substances in electrical and electronic equipment. RoHS certificates from our suppliers are available on request.



**Final** 

#### **Important Notice and Disclaimer**

RENESAS ELECTRONICS CORPORATION AND ITS SUBSIDIARIES ("RENESAS") PROVIDES TECHNICAL SPECIFICATIONS AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for developers skilled in the art designing with Renesas products. You are solely responsible for (1) selecting the appropriate products for your application, (2) designing, validating, and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. Renesas grants you permission to use these resources only for development of an application that uses Renesas products. Other reproduction or use of these resources is strictly prohibited. No license is granted to any other Renesas intellectual property or to any third party intellectual property. Renesas disclaims responsibility for, and you will fully indemnify Renesas and its representatives against, any claims, damages, costs, losses, or itabilities arising out of your use of these resources. Renesas' products are provided only subject to Renesas' Terms and Conditions of Sale or other applicable terms agreed to in writing. No use of any Renesas resources expands or otherwise alters any applicable warranties or warranty disclaimers for these products.

© 2022 Renesas Electronics Corporation. All rights reserved.

# **Corporate Headquarters**

TOYOSU FORESIA, 3-2-24 Toyosu

Koto-ku, Tokyo 135-0061, Japan

www.renesas.com

#### **Contact Information**

For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit:

https://www.renesas.com/contact/

#### Trademarks

Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners.

(Rev.1.0 Mar 2020)

# **X-ON Electronics**

Largest Supplier of Electrical and Electronic Components

Click to view similar products for RF System on a Chip - SoC category:

Click to view products by Renesas manufacturer:

Other Similar products are found below:

ATB3225-75012CT-T000 BCM20737A1KML2G BCM43236BKMLG CYBL10463-56LQXI CYBL10563-68FLXIT BCM4322KFBGH

88W8801-B0-NMDE/AK EC25AUXGA-MINIPCIE CYBL10463-56LQXIT CC2511F32RSPR ATWILC1000-MR1100B AX-SFEU-API-1
01-TB05 NRF51422-CFAC-R NRF51822-CDAB-R EM3585-RT NCH-RSL10-101Q48-ABG ATSAMR30E18A-MU BLUENRG-248

EFR32BG13P532F512GM48-C BLUENRG-232 ATWINC1500B-MU-T CC2533F64RHAR CC2538SF23RTQR CC1110F8RHHR AX
SFEU-1-01-TX30 DA14585-00000AT2 EFR32MG12P432F1024GL125-C EFR32BG12P432F1024GL125-C AWR1642ABIGABLQ1

ESP32-D0WD DA14699-00000HR2 DA14691-00000HQ2 DA14695-00000HQ2 ESP8266EX CYBL10561-56LQXI ATWINC1500B-MU-Y

CYBL10163-56LQXI CYBL10462-56LQXI CYBL10563-56LQXI DA14531-00000FX2 DA14531-00000OG2 DA14583-01F01AT2

DA14681-01000U22 DA14697-00000HR2 DA16200-00000A32 DA16200-00000F22 ESP32-S2FN4R2 ESP32-S3FH4R2 ESP32-C3FH4

ESP32-C3FN4